@geotab/zenith 3.1.1-beta.5 → 3.2.0-beta.0

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 (442) hide show
  1. package/README.md +20 -0
  2. package/dist/advancedGroupsFilter/advancedGroupsFilter.js +136 -30
  3. package/dist/advancedGroupsFilter/advancedGroupsFilterForm.js +139 -34
  4. package/dist/advancedGroupsFilter/advancedGroupsFilterFormSection.js +352 -87
  5. package/dist/advancedGroupsFilter/advancedGroupsFilterSectionTooltip.d.ts +0 -1
  6. package/dist/advancedGroupsFilter/advancedGroupsFilterSectionTooltip.js +83 -9
  7. package/dist/alertRaw/alertRaw.js +175 -54
  8. package/dist/banner/bannerMultipLine.js +131 -23
  9. package/dist/banner/bannerSingleLine.js +110 -16
  10. package/dist/betaPill/betaPill.js +111 -20
  11. package/dist/bookmark/bookmark.js +95 -28
  12. package/dist/bulkEditControl/bulkEditControl.js +167 -34
  13. package/dist/calendar/calendar.js +943 -273
  14. package/dist/calendar/calendarUtils.js +157 -85
  15. package/dist/card/card.js +268 -123
  16. package/dist/chart/accessibleChart/accessibleChartNarrative.js +648 -555
  17. package/dist/chart/accessibleChart/accessibleChartTable.js +245 -86
  18. package/dist/chart/chart.js +36 -21
  19. package/dist/chart/chartAxis/chartAxis.js +85 -7
  20. package/dist/checkboxListWithAction/checkboxListWithAction.js +224 -69
  21. package/dist/chip/chip.js +195 -91
  22. package/dist/columnsSelector/columnsSelector.js +97 -12
  23. package/dist/columnsSelector/columnsTab/columnsTab.js +59 -15
  24. package/dist/columnsSelector/columnsTabGroup/columnsTabGroup.js +81 -34
  25. package/dist/comboboxSelected/comboboxSelected.js +1 -3
  26. package/dist/dataFeed/feedExpandControl/feedExpandControl.js +25 -10
  27. package/dist/dataGrid/columns/checkboxColumn/checkboxHeaderCell.js +92 -11
  28. package/dist/dataGrid/dataGrid.js +227 -117
  29. package/dist/dataGrid/emptySearchList/emptySearchList.js +56 -9
  30. package/dist/dataGrid/entitiesListActions/actions/columnsListButton.js +51 -7
  31. package/dist/dataGrid/entitiesListActions/actions/fullscreenButton.js +64 -18
  32. package/dist/dataGrid/withFlexibleColumns/components/columnSettings.js +84 -10
  33. package/dist/dataGrid/withFlexibleColumns/components/columnSettingsSidePanel.js +48 -16
  34. package/dist/dataGrid/withSelectableRows/components/bulkActions/bulkActions.js +223 -32
  35. package/dist/dataGrid/withSelectableRows/withSelectableRows.js +286 -213
  36. package/dist/dataGrid/withSortableColumns/columns/sortableColumnWrapper.js +178 -95
  37. package/dist/dateInputInner/dateInputInner.js +791 -476
  38. package/dist/dateInputInner/dateInputInnerControlBlock.js +125 -22
  39. package/dist/dateInputRaw/dateInputRaw.js +315 -104
  40. package/dist/dateInputRaw/utils/getLabel.js +38 -7
  41. package/dist/dateRangeInner/dateRangeInner.js +172 -58
  42. package/dist/dateRangeRaw/dateRangeRaw.js +601 -239
  43. package/dist/dateRangeRaw/utils/dateRangeUtils.js +629 -241
  44. package/dist/dateSelectionWrapper/dateSelectionWrapper.js +152 -14
  45. package/dist/dialog/dialogContent.js +123 -40
  46. package/dist/dropdownRaw/dropdownHelper.d.ts +2 -2
  47. package/dist/dropdownRaw/dropdownHelper.js +9 -9
  48. package/dist/dropdownRaw/dropdownList.js +447 -78
  49. package/dist/dropdownRaw/dropdownPopup.js +218 -20
  50. package/dist/dropdownRaw/dropdownRaw.js +866 -506
  51. package/dist/dropdownRaw/dropdownSearchableTrigger.js +223 -46
  52. package/dist/dropdownRaw/stateReducer/stateAction.d.ts +5 -1
  53. package/dist/dropdownRaw/stateReducer/stateActionType.d.ts +2 -1
  54. package/dist/dropdownRaw/stateReducer/stateActionType.js +1 -0
  55. package/dist/dropdownRaw/stateReducer/stateReducer.d.ts +6 -1
  56. package/dist/dropdownRaw/stateReducer/stateReducer.js +24 -12
  57. package/dist/dropdownRaw/stateReducer/stateReducerHelper.d.ts +2 -0
  58. package/dist/dropdownRaw/stateReducer/stateReducerHelper.js +20 -1
  59. package/dist/dropdownRaw/stateReducer/stateReducerTestData.d.ts +39 -0
  60. package/dist/dropdownRaw/stateReducer/stateReducerTestData.js +74 -0
  61. package/dist/dropdownRaw/types.d.ts +1 -0
  62. package/dist/favoriteButton/favoriteButton.js +59 -10
  63. package/dist/filters/components/filtersContainer.js +151 -64
  64. package/dist/filters/components/filtersEmptySelectedList.js +30 -4
  65. package/dist/filters/components/filtersSaveModal.js +140 -42
  66. package/dist/filters/components/filtersSavedChipComponent.js +318 -108
  67. package/dist/filters/components/filtersSearchItemData.js +127 -47
  68. package/dist/filters/components/filtersSearchList.js +381 -179
  69. package/dist/filters/components/filtersSelect.js +128 -61
  70. package/dist/filters/components/filtersSelectListItem.js +125 -13
  71. package/dist/filters/components/filtersSidePanel.js +510 -178
  72. package/dist/filters/filters.js +445 -268
  73. package/dist/filtersBar/components/filtersBarPeriodPicker/getRangeOption.js +729 -272
  74. package/dist/filtersBar/components/resetComponentButton.js +45 -5
  75. package/dist/filtersBar/filtersBarActions/filtersBarActions.js +126 -15
  76. package/dist/filtersBar/filtersBarSidePanel/components/filtersBarSidePanelRange/filtersBarSidePanelRange.js +155 -49
  77. package/dist/filtersBar/filtersBarSidePanel/filtersBarSidePanel.js +360 -104
  78. package/dist/filtersBar/filtersContainer/filtersContainer.js +204 -134
  79. package/dist/formField/components/formFieldWithLabel.d.ts +2 -1
  80. package/dist/formField/components/formFieldWithLabel.js +3 -2
  81. package/dist/formField/components/formFieldWithoutLabel.d.ts +2 -1
  82. package/dist/formField/components/formFieldWithoutLabel.js +3 -3
  83. package/dist/formField/components/trailingComponent.d.ts +8 -0
  84. package/dist/formField/components/trailingComponent.js +11 -0
  85. package/dist/formField/formField.d.ts +0 -1
  86. package/dist/formField/formField.js +15 -16
  87. package/dist/formField/hooks/useError.js +100 -36
  88. package/dist/formGroup/components/reviewListToggle/reviewListToggle.js +72 -7
  89. package/dist/formGroup/hooks/useToggle.js +37 -11
  90. package/dist/formGroup/utils/getControls.js +8 -7
  91. package/dist/formLayout/hooks/useError.js +55 -15
  92. package/dist/formLayout/hooks/useFormButtons.js +128 -27
  93. package/dist/formSection/components/formSectionModal.js +1 -1
  94. package/dist/formSection/formSection.js +1 -1
  95. package/dist/formSection/hooks/useError.js +70 -22
  96. package/dist/formStepper/components/formStep.js +65 -10
  97. package/dist/formStepper/formStepper.js +129 -33
  98. package/dist/formStepperButtons/formStepperButtons.js +184 -38
  99. package/dist/groupsFilter/groupsFilterTestData.d.ts +37 -0
  100. package/dist/groupsFilter/groupsFilterTestData.js +7 -0
  101. package/dist/groupsFilter/groupsHelper.d.ts +24 -1
  102. package/dist/groupsFilter/groupsHelper.js +25 -15
  103. package/dist/groupsFilterRaw/groupsFilterAdjustmentState.js +162 -17
  104. package/dist/groupsFilterRaw/groupsFilterBox.js +137 -32
  105. package/dist/groupsFilterRaw/groupsFilterCommon.js +75 -8
  106. package/dist/groupsFilterRaw/groupsFilterCurrentlySelectedState.js +184 -25
  107. package/dist/groupsFilterRaw/groupsFilterHelper.d.ts +2 -1
  108. package/dist/groupsFilterRaw/groupsFilterHelper.js +284 -168
  109. package/dist/groupsFilterRaw/groupsFilterInitialState.js +266 -18
  110. package/dist/groupsFilterRaw/groupsFilterMenu.js +124 -9
  111. package/dist/groupsFilterRaw/groupsFilterRaw.d.ts +1 -0
  112. package/dist/groupsFilterRaw/groupsFilterRaw.js +816 -308
  113. package/dist/groupsFilterRaw/groupsFilterTestData.d.ts +155 -2
  114. package/dist/groupsFilterRaw/groupsFilterTestData.js +153 -58
  115. package/dist/groupsFilterRaw/groupsFilterTrigger.js +139 -35
  116. package/dist/groupsFilterRaw/groupsHelper.js +739 -208
  117. package/dist/groupsFilterRaw/stateReducer/stateReducerHelper.js +3 -1
  118. package/dist/groupsFilterRaw/types.d.ts +1 -0
  119. package/dist/header/components/collapsedItemsControl/collapsedItemsControl.js +107 -52
  120. package/dist/header/components/mobileFilterControl/mobileFilterControl.js +62 -9
  121. package/dist/header/components/mobileSearchControl/mobileSearchControl.js +119 -14
  122. package/dist/header/headerBack.js +64 -20
  123. package/dist/index.css +110 -71
  124. package/dist/index.d.ts +2 -1
  125. package/dist/index.js +5 -2
  126. package/dist/list/itemData/itemDataInternal.js +216 -51
  127. package/dist/list/listItem/listItem.js +168 -55
  128. package/dist/menu/components/menuErrorItem.js +33 -5
  129. package/dist/mobileSheet/mobileSheet.js +195 -69
  130. package/dist/modal/modal.js +300 -142
  131. package/dist/nav/nav.js +1 -1
  132. package/dist/nav/navFooter/navFooter.js +82 -39
  133. package/dist/nav/navFooter/navFooterAction/navFooterAction.js +52 -13
  134. package/dist/nav/navHeader/navHeader.js +86 -36
  135. package/dist/nav/navHeader/navHeaderSearch/navHeaderSearch.js +88 -29
  136. package/dist/nav/navItem/navItem.d.ts +3 -3
  137. package/dist/nav/navItem/navItem.js +35 -33
  138. package/dist/nav/navMobileBar/navMobileBar.js +67 -21
  139. package/dist/notification/notification.js +124 -21
  140. package/dist/pagination/paginationArrow.js +81 -11
  141. package/dist/pagination/paginationText/paginationText.js +45 -11
  142. package/dist/pill/components/pillNonActionable/pillNonActionable.js +93 -24
  143. package/dist/pillBox/components/pillBoxItem.js +52 -9
  144. package/dist/pillBox/pillBox.js +121 -20
  145. package/dist/pillExpandable/pillExpandable.js +333 -139
  146. package/dist/rangeRaw/rangeRaw.js +486 -141
  147. package/dist/rangeRaw/utils/rangeHelper.js +209 -39
  148. package/dist/searchInputRaw/searchInputRaw.js +180 -65
  149. package/dist/skeleton/skeleton.js +51 -6
  150. package/dist/sortControl/sortControl.js +152 -42
  151. package/dist/stepperRaw/stepperRaw.js +116 -42
  152. package/dist/summary/summary.js +94 -8
  153. package/dist/table/actions/actionsMenu.js +171 -78
  154. package/dist/table/flexible/columnSettings.js +80 -10
  155. package/dist/table/flexible/columnsList.js +110 -43
  156. package/dist/table/flexible/columnsPopup.js +77 -20
  157. package/dist/table/nested/useNestedRows.js +167 -77
  158. package/dist/table/selectable/selectableHeader.js +180 -41
  159. package/dist/table/selectable/useSelectableRows.js +270 -191
  160. package/dist/table/sortable/sortableHeader.js +153 -75
  161. package/dist/tabs/tabs.js +227 -118
  162. package/dist/timePickerRaw/timePickerRaw.js +278 -58
  163. package/dist/toastRaw/toastRaw.js +138 -32
  164. package/dist/toggleButton/toggleButton.d.ts +0 -1
  165. package/dist/toggleButtonRaw/toggleButtonRaw.d.ts +1 -0
  166. package/dist/toggleButtonRaw/toggleButtonRaw.js +146 -40
  167. package/dist/utils/formatDate.js +1001 -117
  168. package/{esm/utils/localization/translations/cs-json.js → dist/utils/localization/translations/cs.json} +11 -12
  169. package/{esm/utils/localization/translations/da-DK-json.js → dist/utils/localization/translations/da-DK.json} +31 -23
  170. package/{esm/utils/localization/translations/de-json.js → dist/utils/localization/translations/de.json} +12 -13
  171. package/dist/utils/localization/translations/en.json +308 -0
  172. package/{esm/utils/localization/translations/es-json.js → dist/utils/localization/translations/es.json} +11 -12
  173. package/{esm/utils/localization/translations/fi-FI-json.js → dist/utils/localization/translations/fi-FI.json} +31 -23
  174. package/{esm/utils/localization/translations/fr-FR-json.js → dist/utils/localization/translations/fr-FR.json} +12 -12
  175. package/{esm/utils/localization/translations/fr-json.js → dist/utils/localization/translations/fr.json} +11 -12
  176. package/{esm/utils/localization/translations/hu-HU-json.js → dist/utils/localization/translations/hu-HU.json} +31 -23
  177. package/{esm/utils/localization/translations/id-json.js → dist/utils/localization/translations/id.json} +11 -13
  178. package/{esm/utils/localization/translations/it-json.js → dist/utils/localization/translations/it.json} +11 -12
  179. package/{esm/utils/localization/translations/ja-json.js → dist/utils/localization/translations/ja.json} +11 -12
  180. package/{esm/utils/localization/translations/ko-KR-json.js → dist/utils/localization/translations/ko-KR.json} +24 -23
  181. package/{esm/utils/localization/translations/ms-json.js → dist/utils/localization/translations/ms.json} +11 -12
  182. package/{esm/utils/localization/translations/nb-NO-json.js → dist/utils/localization/translations/nb-NO.json} +31 -23
  183. package/{esm/utils/localization/translations/nl-json.js → dist/utils/localization/translations/nl.json} +11 -12
  184. package/{esm/utils/localization/translations/pl-json.js → dist/utils/localization/translations/pl.json} +11 -12
  185. package/{esm/utils/localization/translations/pt-BR-json.js → dist/utils/localization/translations/pt-BR.json} +11 -12
  186. package/{esm/utils/localization/translations/sk-SK-json.js → dist/utils/localization/translations/sk-SK.json} +31 -23
  187. package/{esm/utils/localization/translations/sv-json.js → dist/utils/localization/translations/sv.json} +11 -12
  188. package/{esm/utils/localization/translations/th-json.js → dist/utils/localization/translations/th.json} +11 -12
  189. package/{esm/utils/localization/translations/tr-json.js → dist/utils/localization/translations/tr.json} +11 -12
  190. package/{esm/utils/localization/translations/zh-Hans-json.js → dist/utils/localization/translations/zh-Hans.json} +11 -12
  191. package/{esm/utils/localization/translations/zh-TW-json.js → dist/utils/localization/translations/zh-TW.json} +11 -23
  192. package/dist/utils/localization/translationsDictionary.d.ts +2 -0
  193. package/dist/utils/localization/translationsDictionary.js +63 -0
  194. package/dist/utils/localization/useLanguage.js +2 -74
  195. package/esm/advancedGroupsFilter/advancedGroupsFilter.js +130 -29
  196. package/esm/advancedGroupsFilter/advancedGroupsFilterForm.js +133 -33
  197. package/esm/advancedGroupsFilter/advancedGroupsFilterFormSection.js +317 -65
  198. package/esm/advancedGroupsFilter/advancedGroupsFilterSectionTooltip.d.ts +0 -1
  199. package/esm/advancedGroupsFilter/advancedGroupsFilterSectionTooltip.js +77 -8
  200. package/esm/alertRaw/alertRaw.js +165 -51
  201. package/esm/banner/bannerMultipLine.js +121 -20
  202. package/esm/banner/bannerSingleLine.js +100 -13
  203. package/esm/betaPill/betaPill.js +105 -19
  204. package/esm/bookmark/bookmark.js +89 -27
  205. package/esm/bulkEditControl/bulkEditControl.js +161 -33
  206. package/esm/calendar/calendar.js +937 -272
  207. package/esm/calendar/calendarUtils.js +151 -84
  208. package/esm/card/card.js +233 -101
  209. package/esm/chart/accessibleChart/accessibleChartNarrative.js +642 -554
  210. package/esm/chart/accessibleChart/accessibleChartTable.js +239 -85
  211. package/esm/chart/chart.js +30 -20
  212. package/esm/chart/chartAxis/chartAxis.js +79 -6
  213. package/esm/checkboxListWithAction/checkboxListWithAction.js +218 -68
  214. package/esm/chip/chip.js +189 -90
  215. package/esm/columnsSelector/columnsSelector.js +91 -11
  216. package/esm/columnsSelector/columnsTab/columnsTab.js +53 -14
  217. package/esm/columnsSelector/columnsTabGroup/columnsTabGroup.js +75 -33
  218. package/esm/comboboxSelected/comboboxSelected.js +1 -3
  219. package/esm/dataFeed/feedExpandControl/feedExpandControl.js +21 -9
  220. package/esm/dataGrid/columns/checkboxColumn/checkboxHeaderCell.js +86 -10
  221. package/esm/dataGrid/dataGrid.js +221 -116
  222. package/esm/dataGrid/emptySearchList/emptySearchList.js +50 -8
  223. package/esm/dataGrid/entitiesListActions/actions/columnsListButton.js +45 -6
  224. package/esm/dataGrid/entitiesListActions/actions/fullscreenButton.js +58 -17
  225. package/esm/dataGrid/withFlexibleColumns/components/columnSettings.js +78 -9
  226. package/esm/dataGrid/withFlexibleColumns/components/columnSettingsSidePanel.js +44 -15
  227. package/esm/dataGrid/withSelectableRows/components/bulkActions/bulkActions.js +217 -31
  228. package/esm/dataGrid/withSelectableRows/withSelectableRows.js +280 -212
  229. package/esm/dataGrid/withSortableColumns/columns/sortableColumnWrapper.js +172 -94
  230. package/esm/dateInputInner/dateInputInner.js +785 -475
  231. package/esm/dateInputInner/dateInputInnerControlBlock.js +119 -21
  232. package/esm/dateInputRaw/dateInputRaw.js +309 -103
  233. package/esm/dateInputRaw/utils/getLabel.js +32 -6
  234. package/esm/dateRangeInner/dateRangeInner.js +166 -57
  235. package/esm/dateRangeRaw/dateRangeRaw.js +595 -238
  236. package/esm/dateRangeRaw/utils/dateRangeUtils.js +622 -239
  237. package/esm/dateSelectionWrapper/dateSelectionWrapper.js +146 -13
  238. package/esm/dialog/dialogContent.js +117 -39
  239. package/esm/dropdownRaw/dropdownHelper.d.ts +2 -2
  240. package/esm/dropdownRaw/dropdownHelper.js +10 -10
  241. package/esm/dropdownRaw/dropdownList.js +412 -56
  242. package/esm/dropdownRaw/dropdownPopup.js +212 -19
  243. package/esm/dropdownRaw/dropdownRaw.js +862 -507
  244. package/esm/dropdownRaw/dropdownSearchableTrigger.js +217 -45
  245. package/esm/dropdownRaw/stateReducer/stateAction.d.ts +5 -1
  246. package/esm/dropdownRaw/stateReducer/stateActionType.d.ts +2 -1
  247. package/esm/dropdownRaw/stateReducer/stateActionType.js +1 -0
  248. package/esm/dropdownRaw/stateReducer/stateReducer.d.ts +6 -1
  249. package/esm/dropdownRaw/stateReducer/stateReducer.js +24 -12
  250. package/esm/dropdownRaw/stateReducer/stateReducerHelper.d.ts +2 -0
  251. package/esm/dropdownRaw/stateReducer/stateReducerHelper.js +18 -0
  252. package/esm/dropdownRaw/stateReducer/stateReducerTestData.d.ts +39 -0
  253. package/esm/dropdownRaw/stateReducer/stateReducerTestData.js +71 -0
  254. package/esm/dropdownRaw/types.d.ts +1 -0
  255. package/esm/favoriteButton/favoriteButton.js +53 -9
  256. package/esm/filters/components/filtersContainer.js +141 -61
  257. package/esm/filters/components/filtersEmptySelectedList.js +24 -3
  258. package/esm/filters/components/filtersSaveModal.js +134 -41
  259. package/esm/filters/components/filtersSavedChipComponent.js +312 -107
  260. package/esm/filters/components/filtersSearchItemData.js +121 -46
  261. package/esm/filters/components/filtersSearchList.js +375 -178
  262. package/esm/filters/components/filtersSelect.js +122 -60
  263. package/esm/filters/components/filtersSelectListItem.js +119 -12
  264. package/esm/filters/components/filtersSidePanel.js +504 -177
  265. package/esm/filters/filters.js +435 -265
  266. package/esm/filtersBar/components/filtersBarPeriodPicker/getRangeOption.js +722 -270
  267. package/esm/filtersBar/components/resetComponentButton.js +39 -4
  268. package/esm/filtersBar/filtersBarActions/filtersBarActions.js +120 -14
  269. package/esm/filtersBar/filtersBarSidePanel/components/filtersBarSidePanelRange/filtersBarSidePanelRange.js +149 -48
  270. package/esm/filtersBar/filtersBarSidePanel/filtersBarSidePanel.js +354 -103
  271. package/esm/filtersBar/filtersContainer/filtersContainer.js +198 -133
  272. package/esm/formField/components/formFieldWithLabel.d.ts +2 -1
  273. package/esm/formField/components/formFieldWithLabel.js +3 -2
  274. package/esm/formField/components/formFieldWithoutLabel.d.ts +2 -1
  275. package/esm/formField/components/formFieldWithoutLabel.js +3 -3
  276. package/esm/formField/components/trailingComponent.d.ts +8 -0
  277. package/esm/formField/components/trailingComponent.js +7 -0
  278. package/esm/formField/formField.d.ts +0 -1
  279. package/esm/formField/formField.js +15 -16
  280. package/esm/formField/hooks/useError.js +94 -35
  281. package/esm/formGroup/components/reviewListToggle/reviewListToggle.js +66 -6
  282. package/esm/formGroup/hooks/useToggle.js +31 -10
  283. package/esm/formGroup/utils/getControls.js +8 -7
  284. package/esm/formLayout/hooks/useError.js +49 -14
  285. package/esm/formLayout/hooks/useFormButtons.js +122 -26
  286. package/esm/formSection/components/formSectionModal.js +1 -1
  287. package/esm/formSection/formSection.js +1 -1
  288. package/esm/formSection/hooks/useError.js +64 -21
  289. package/esm/formStepper/components/formStep.js +59 -9
  290. package/esm/formStepper/formStepper.js +123 -32
  291. package/esm/formStepperButtons/formStepperButtons.js +178 -37
  292. package/esm/groupsFilter/groupsFilterTestData.d.ts +37 -0
  293. package/esm/groupsFilter/groupsFilterTestData.js +4 -0
  294. package/esm/groupsFilter/groupsHelper.d.ts +24 -1
  295. package/esm/groupsFilter/groupsHelper.js +24 -1
  296. package/esm/groupsFilterRaw/groupsFilterAdjustmentState.js +152 -14
  297. package/esm/groupsFilterRaw/groupsFilterBox.js +131 -31
  298. package/esm/groupsFilterRaw/groupsFilterCommon.js +69 -7
  299. package/esm/groupsFilterRaw/groupsFilterCurrentlySelectedState.js +178 -24
  300. package/esm/groupsFilterRaw/groupsFilterHelper.d.ts +2 -1
  301. package/esm/groupsFilterRaw/groupsFilterHelper.js +279 -168
  302. package/esm/groupsFilterRaw/groupsFilterInitialState.js +260 -17
  303. package/esm/groupsFilterRaw/groupsFilterMenu.js +118 -8
  304. package/esm/groupsFilterRaw/groupsFilterRaw.d.ts +1 -0
  305. package/esm/groupsFilterRaw/groupsFilterRaw.js +811 -308
  306. package/esm/groupsFilterRaw/groupsFilterTestData.d.ts +155 -2
  307. package/esm/groupsFilterRaw/groupsFilterTestData.js +152 -57
  308. package/esm/groupsFilterRaw/groupsFilterTrigger.js +133 -34
  309. package/esm/groupsFilterRaw/groupsHelper.js +733 -207
  310. package/esm/groupsFilterRaw/stateReducer/stateReducerHelper.js +3 -1
  311. package/esm/groupsFilterRaw/types.d.ts +1 -0
  312. package/esm/header/components/collapsedItemsControl/collapsedItemsControl.js +101 -51
  313. package/esm/header/components/mobileFilterControl/mobileFilterControl.js +56 -8
  314. package/esm/header/components/mobileSearchControl/mobileSearchControl.js +113 -13
  315. package/esm/header/headerBack.js +58 -19
  316. package/esm/index.d.ts +2 -1
  317. package/esm/index.js +2 -1
  318. package/esm/list/itemData/itemDataInternal.js +210 -50
  319. package/esm/list/listItem/listItem.js +162 -54
  320. package/esm/menu/components/menuErrorItem.js +27 -4
  321. package/esm/mobileSheet/mobileSheet.js +189 -68
  322. package/esm/modal/modal.js +265 -120
  323. package/esm/nav/nav.js +1 -1
  324. package/esm/nav/navFooter/navFooter.js +76 -38
  325. package/esm/nav/navFooter/navFooterAction/navFooterAction.js +46 -12
  326. package/esm/nav/navHeader/navHeader.js +80 -35
  327. package/esm/nav/navHeader/navHeaderSearch/navHeaderSearch.js +82 -28
  328. package/esm/nav/navItem/navItem.d.ts +3 -3
  329. package/esm/nav/navItem/navItem.js +35 -33
  330. package/esm/nav/navMobileBar/navMobileBar.js +61 -20
  331. package/esm/notification/notification.js +114 -18
  332. package/esm/pagination/paginationArrow.js +75 -10
  333. package/esm/pagination/paginationText/paginationText.js +39 -10
  334. package/esm/pill/components/pillNonActionable/pillNonActionable.js +87 -23
  335. package/esm/pillBox/components/pillBoxItem.js +46 -8
  336. package/esm/pillBox/pillBox.js +115 -19
  337. package/esm/pillExpandable/pillExpandable.js +327 -138
  338. package/esm/rangeRaw/rangeRaw.js +480 -140
  339. package/esm/rangeRaw/utils/rangeHelper.js +203 -38
  340. package/esm/searchInputRaw/searchInputRaw.js +145 -43
  341. package/esm/skeleton/skeleton.js +45 -5
  342. package/esm/sortControl/sortControl.js +146 -41
  343. package/esm/stepperRaw/stepperRaw.js +112 -41
  344. package/esm/storybookHelpers/dataGridWithDifferentCellOptions/components/EntitiesListAction.js +178 -19
  345. package/esm/summary/summary.js +88 -7
  346. package/esm/table/actions/actionsMenu.js +165 -77
  347. package/esm/table/flexible/columnSettings.js +74 -9
  348. package/esm/table/flexible/columnsList.js +104 -42
  349. package/esm/table/flexible/columnsPopup.js +71 -19
  350. package/esm/table/nested/useNestedRows.js +161 -76
  351. package/esm/table/selectable/selectableHeader.js +174 -40
  352. package/esm/table/selectable/useSelectableRows.js +264 -190
  353. package/esm/table/sortable/sortableHeader.js +147 -74
  354. package/esm/tabs/tabs.js +221 -117
  355. package/esm/timePickerRaw/timePickerRaw.js +272 -57
  356. package/esm/toastRaw/toastRaw.js +132 -31
  357. package/esm/toggleButton/toggleButton.d.ts +0 -1
  358. package/esm/toggleButtonRaw/toggleButtonRaw.d.ts +1 -0
  359. package/esm/toggleButtonRaw/toggleButtonRaw.js +111 -18
  360. package/esm/utils/formatDate.js +995 -116
  361. package/{dist/utils/localization/translations/cs-json.js → esm/utils/localization/translations/cs.json} +11 -15
  362. package/{dist/utils/localization/translations/da-DK-json.js → esm/utils/localization/translations/da-DK.json} +31 -26
  363. package/{dist/utils/localization/translations/de-json.js → esm/utils/localization/translations/de.json} +12 -16
  364. package/esm/utils/localization/translations/en.json +308 -0
  365. package/{dist/utils/localization/translations/es-json.js → esm/utils/localization/translations/es.json} +11 -15
  366. package/{dist/utils/localization/translations/fi-FI-json.js → esm/utils/localization/translations/fi-FI.json} +31 -26
  367. package/{dist/utils/localization/translations/fr-FR-json.js → esm/utils/localization/translations/fr-FR.json} +12 -15
  368. package/{dist/utils/localization/translations/fr-json.js → esm/utils/localization/translations/fr.json} +11 -15
  369. package/{dist/utils/localization/translations/hu-HU-json.js → esm/utils/localization/translations/hu-HU.json} +31 -26
  370. package/{dist/utils/localization/translations/id-json.js → esm/utils/localization/translations/id.json} +11 -16
  371. package/{dist/utils/localization/translations/it-json.js → esm/utils/localization/translations/it.json} +11 -15
  372. package/{dist/utils/localization/translations/ja-json.js → esm/utils/localization/translations/ja.json} +11 -15
  373. package/{dist/utils/localization/translations/ko-KR-json.js → esm/utils/localization/translations/ko-KR.json} +24 -26
  374. package/{dist/utils/localization/translations/ms-json.js → esm/utils/localization/translations/ms.json} +11 -15
  375. package/{dist/utils/localization/translations/nb-NO-json.js → esm/utils/localization/translations/nb-NO.json} +31 -26
  376. package/{dist/utils/localization/translations/nl-json.js → esm/utils/localization/translations/nl.json} +11 -15
  377. package/{dist/utils/localization/translations/pl-json.js → esm/utils/localization/translations/pl.json} +11 -15
  378. package/{dist/utils/localization/translations/pt-BR-json.js → esm/utils/localization/translations/pt-BR.json} +11 -15
  379. package/{dist/utils/localization/translations/sk-SK-json.js → esm/utils/localization/translations/sk-SK.json} +31 -26
  380. package/{dist/utils/localization/translations/sv-json.js → esm/utils/localization/translations/sv.json} +11 -15
  381. package/{dist/utils/localization/translations/th-json.js → esm/utils/localization/translations/th.json} +11 -15
  382. package/{dist/utils/localization/translations/tr-json.js → esm/utils/localization/translations/tr.json} +11 -15
  383. package/{dist/utils/localization/translations/zh-Hans-json.js → esm/utils/localization/translations/zh-Hans.json} +11 -15
  384. package/{dist/utils/localization/translations/zh-TW-json.js → esm/utils/localization/translations/zh-TW.json} +11 -26
  385. package/esm/utils/localization/translationsDictionary.d.ts +2 -0
  386. package/esm/utils/localization/translationsDictionary.js +59 -0
  387. package/esm/utils/localization/useLanguage.js +1 -50
  388. package/package.json +17 -10
  389. package/dist/formField/hooks/useClasses.d.ts +0 -8
  390. package/dist/formField/hooks/useClasses.js +0 -25
  391. package/dist/utils/localization/translations/cs-json.d.ts +0 -251
  392. package/dist/utils/localization/translations/da-DK-json.d.ts +0 -252
  393. package/dist/utils/localization/translations/de-json.d.ts +0 -251
  394. package/dist/utils/localization/translations/en-json.d.ts +0 -314
  395. package/dist/utils/localization/translations/en-json.js +0 -317
  396. package/dist/utils/localization/translations/es-json.d.ts +0 -251
  397. package/dist/utils/localization/translations/fi-FI-json.d.ts +0 -252
  398. package/dist/utils/localization/translations/fr-FR-json.d.ts +0 -250
  399. package/dist/utils/localization/translations/fr-json.d.ts +0 -251
  400. package/dist/utils/localization/translations/hu-HU-json.d.ts +0 -252
  401. package/dist/utils/localization/translations/id-json.d.ts +0 -252
  402. package/dist/utils/localization/translations/it-json.d.ts +0 -251
  403. package/dist/utils/localization/translations/ja-json.d.ts +0 -251
  404. package/dist/utils/localization/translations/ko-KR-json.d.ts +0 -258
  405. package/dist/utils/localization/translations/ms-json.d.ts +0 -251
  406. package/dist/utils/localization/translations/nb-NO-json.d.ts +0 -252
  407. package/dist/utils/localization/translations/nl-json.d.ts +0 -251
  408. package/dist/utils/localization/translations/pl-json.d.ts +0 -251
  409. package/dist/utils/localization/translations/pt-BR-json.d.ts +0 -251
  410. package/dist/utils/localization/translations/sk-SK-json.d.ts +0 -251
  411. package/dist/utils/localization/translations/sv-json.d.ts +0 -251
  412. package/dist/utils/localization/translations/th-json.d.ts +0 -251
  413. package/dist/utils/localization/translations/tr-json.d.ts +0 -251
  414. package/dist/utils/localization/translations/zh-Hans-json.d.ts +0 -251
  415. package/dist/utils/localization/translations/zh-TW-json.d.ts +0 -271
  416. package/esm/formField/hooks/useClasses.d.ts +0 -8
  417. package/esm/formField/hooks/useClasses.js +0 -21
  418. package/esm/utils/localization/translations/cs-json.d.ts +0 -251
  419. package/esm/utils/localization/translations/da-DK-json.d.ts +0 -252
  420. package/esm/utils/localization/translations/de-json.d.ts +0 -251
  421. package/esm/utils/localization/translations/en-json.d.ts +0 -314
  422. package/esm/utils/localization/translations/en-json.js +0 -314
  423. package/esm/utils/localization/translations/es-json.d.ts +0 -251
  424. package/esm/utils/localization/translations/fi-FI-json.d.ts +0 -252
  425. package/esm/utils/localization/translations/fr-FR-json.d.ts +0 -250
  426. package/esm/utils/localization/translations/fr-json.d.ts +0 -251
  427. package/esm/utils/localization/translations/hu-HU-json.d.ts +0 -252
  428. package/esm/utils/localization/translations/id-json.d.ts +0 -252
  429. package/esm/utils/localization/translations/it-json.d.ts +0 -251
  430. package/esm/utils/localization/translations/ja-json.d.ts +0 -251
  431. package/esm/utils/localization/translations/ko-KR-json.d.ts +0 -258
  432. package/esm/utils/localization/translations/ms-json.d.ts +0 -251
  433. package/esm/utils/localization/translations/nb-NO-json.d.ts +0 -252
  434. package/esm/utils/localization/translations/nl-json.d.ts +0 -251
  435. package/esm/utils/localization/translations/pl-json.d.ts +0 -251
  436. package/esm/utils/localization/translations/pt-BR-json.d.ts +0 -251
  437. package/esm/utils/localization/translations/sk-SK-json.d.ts +0 -251
  438. package/esm/utils/localization/translations/sv-json.d.ts +0 -251
  439. package/esm/utils/localization/translations/th-json.d.ts +0 -251
  440. package/esm/utils/localization/translations/tr-json.d.ts +0 -251
  441. package/esm/utils/localization/translations/zh-Hans-json.d.ts +0 -251
  442. package/esm/utils/localization/translations/zh-TW-json.d.ts +0 -271
@@ -1,3 +1,4 @@
1
+ import { injectString } from "../../utils/localization/translationsDictionary";
1
2
  import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
3
  import { useCallback, useEffect, useMemo, useRef, useState } from "react";
3
4
  import { List } from "../../list/list";
@@ -14,186 +15,382 @@ import { MAX_TOTAL_RESULTS } from "../filtersHelper";
14
15
  import { EmptySearchList } from "../../dataGrid/emptySearchList/emptySearchList";
15
16
  import { getNewFocusableItem } from "../../utils/keyboardHelpers";
16
17
  import { FOCUSABLE_SELECTOR } from "../../utils/focusableSelector";
18
+ injectString("cs", "Back", "Zp\u011Bt");
19
+ injectString("da-DK", "Back", "Tilbage");
20
+ injectString("de", "Back", "Zur\xFCck");
21
+ injectString("en", "Back", "Back");
22
+ injectString("es", "Back", "Regresar");
23
+ injectString("fi-FI", "Back", "Takaisin");
24
+ injectString("fr", "Back", "Retour");
25
+ injectString("fr-FR", "Back", "Retour");
26
+ injectString("hu-HU", "Back", "Vissza");
27
+ injectString("id", "Back", "Kembali");
28
+ injectString("it", "Back", "Indietro");
29
+ injectString("ja", "Back", "\u623B\u308B");
30
+ injectString("ko-KR", "Back", "\uB4A4\uB85C");
31
+ injectString("ms", "Back", "Kembali");
32
+ injectString("nb-NO", "Back", "Tilbake");
33
+ injectString("nl", "Back", "Terug");
34
+ injectString("pl", "Back", "Wstecz");
35
+ injectString("pt-BR", "Back", "Voltar");
36
+ injectString("sk-SK", "Back", "Sp\xE4\u0165");
37
+ injectString("sv", "Back", "Tillbaka");
38
+ injectString("th", "Back", "\u0E01\u0E25\u0E31\u0E1A");
39
+ injectString("tr", "Back", "Geri");
40
+ injectString("zh-Hans", "Back", "\u8FD4\u56DE");
41
+ injectString("zh-TW", "Back", "\u8FD4\u56DE");
42
+ injectString("cs", "Clear all", "Vymazat v\u0161e");
43
+ injectString("da-DK", "Clear all", "Ryd alt");
44
+ injectString("de", "Clear all", "Alle l\xF6schen");
45
+ injectString("en", "Clear all", "Clear all");
46
+ injectString("es", "Clear all", "Borrar todo");
47
+ injectString("fi-FI", "Clear all", "Tyhjenn\xE4 kaikki");
48
+ injectString("fr", "Clear all", "Effacer tout");
49
+ injectString("fr-FR", "Clear all", "Tout effacer");
50
+ injectString("hu-HU", "Clear all", "Mindent t\xF6r\xF6lni");
51
+ injectString("id", "Clear all", "Hapus semua");
52
+ injectString("it", "Clear all", "Cancellare tutto");
53
+ injectString("ja", "Clear all", "\u3059\u3079\u3066\u3092\u30AF\u30EA\u30A2");
54
+ injectString("ko-KR", "Clear all", "\uBAA8\uB450 \uC9C0\uC6B0\uAE30");
55
+ injectString("ms", "Clear all", "Kosongkan semua");
56
+ injectString("nb-NO", "Clear all", "Fjern alt");
57
+ injectString("nl", "Clear all", "Alles wissen");
58
+ injectString("pl", "Clear all", "Wyczy\u015B\u0107 wszystkie");
59
+ injectString("pt-BR", "Clear all", "Limpar tudo");
60
+ injectString("sk-SK", "Clear all", "Vymaza\u0165 v\u0161etko");
61
+ injectString("sv", "Clear all", "Rensa alla");
62
+ injectString("th", "Clear all", "\u0E25\u0E49\u0E32\u0E07\u0E17\u0E31\u0E49\u0E07\u0E2B\u0E21\u0E14");
63
+ injectString("tr", "Clear all", "T\xFCm\xFCn\xFC temizle");
64
+ injectString("zh-Hans", "Clear all", "\u5168\u90E8\u6E05\u9664");
65
+ injectString("zh-TW", "Clear all", "\u6E05\u9664\u5168\u90E8");
66
+ injectString("en", "Recent searches", "Recent searches");
67
+ injectString("en", "Currently selected", "Currently selected");
68
+ injectString("en", "View history", "View history");
69
+ injectString("cs", "Clear", "Vymazat");
70
+ injectString("da-DK", "Clear", "Ryd");
71
+ injectString("de", "Clear", "L\xF6schen");
72
+ injectString("en", "Clear", "Clear");
73
+ injectString("es", "Clear", "Borrar");
74
+ injectString("fi-FI", "Clear", "Tyhjenn\xE4");
75
+ injectString("fr", "Clear", "Effacer");
76
+ injectString("fr-FR", "Clear", "Effacer");
77
+ injectString("hu-HU", "Clear", "T\xF6r\xF6ld.");
78
+ injectString("id", "Clear", "Hapus");
79
+ injectString("it", "Clear", "Cancella");
80
+ injectString("ja", "Clear", "\u30AF\u30EA\u30A2");
81
+ injectString("ko-KR", "Clear", "\uC9C0\uC6B0\uAE30");
82
+ injectString("ms", "Clear", "Kosongkan");
83
+ injectString("nb-NO", "Clear", "T\xF8m");
84
+ injectString("nl", "Clear", "Wissen");
85
+ injectString("pl", "Clear", "Wyczy\u015B\u0107");
86
+ injectString("pt-BR", "Clear", "Limpar");
87
+ injectString("sk-SK", "Clear", "Vyma\u017E");
88
+ injectString("sv", "Clear", "Rensa");
89
+ injectString("th", "Clear", "\u0E25\u0E49\u0E32\u0E07");
90
+ injectString("tr", "Clear", "Temizle");
91
+ injectString("zh-Hans", "Clear", "\u6E05\u9664");
92
+ injectString("zh-TW", "Clear", "\u6E05\u9664");
93
+ injectString("en", "Top results", "Top results");
94
+ injectString("cs", "No data available", "Nejsou k\xA0dispozici \u017E\xE1dn\xE1 data");
95
+ injectString("da-DK", "No data available", "Ingen data tilg\xE6ngelige");
96
+ injectString("de", "No data available", "Keine Daten verf\xFCgbar");
97
+ injectString("en", "No data available", "No data available");
98
+ injectString("es", "No data available", "No hay datos disponibles");
99
+ injectString("fi-FI", "No data available", "Tietoja ei saatavilla");
100
+ injectString("fr", "No data available", "Aucune donn\xE9e disponible");
101
+ injectString("fr-FR", "No data available", "Aucune donn\xE9e disponible");
102
+ injectString("hu-HU", "No data available", "Nincsenek rendelkez\xE9sre \xE1ll\xF3 adatok");
103
+ injectString("id", "No data available", "Tidak ada data tersedia");
104
+ injectString("it", "No data available", "Nessun dato disponibile");
105
+ injectString("ja", "No data available", "\u30C7\u30FC\u30BF\u304C\u3042\u308A\u307E\u305B\u3093");
106
+ injectString("ko-KR", "No data available", "\uC0AC\uC6A9 \uAC00\uB2A5\uD55C \uB370\uC774\uD130\uAC00 \uC5C6\uC2B5\uB2C8\uB2E4");
107
+ injectString("ms", "No data available", "Tiada data tersedia");
108
+ injectString("nb-NO", "No data available", "Ingen data tilgjengelig");
109
+ injectString("nl", "No data available", "Geen gegevens beschikbaar");
110
+ injectString("pl", "No data available", "Brak dost\u0119pnych danych");
111
+ injectString("pt-BR", "No data available", "Nenhum dado dispon\xEDvel");
112
+ injectString("sk-SK", "No data available", "Nie s\xFA k dispoz\xEDcii \u017Eiadne \xFAdaje");
113
+ injectString("sv", "No data available", "Det finns inga tillg\xE4ngliga data");
114
+ injectString("th", "No data available", "\u0E44\u0E21\u0E48\u0E21\u0E35\u0E02\u0E49\u0E2D\u0E21\u0E39\u0E25");
115
+ injectString("tr", "No data available", "Mevcut veri yok");
116
+ injectString("zh-Hans", "No data available", "\u65E0\u53EF\u7528\u6570\u636E");
117
+ injectString("zh-TW", "No data available", "\u6C92\u6709\u53EF\u7528\u8CC7\u6599");
17
118
  export const NO_TYPED_SEARCH_ITEM = "noTypedSearchItem";
18
119
  export const KEYWORD_ID = "keywordId";
19
120
  export const KEYWORD_TYPE = "keyword";
20
121
  export const NOT_POPULATED_NAME = "...";
21
- export const FiltersSearchList = ({ searchValue, searchData, recentSearches, searchSelection, onlyOneType, handleSearchItemClick, onRemoveRecentSearchItem, handleRecentSearchItemClick, getIconByType, handleClearSearchSelection, searchListRef }) => {
22
- const { translate } = useLanguage();
23
- const isSearchModeAvailable = Boolean(handleSearchItemClick && searchSelection);
24
- const isRecentSearchesModeAvailable = Boolean(recentSearches && handleRecentSearchItemClick && onRemoveRecentSearchItem);
25
- const isMobile = useMobile();
26
- const isDrive = useDrive();
27
- const [removedItems, setRemovedItems] = useState([]);
28
- const initialSearchSelectionRef = useRef(searchSelection || []);
29
- const hasNotPopulatedName = initialSearchSelectionRef.current.length === 0 ? false : initialSearchSelectionRef.current.some(el => el.name === NOT_POPULATED_NAME);
30
- const getCurrentMode = useCallback(() => {
31
- if (searchValue) {
32
- return "search";
33
- }
34
- if (isSearchModeAvailable && initialSearchSelectionRef.current.length > 0) {
35
- return "selected";
36
- }
37
- if (isRecentSearchesModeAvailable && (recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.data) && recentSearches.data.length > 0) {
38
- return "recent";
39
- }
40
- return "";
41
- }, [searchValue, isSearchModeAvailable, isRecentSearchesModeAvailable, recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.data]);
42
- const [currentMode, setCurrentMode] = useState(getCurrentMode());
43
- const waitingItemsLimit = 5;
44
- // Handle React Query errors
45
- useEffect(() => {
46
- if (currentMode === "search" && (searchData === null || searchData === void 0 ? void 0 : searchData.error)) {
47
- console.error("Failed to fetch search results. Error:", searchData.error);
48
- }
49
- }, [currentMode, searchData === null || searchData === void 0 ? void 0 : searchData.error]);
50
- useEffect(() => {
51
- if (currentMode !== "search" && searchValue) {
52
- setCurrentMode("search");
53
- }
54
- }, [searchValue, currentMode]);
55
- useEffect(() => {
56
- if (currentMode === "recent" && searchSelection && searchSelection.length === 0) {
57
- initialSearchSelectionRef.current = [];
58
- }
59
- }, [isSearchModeAvailable, isRecentSearchesModeAvailable, currentMode, searchSelection]);
60
- // Reset history mode when search value changes
61
- useEffect(() => {
62
- if (currentMode === "history" && searchValue) {
63
- setCurrentMode(isSearchModeAvailable ? "search" : "");
64
- }
65
- else if (currentMode === "search" && !searchValue) {
66
- setCurrentMode(getCurrentMode());
67
- }
68
- }, [currentMode, getCurrentMode, isRecentSearchesModeAvailable, isSearchModeAvailable, searchValue]);
69
- useEffect(() => {
70
- if (searchSelection && searchSelection.length === 0) {
71
- return;
72
- }
73
- searchSelection === null || searchSelection === void 0 ? void 0 : searchSelection.forEach(item => {
74
- const existingItem = initialSearchSelectionRef.current.find(el => (onlyOneType ? el.id === item.id : el.id === item.id && el.type === item.type));
75
- if (!existingItem) {
76
- initialSearchSelectionRef.current = [...initialSearchSelectionRef.current, item];
77
- }
78
- else if (hasNotPopulatedName) {
79
- existingItem.name = item.name;
80
- existingItem.description = item.description;
81
- existingItem.type = item.type;
82
- }
83
- });
84
- }, [hasNotPopulatedName, onlyOneType, searchSelection]);
85
- const searchItems = useMemo(() => currentMode === "search" || currentMode === "" ? (searchData === null || searchData === void 0 ? void 0 : searchData.data) || [] : [], [currentMode, searchData === null || searchData === void 0 ? void 0 : searchData.data]);
86
- const recentItems = useMemo(() => currentMode === "recent" || currentMode === "history" ? (recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.data) || [] : [], [currentMode, recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.data]);
87
- const isLoading = currentMode === "search" && (searchData === null || searchData === void 0 ? void 0 : searchData.isLoading) || (currentMode === "recent" || currentMode === "history" ? recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.isLoading : false) || false;
88
- const changeMode = useCallback((newVal) => {
89
- setCurrentMode(newVal);
90
- setRemovedItems([]);
91
- // Note: In React Query implementation, the parent component should handle
92
- // refetching data when switching between modes
93
- }, []);
94
- const handleRemove = useCallback((itemId) => () => {
95
- var _a;
96
- setRemovedItems(prev => [...prev, itemId]);
97
- onRemoveRecentSearchItem && onRemoveRecentSearchItem([itemId]);
98
- // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
99
- const firstItem = (_a = searchListRef.current) === null || _a === void 0 ? void 0 : _a.querySelector(FOCUSABLE_SELECTOR);
100
- firstItem === null || firstItem === void 0 ? void 0 : firstItem.focus();
101
- }, [onRemoveRecentSearchItem, searchListRef]);
102
- const handleRemoveAll = useCallback(() => {
103
- setRemovedItems(recentItems.map(item => item.id));
104
- onRemoveRecentSearchItem && onRemoveRecentSearchItem(recentItems.map(item => item.id));
105
- changeMode(getCurrentMode());
106
- }, [recentItems, onRemoveRecentSearchItem, changeMode, getCurrentMode]);
107
- const memoizedSearchItemClick = useCallback((itemId, itemType) => () => {
108
- const currentSearchItem = onlyOneType && !itemType ? searchItems.find(item => item.id === itemId)
109
- : searchItems.find(item => item.id === itemId && item.type === itemType);
110
- currentSearchItem && handleSearchItemClick && handleSearchItemClick(currentSearchItem);
111
- }, [handleSearchItemClick, onlyOneType, searchItems]);
112
- const memoizedSelectedItemClick = useCallback((itemId, itemType) => () => {
113
- const currentSelectedItem = onlyOneType && !itemType ? initialSearchSelectionRef.current.find(item => item.id === itemId)
114
- : initialSearchSelectionRef.current.find(item => item.id === itemId && item.type === itemType);
115
- currentSelectedItem && handleSearchItemClick && handleSearchItemClick(currentSelectedItem);
116
- }, [handleSearchItemClick, onlyOneType]);
117
- const memoizedRecentSearchItemClick = useCallback((itemId, itemType) => () => {
118
- const currentSearchItem = recentItems.find(item => item.id === itemId && item.type === itemType);
119
- currentSearchItem && handleRecentSearchItemClick && handleRecentSearchItemClick(currentSearchItem);
120
- }, [handleRecentSearchItemClick, recentItems]);
121
- const memoizedClearSelectedItems = useCallback(() => {
122
- var _a;
123
- handleClearSearchSelection === null || handleClearSearchSelection === void 0 ? void 0 : handleClearSearchSelection();
124
- initialSearchSelectionRef.current = [];
125
- setCurrentMode(isRecentSearchesModeAvailable && ((_a = recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.data) === null || _a === void 0 ? void 0 : _a.length) ? "recent" : "");
126
- }, [handleClearSearchSelection, isRecentSearchesModeAvailable, recentSearches]);
127
- const handleKeyDown = useCallback((event) => {
128
- const isListItem = event.target instanceof HTMLElement && event.target.dataset.listItem === "true";
129
- const isButtonItem = event.target instanceof HTMLElement && event.target.dataset.closeButton === "true";
130
- const getSelector = () => {
131
- if (isListItem) {
132
- return `[data-list-item="true"]`;
133
- }
134
- if (isButtonItem) {
135
- return `[data-close-button="true"]`;
136
- }
137
- return undefined;
138
- };
139
- if (event.key === "ArrowDown") {
140
- const nextItem = getNewFocusableItem(1, searchListRef.current, getSelector());
141
- nextItem === null || nextItem === void 0 ? void 0 : nextItem.focus();
142
- return;
143
- }
144
- if (event.key === "ArrowUp") {
145
- const prevItem = getNewFocusableItem(-1, searchListRef.current, getSelector());
146
- prevItem === null || prevItem === void 0 ? void 0 : prevItem.focus();
147
- return;
148
- }
149
- if (event.key === "ArrowRight" && isListItem) {
150
- const nextItem = getNewFocusableItem(1, searchListRef.current, `[data-close-button="true"]`);
151
- nextItem === null || nextItem === void 0 ? void 0 : nextItem.focus();
152
- return;
153
- }
154
- if (event.key === "ArrowLeft" && isButtonItem) {
155
- const prevItem = getNewFocusableItem(-1, searchListRef.current, `[data-list-item="true"]`);
156
- prevItem === null || prevItem === void 0 ? void 0 : prevItem.focus();
157
- return;
158
- }
159
- }, [searchListRef]);
160
- const memoizedRecentDataArr = useMemo(() => recentItems.filter(item => !removedItems.includes(item.id)).reverse(), [recentItems, removedItems]);
161
- const memoizedRecentData = useMemo(() => {
162
- if (currentMode !== "recent" && currentMode !== "history") {
163
- return [];
164
- }
165
- const recentDataArr = currentMode === "history" ? memoizedRecentDataArr : memoizedRecentDataArr.slice(0, waitingItemsLimit);
166
- return recentDataArr.map(item => (_jsx(FiltersSearchItemData, { id: item.id, name: item.name, isActive: false, secondary: item.description, onClose: handleRemove(item.id), onClick: memoizedRecentSearchItemClick(item.id, item.type), icon: getIconByType(item.type || onlyOneType), isMobile: isMobile, isDrive: isDrive }, `${currentMode}-${item.id}`)));
167
- }, [currentMode, memoizedRecentDataArr, handleRemove, memoizedRecentSearchItemClick, getIconByType, onlyOneType, isMobile, isDrive]);
168
- const memoizedSearchData = useMemo(() => currentMode !== "search" && currentMode !== "" ? [] : searchItems.slice(0, MAX_TOTAL_RESULTS).map(item => (_jsx(FiltersSearchItemData, { id: item.id, name: item.name, isActive: isSearchModeAvailable ? (onlyOneType ? searchSelection.some(el => el.id === item.id) : searchSelection.filter(el => el.id === item.id)
169
- .some(el => el.type === (item.type || NO_TYPED_SEARCH_ITEM)) || false) : false, secondary: item.description, onClose: undefined, onClick: isSearchModeAvailable ? memoizedSearchItemClick(item.id, item.type) : undefined, icon: getIconByType(item.type || onlyOneType), isMobile: isMobile, isDrive: isDrive }, `search-${item.id}-${item.type || NO_TYPED_SEARCH_ITEM}`))), [currentMode, searchItems, isSearchModeAvailable, searchSelection, memoizedSearchItemClick, getIconByType, onlyOneType, isMobile, isDrive]);
170
- const memoizedSelectedData = useMemo(() => currentMode !== "selected" || initialSearchSelectionRef.current.length === 0 ? [] : initialSearchSelectionRef.current.slice(0, MAX_TOTAL_RESULTS)
171
- .map(item => (_jsx(FiltersSearchItemData, { id: item.id, name: item.name, isActive: onlyOneType ? (searchSelection || []).some(el => el.id === item.id)
172
- : (searchSelection || []).filter(el => el.id === item.id).some(el => el.type === (item.type || NO_TYPED_SEARCH_ITEM)) || false, secondary: item.description, onClose: undefined, onClick: memoizedSelectedItemClick(item.id, item.type), icon: getIconByType(item.type || onlyOneType), isMobile: isMobile, isDrive: isDrive }, `selected-${item.id}-${item.type || onlyOneType || NO_TYPED_SEARCH_ITEM}-${item.name}-${hasNotPopulatedName ? "notPopulated" : ""}`))), [currentMode, onlyOneType, searchSelection, memoizedSelectedItemClick, getIconByType, isMobile, isDrive, hasNotPopulatedName]);
173
- const resultsToShow = useMemo(() => {
174
- if (currentMode === "search") {
175
- return memoizedSearchData;
176
- }
177
- if (currentMode === "recent" || currentMode === "history") {
178
- return memoizedRecentData;
179
- }
180
- if (currentMode === "selected") {
181
- return memoizedSelectedData;
182
- }
183
- return memoizedSearchData;
184
- }, [currentMode, memoizedSearchData, memoizedRecentData, memoizedSelectedData]);
185
- const getSearchHeaderContent = () => {
186
- if (currentMode === "history") {
187
- return _jsxs(_Fragment, { children: [_jsx(TextIconButton, { className: "zen-filters-search-list__header-back-button", title: translate("Back"), type: "tertiary", onClick: changeMode.bind(null, "recent"), icon: IconChevronLeft, iconPosition: ButtonIconPosition.Start }), _jsx(Button, { type: "tertiary", onClick: handleRemoveAll, children: translate("Clear all") })] });
188
- }
189
- if (currentMode === "recent" || currentMode === "selected") {
190
- return _jsxs(_Fragment, { children: [_jsxs("div", { className: "zen-filters-search-list__header-title", children: [_jsx(Button, { type: currentMode === "recent" ? "tertiary" : "tertiary-black", className: currentMode === "recent" ? "zen-filters-search-list__header-button--active" : "", title: translate("Recent searches"), onClick: changeMode.bind(null, "recent"), children: translate("Recent searches") }), _jsx(Button, { type: currentMode === "selected" ? "tertiary" : "tertiary-black", className: currentMode === "selected" ? "zen-filters-search-list__header-button--active" : "", title: translate("Currently selected"), onClick: changeMode.bind(null, "selected"), children: translate("Currently selected") })] }), currentMode === "recent" && recentItems.length > resultsToShow.length && _jsx(Button, { type: "tertiary", onClick: changeMode.bind(null, "history"), children: translate("View history") }), currentMode === "selected" && resultsToShow.length > 0 && _jsx(Button, { type: "tertiary", onClick: memoizedClearSelectedItems, children: translate("Clear") })] });
191
- }
192
- if (currentMode === "search" && resultsToShow.length > 0) {
193
- return _jsx("div", { className: "zen-filters-search-list__header-title", children: translate("Top results") });
194
- }
195
- return undefined;
122
+ export const FiltersSearchList = ({
123
+ searchValue,
124
+ searchData,
125
+ recentSearches,
126
+ searchSelection,
127
+ onlyOneType,
128
+ handleSearchItemClick,
129
+ onRemoveRecentSearchItem,
130
+ handleRecentSearchItemClick,
131
+ getIconByType,
132
+ handleClearSearchSelection,
133
+ searchListRef
134
+ }) => {
135
+ const {
136
+ translate
137
+ } = useLanguage();
138
+ const isSearchModeAvailable = Boolean(handleSearchItemClick && searchSelection);
139
+ const isRecentSearchesModeAvailable = Boolean(recentSearches && handleRecentSearchItemClick && onRemoveRecentSearchItem);
140
+ const isMobile = useMobile();
141
+ const isDrive = useDrive();
142
+ const [removedItems, setRemovedItems] = useState([]);
143
+ const initialSearchSelectionRef = useRef(searchSelection || []);
144
+ const hasNotPopulatedName = initialSearchSelectionRef.current.length === 0 ? false : initialSearchSelectionRef.current.some(el => el.name === NOT_POPULATED_NAME);
145
+ const getCurrentMode = useCallback(() => {
146
+ if (searchValue) {
147
+ return "search";
148
+ }
149
+ if (isSearchModeAvailable && initialSearchSelectionRef.current.length > 0) {
150
+ return "selected";
151
+ }
152
+ if (isRecentSearchesModeAvailable && (recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.data) && recentSearches.data.length > 0) {
153
+ return "recent";
154
+ }
155
+ return "";
156
+ }, [searchValue, isSearchModeAvailable, isRecentSearchesModeAvailable, recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.data]);
157
+ const [currentMode, setCurrentMode] = useState(getCurrentMode());
158
+ const waitingItemsLimit = 5;
159
+ // Handle React Query errors
160
+ useEffect(() => {
161
+ if (currentMode === "search" && (searchData === null || searchData === void 0 ? void 0 : searchData.error)) {
162
+ console.error("Failed to fetch search results. Error:", searchData.error);
163
+ }
164
+ }, [currentMode, searchData === null || searchData === void 0 ? void 0 : searchData.error]);
165
+ useEffect(() => {
166
+ if (currentMode !== "search" && searchValue) {
167
+ setCurrentMode("search");
168
+ }
169
+ }, [searchValue, currentMode]);
170
+ useEffect(() => {
171
+ if (currentMode === "recent" && searchSelection && searchSelection.length === 0) {
172
+ initialSearchSelectionRef.current = [];
173
+ }
174
+ }, [isSearchModeAvailable, isRecentSearchesModeAvailable, currentMode, searchSelection]);
175
+ // Reset history mode when search value changes
176
+ useEffect(() => {
177
+ if (currentMode === "history" && searchValue) {
178
+ setCurrentMode(isSearchModeAvailable ? "search" : "");
179
+ } else if (currentMode === "search" && !searchValue) {
180
+ setCurrentMode(getCurrentMode());
181
+ }
182
+ }, [currentMode, getCurrentMode, isRecentSearchesModeAvailable, isSearchModeAvailable, searchValue]);
183
+ useEffect(() => {
184
+ if (searchSelection && searchSelection.length === 0) {
185
+ return;
186
+ }
187
+ searchSelection === null || searchSelection === void 0 ? void 0 : searchSelection.forEach(item => {
188
+ const existingItem = initialSearchSelectionRef.current.find(el => onlyOneType ? el.id === item.id : el.id === item.id && el.type === item.type);
189
+ if (!existingItem) {
190
+ initialSearchSelectionRef.current = [...initialSearchSelectionRef.current, item];
191
+ } else if (hasNotPopulatedName) {
192
+ existingItem.name = item.name;
193
+ existingItem.description = item.description;
194
+ existingItem.type = item.type;
195
+ }
196
+ });
197
+ }, [hasNotPopulatedName, onlyOneType, searchSelection]);
198
+ const searchItems = useMemo(() => currentMode === "search" || currentMode === "" ? (searchData === null || searchData === void 0 ? void 0 : searchData.data) || [] : [], [currentMode, searchData === null || searchData === void 0 ? void 0 : searchData.data]);
199
+ const recentItems = useMemo(() => currentMode === "recent" || currentMode === "history" ? (recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.data) || [] : [], [currentMode, recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.data]);
200
+ const isLoading = currentMode === "search" && (searchData === null || searchData === void 0 ? void 0 : searchData.isLoading) || (currentMode === "recent" || currentMode === "history" ? recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.isLoading : false) || false;
201
+ const changeMode = useCallback(newVal => {
202
+ setCurrentMode(newVal);
203
+ setRemovedItems([]);
204
+ // Note: In React Query implementation, the parent component should handle
205
+ // refetching data when switching between modes
206
+ }, []);
207
+ const handleRemove = useCallback(itemId => () => {
208
+ var _a;
209
+ setRemovedItems(prev => [...prev, itemId]);
210
+ onRemoveRecentSearchItem && onRemoveRecentSearchItem([itemId]);
211
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
212
+ const firstItem = (_a = searchListRef.current) === null || _a === void 0 ? void 0 : _a.querySelector(FOCUSABLE_SELECTOR);
213
+ firstItem === null || firstItem === void 0 ? void 0 : firstItem.focus();
214
+ }, [onRemoveRecentSearchItem, searchListRef]);
215
+ const handleRemoveAll = useCallback(() => {
216
+ setRemovedItems(recentItems.map(item => item.id));
217
+ onRemoveRecentSearchItem && onRemoveRecentSearchItem(recentItems.map(item => item.id));
218
+ changeMode(getCurrentMode());
219
+ }, [recentItems, onRemoveRecentSearchItem, changeMode, getCurrentMode]);
220
+ const memoizedSearchItemClick = useCallback((itemId, itemType) => () => {
221
+ const currentSearchItem = onlyOneType && !itemType ? searchItems.find(item => item.id === itemId) : searchItems.find(item => item.id === itemId && item.type === itemType);
222
+ currentSearchItem && handleSearchItemClick && handleSearchItemClick(currentSearchItem);
223
+ }, [handleSearchItemClick, onlyOneType, searchItems]);
224
+ const memoizedSelectedItemClick = useCallback((itemId, itemType) => () => {
225
+ const currentSelectedItem = onlyOneType && !itemType ? initialSearchSelectionRef.current.find(item => item.id === itemId) : initialSearchSelectionRef.current.find(item => item.id === itemId && item.type === itemType);
226
+ currentSelectedItem && handleSearchItemClick && handleSearchItemClick(currentSelectedItem);
227
+ }, [handleSearchItemClick, onlyOneType]);
228
+ const memoizedRecentSearchItemClick = useCallback((itemId, itemType) => () => {
229
+ const currentSearchItem = recentItems.find(item => item.id === itemId && item.type === itemType);
230
+ currentSearchItem && handleRecentSearchItemClick && handleRecentSearchItemClick(currentSearchItem);
231
+ }, [handleRecentSearchItemClick, recentItems]);
232
+ const memoizedClearSelectedItems = useCallback(() => {
233
+ var _a;
234
+ handleClearSearchSelection === null || handleClearSearchSelection === void 0 ? void 0 : handleClearSearchSelection();
235
+ initialSearchSelectionRef.current = [];
236
+ setCurrentMode(isRecentSearchesModeAvailable && ((_a = recentSearches === null || recentSearches === void 0 ? void 0 : recentSearches.data) === null || _a === void 0 ? void 0 : _a.length) ? "recent" : "");
237
+ }, [handleClearSearchSelection, isRecentSearchesModeAvailable, recentSearches]);
238
+ const handleKeyDown = useCallback(event => {
239
+ const isListItem = event.target instanceof HTMLElement && event.target.dataset.listItem === "true";
240
+ const isButtonItem = event.target instanceof HTMLElement && event.target.dataset.closeButton === "true";
241
+ const getSelector = () => {
242
+ if (isListItem) {
243
+ return `[data-list-item="true"]`;
244
+ }
245
+ if (isButtonItem) {
246
+ return `[data-close-button="true"]`;
247
+ }
248
+ return undefined;
196
249
  };
197
- const searchHeaderContent = getSearchHeaderContent();
198
- return _jsxs("div", { className: "zen-filters-search-list", children: [searchHeaderContent ? _jsx("div", { className: classNames(["zen-filters-search-list__header", isDrive ? (isMobile ? "zen-filters-search-list__header--drive" : "zen-filters-search-list__header--drive-tablet") : ""]), children: searchHeaderContent }) : null, _jsx("div", { ref: searchListRef, children: _jsx(List, { className: "zen-filters-search-list__data", onKeyDown: handleKeyDown, isLoading: currentMode === "selected" ? false : isLoading, type: "data", waitingItems: waitingItemsLimit, children: resultsToShow }) }), !isLoading && resultsToShow.length === 0 ? _jsx(EmptySearchList, { children: translate("No data available") }) : null] });
199
- };
250
+ if (event.key === "ArrowDown") {
251
+ const nextItem = getNewFocusableItem(1, searchListRef.current, getSelector());
252
+ nextItem === null || nextItem === void 0 ? void 0 : nextItem.focus();
253
+ return;
254
+ }
255
+ if (event.key === "ArrowUp") {
256
+ const prevItem = getNewFocusableItem(-1, searchListRef.current, getSelector());
257
+ prevItem === null || prevItem === void 0 ? void 0 : prevItem.focus();
258
+ return;
259
+ }
260
+ if (event.key === "ArrowRight" && isListItem) {
261
+ const nextItem = getNewFocusableItem(1, searchListRef.current, `[data-close-button="true"]`);
262
+ nextItem === null || nextItem === void 0 ? void 0 : nextItem.focus();
263
+ return;
264
+ }
265
+ if (event.key === "ArrowLeft" && isButtonItem) {
266
+ const prevItem = getNewFocusableItem(-1, searchListRef.current, `[data-list-item="true"]`);
267
+ prevItem === null || prevItem === void 0 ? void 0 : prevItem.focus();
268
+ return;
269
+ }
270
+ }, [searchListRef]);
271
+ const memoizedRecentDataArr = useMemo(() => recentItems.filter(item => !removedItems.includes(item.id)).reverse(), [recentItems, removedItems]);
272
+ const memoizedRecentData = useMemo(() => {
273
+ if (currentMode !== "recent" && currentMode !== "history") {
274
+ return [];
275
+ }
276
+ const recentDataArr = currentMode === "history" ? memoizedRecentDataArr : memoizedRecentDataArr.slice(0, waitingItemsLimit);
277
+ return recentDataArr.map(item => _jsx(FiltersSearchItemData, {
278
+ id: item.id,
279
+ name: item.name,
280
+ isActive: false,
281
+ secondary: item.description,
282
+ onClose: handleRemove(item.id),
283
+ onClick: memoizedRecentSearchItemClick(item.id, item.type),
284
+ icon: getIconByType(item.type || onlyOneType),
285
+ isMobile: isMobile,
286
+ isDrive: isDrive
287
+ }, `${currentMode}-${item.id}`));
288
+ }, [currentMode, memoizedRecentDataArr, handleRemove, memoizedRecentSearchItemClick, getIconByType, onlyOneType, isMobile, isDrive]);
289
+ const memoizedSearchData = useMemo(() => currentMode !== "search" && currentMode !== "" ? [] : searchItems.slice(0, MAX_TOTAL_RESULTS).map(item => _jsx(FiltersSearchItemData, {
290
+ id: item.id,
291
+ name: item.name,
292
+ isActive: isSearchModeAvailable ? onlyOneType ? searchSelection.some(el => el.id === item.id) : searchSelection.filter(el => el.id === item.id).some(el => el.type === (item.type || NO_TYPED_SEARCH_ITEM)) || false : false,
293
+ secondary: item.description,
294
+ onClose: undefined,
295
+ onClick: isSearchModeAvailable ? memoizedSearchItemClick(item.id, item.type) : undefined,
296
+ icon: getIconByType(item.type || onlyOneType),
297
+ isMobile: isMobile,
298
+ isDrive: isDrive
299
+ }, `search-${item.id}-${item.type || NO_TYPED_SEARCH_ITEM}`)), [currentMode, searchItems, isSearchModeAvailable, searchSelection, memoizedSearchItemClick, getIconByType, onlyOneType, isMobile, isDrive]);
300
+ const memoizedSelectedData = useMemo(() => currentMode !== "selected" || initialSearchSelectionRef.current.length === 0 ? [] : initialSearchSelectionRef.current.slice(0, MAX_TOTAL_RESULTS).map(item => _jsx(FiltersSearchItemData, {
301
+ id: item.id,
302
+ name: item.name,
303
+ isActive: onlyOneType ? (searchSelection || []).some(el => el.id === item.id) : (searchSelection || []).filter(el => el.id === item.id).some(el => el.type === (item.type || NO_TYPED_SEARCH_ITEM)) || false,
304
+ secondary: item.description,
305
+ onClose: undefined,
306
+ onClick: memoizedSelectedItemClick(item.id, item.type),
307
+ icon: getIconByType(item.type || onlyOneType),
308
+ isMobile: isMobile,
309
+ isDrive: isDrive
310
+ }, `selected-${item.id}-${item.type || onlyOneType || NO_TYPED_SEARCH_ITEM}-${item.name}-${hasNotPopulatedName ? "notPopulated" : ""}`)), [currentMode, onlyOneType, searchSelection, memoizedSelectedItemClick, getIconByType, isMobile, isDrive, hasNotPopulatedName]);
311
+ const resultsToShow = useMemo(() => {
312
+ if (currentMode === "search") {
313
+ return memoizedSearchData;
314
+ }
315
+ if (currentMode === "recent" || currentMode === "history") {
316
+ return memoizedRecentData;
317
+ }
318
+ if (currentMode === "selected") {
319
+ return memoizedSelectedData;
320
+ }
321
+ return memoizedSearchData;
322
+ }, [currentMode, memoizedSearchData, memoizedRecentData, memoizedSelectedData]);
323
+ const getSearchHeaderContent = () => {
324
+ if (currentMode === "history") {
325
+ return _jsxs(_Fragment, {
326
+ children: [_jsx(TextIconButton, {
327
+ className: "zen-filters-search-list__header-back-button",
328
+ title: translate("Back"),
329
+ type: "tertiary",
330
+ onClick: changeMode.bind(null, "recent"),
331
+ icon: IconChevronLeft,
332
+ iconPosition: ButtonIconPosition.Start
333
+ }), _jsx(Button, {
334
+ type: "tertiary",
335
+ onClick: handleRemoveAll,
336
+ children: translate("Clear all")
337
+ })]
338
+ });
339
+ }
340
+ if (currentMode === "recent" || currentMode === "selected") {
341
+ return _jsxs(_Fragment, {
342
+ children: [_jsxs("div", {
343
+ className: "zen-filters-search-list__header-title",
344
+ children: [_jsx(Button, {
345
+ type: currentMode === "recent" ? "tertiary" : "tertiary-black",
346
+ className: currentMode === "recent" ? "zen-filters-search-list__header-button--active" : "",
347
+ title: translate("Recent searches"),
348
+ onClick: changeMode.bind(null, "recent"),
349
+ children: translate("Recent searches")
350
+ }), _jsx(Button, {
351
+ type: currentMode === "selected" ? "tertiary" : "tertiary-black",
352
+ className: currentMode === "selected" ? "zen-filters-search-list__header-button--active" : "",
353
+ title: translate("Currently selected"),
354
+ onClick: changeMode.bind(null, "selected"),
355
+ children: translate("Currently selected")
356
+ })]
357
+ }), currentMode === "recent" && recentItems.length > resultsToShow.length && _jsx(Button, {
358
+ type: "tertiary",
359
+ onClick: changeMode.bind(null, "history"),
360
+ children: translate("View history")
361
+ }), currentMode === "selected" && resultsToShow.length > 0 && _jsx(Button, {
362
+ type: "tertiary",
363
+ onClick: memoizedClearSelectedItems,
364
+ children: translate("Clear")
365
+ })]
366
+ });
367
+ }
368
+ if (currentMode === "search" && resultsToShow.length > 0) {
369
+ return _jsx("div", {
370
+ className: "zen-filters-search-list__header-title",
371
+ children: translate("Top results")
372
+ });
373
+ }
374
+ return undefined;
375
+ };
376
+ const searchHeaderContent = getSearchHeaderContent();
377
+ return _jsxs("div", {
378
+ className: "zen-filters-search-list",
379
+ children: [searchHeaderContent ? _jsx("div", {
380
+ className: classNames(["zen-filters-search-list__header", isDrive ? isMobile ? "zen-filters-search-list__header--drive" : "zen-filters-search-list__header--drive-tablet" : ""]),
381
+ children: searchHeaderContent
382
+ }) : null, _jsx("div", {
383
+ ref: searchListRef,
384
+ children: _jsx(List, {
385
+ className: "zen-filters-search-list__data",
386
+ onKeyDown: handleKeyDown,
387
+ isLoading: currentMode === "selected" ? false : isLoading,
388
+ type: "data",
389
+ waitingItems: waitingItemsLimit,
390
+ children: resultsToShow
391
+ })
392
+ }), !isLoading && resultsToShow.length === 0 ? _jsx(EmptySearchList, {
393
+ children: translate("No data available")
394
+ }) : null]
395
+ });
396
+ };