@geotab/zenith 3.1.1-beta.6 → 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 (430) 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.js +12 -11
  86. package/dist/formField/hooks/useError.js +100 -36
  87. package/dist/formGroup/components/reviewListToggle/reviewListToggle.js +72 -7
  88. package/dist/formGroup/hooks/useToggle.js +37 -11
  89. package/dist/formGroup/utils/getControls.js +8 -7
  90. package/dist/formLayout/hooks/useError.js +55 -15
  91. package/dist/formLayout/hooks/useFormButtons.js +128 -27
  92. package/dist/formSection/components/formSectionModal.js +1 -1
  93. package/dist/formSection/formSection.js +1 -1
  94. package/dist/formSection/hooks/useError.js +70 -22
  95. package/dist/formStepper/components/formStep.js +65 -10
  96. package/dist/formStepper/formStepper.js +129 -33
  97. package/dist/formStepperButtons/formStepperButtons.js +184 -38
  98. package/dist/groupsFilter/groupsHelper.d.ts +1 -1
  99. package/dist/groupsFilterRaw/groupsFilterAdjustmentState.js +162 -17
  100. package/dist/groupsFilterRaw/groupsFilterBox.js +137 -32
  101. package/dist/groupsFilterRaw/groupsFilterCommon.js +75 -8
  102. package/dist/groupsFilterRaw/groupsFilterCurrentlySelectedState.js +184 -25
  103. package/dist/groupsFilterRaw/groupsFilterHelper.d.ts +2 -1
  104. package/dist/groupsFilterRaw/groupsFilterHelper.js +284 -168
  105. package/dist/groupsFilterRaw/groupsFilterInitialState.js +266 -18
  106. package/dist/groupsFilterRaw/groupsFilterMenu.js +124 -9
  107. package/dist/groupsFilterRaw/groupsFilterRaw.d.ts +1 -0
  108. package/dist/groupsFilterRaw/groupsFilterRaw.js +816 -308
  109. package/dist/groupsFilterRaw/groupsFilterTestData.d.ts +155 -2
  110. package/dist/groupsFilterRaw/groupsFilterTestData.js +153 -58
  111. package/dist/groupsFilterRaw/groupsFilterTrigger.js +139 -35
  112. package/dist/groupsFilterRaw/groupsHelper.js +739 -208
  113. package/dist/groupsFilterRaw/stateReducer/stateReducerHelper.js +3 -1
  114. package/dist/groupsFilterRaw/types.d.ts +1 -0
  115. package/dist/header/components/collapsedItemsControl/collapsedItemsControl.js +107 -52
  116. package/dist/header/components/mobileFilterControl/mobileFilterControl.js +62 -9
  117. package/dist/header/components/mobileSearchControl/mobileSearchControl.js +119 -14
  118. package/dist/header/headerBack.js +64 -20
  119. package/dist/index.css +110 -71
  120. package/dist/index.d.ts +1 -0
  121. package/dist/index.js +4 -1
  122. package/dist/list/itemData/itemDataInternal.js +216 -51
  123. package/dist/list/listItem/listItem.js +168 -55
  124. package/dist/menu/components/menuErrorItem.js +33 -5
  125. package/dist/mobileSheet/mobileSheet.js +195 -69
  126. package/dist/modal/modal.js +300 -142
  127. package/dist/nav/nav.js +1 -1
  128. package/dist/nav/navFooter/navFooter.js +82 -39
  129. package/dist/nav/navFooter/navFooterAction/navFooterAction.js +52 -13
  130. package/dist/nav/navHeader/navHeader.js +86 -36
  131. package/dist/nav/navHeader/navHeaderSearch/navHeaderSearch.js +88 -29
  132. package/dist/nav/navItem/navItem.d.ts +3 -3
  133. package/dist/nav/navItem/navItem.js +35 -33
  134. package/dist/nav/navMobileBar/navMobileBar.js +67 -21
  135. package/dist/notification/notification.js +124 -21
  136. package/dist/pagination/paginationArrow.js +81 -11
  137. package/dist/pagination/paginationText/paginationText.js +45 -11
  138. package/dist/pill/components/pillNonActionable/pillNonActionable.js +93 -24
  139. package/dist/pillBox/components/pillBoxItem.js +52 -9
  140. package/dist/pillBox/pillBox.js +121 -20
  141. package/dist/pillExpandable/pillExpandable.js +333 -139
  142. package/dist/rangeRaw/rangeRaw.js +486 -141
  143. package/dist/rangeRaw/utils/rangeHelper.js +209 -39
  144. package/dist/searchInputRaw/searchInputRaw.js +180 -65
  145. package/dist/skeleton/skeleton.js +51 -6
  146. package/dist/sortControl/sortControl.js +152 -42
  147. package/dist/stepperRaw/stepperRaw.js +116 -42
  148. package/dist/summary/summary.js +94 -8
  149. package/dist/table/actions/actionsMenu.js +171 -78
  150. package/dist/table/flexible/columnSettings.js +80 -10
  151. package/dist/table/flexible/columnsList.js +110 -43
  152. package/dist/table/flexible/columnsPopup.js +77 -20
  153. package/dist/table/nested/useNestedRows.js +167 -77
  154. package/dist/table/selectable/selectableHeader.js +180 -41
  155. package/dist/table/selectable/useSelectableRows.js +270 -191
  156. package/dist/table/sortable/sortableHeader.js +153 -75
  157. package/dist/tabs/tabs.js +227 -118
  158. package/dist/timePickerRaw/timePickerRaw.js +278 -58
  159. package/dist/toastRaw/toastRaw.js +138 -32
  160. package/dist/toggleButton/toggleButton.d.ts +0 -1
  161. package/dist/toggleButtonRaw/toggleButtonRaw.d.ts +1 -0
  162. package/dist/toggleButtonRaw/toggleButtonRaw.js +146 -40
  163. package/dist/utils/formatDate.js +1001 -117
  164. package/{esm/utils/localization/translations/cs-json.js → dist/utils/localization/translations/cs.json} +11 -12
  165. package/{esm/utils/localization/translations/da-DK-json.js → dist/utils/localization/translations/da-DK.json} +31 -23
  166. package/{esm/utils/localization/translations/de-json.js → dist/utils/localization/translations/de.json} +12 -13
  167. package/dist/utils/localization/translations/en.json +308 -0
  168. package/{esm/utils/localization/translations/es-json.js → dist/utils/localization/translations/es.json} +11 -12
  169. package/{esm/utils/localization/translations/fi-FI-json.js → dist/utils/localization/translations/fi-FI.json} +31 -23
  170. package/{esm/utils/localization/translations/fr-FR-json.js → dist/utils/localization/translations/fr-FR.json} +12 -12
  171. package/{esm/utils/localization/translations/fr-json.js → dist/utils/localization/translations/fr.json} +11 -12
  172. package/{esm/utils/localization/translations/hu-HU-json.js → dist/utils/localization/translations/hu-HU.json} +31 -23
  173. package/{esm/utils/localization/translations/id-json.js → dist/utils/localization/translations/id.json} +11 -13
  174. package/{esm/utils/localization/translations/it-json.js → dist/utils/localization/translations/it.json} +11 -12
  175. package/{esm/utils/localization/translations/ja-json.js → dist/utils/localization/translations/ja.json} +11 -12
  176. package/{esm/utils/localization/translations/ko-KR-json.js → dist/utils/localization/translations/ko-KR.json} +24 -23
  177. package/{esm/utils/localization/translations/ms-json.js → dist/utils/localization/translations/ms.json} +11 -12
  178. package/{esm/utils/localization/translations/nb-NO-json.js → dist/utils/localization/translations/nb-NO.json} +31 -23
  179. package/{esm/utils/localization/translations/nl-json.js → dist/utils/localization/translations/nl.json} +11 -12
  180. package/{esm/utils/localization/translations/pl-json.js → dist/utils/localization/translations/pl.json} +11 -12
  181. package/{esm/utils/localization/translations/pt-BR-json.js → dist/utils/localization/translations/pt-BR.json} +11 -12
  182. package/{esm/utils/localization/translations/sk-SK-json.js → dist/utils/localization/translations/sk-SK.json} +31 -23
  183. package/{esm/utils/localization/translations/sv-json.js → dist/utils/localization/translations/sv.json} +11 -12
  184. package/{esm/utils/localization/translations/th-json.js → dist/utils/localization/translations/th.json} +11 -12
  185. package/{esm/utils/localization/translations/tr-json.js → dist/utils/localization/translations/tr.json} +11 -12
  186. package/{esm/utils/localization/translations/zh-Hans-json.js → dist/utils/localization/translations/zh-Hans.json} +11 -12
  187. package/{esm/utils/localization/translations/zh-TW-json.js → dist/utils/localization/translations/zh-TW.json} +11 -23
  188. package/dist/utils/localization/translationsDictionary.d.ts +2 -0
  189. package/dist/utils/localization/translationsDictionary.js +63 -0
  190. package/dist/utils/localization/useLanguage.js +2 -74
  191. package/esm/advancedGroupsFilter/advancedGroupsFilter.js +130 -29
  192. package/esm/advancedGroupsFilter/advancedGroupsFilterForm.js +133 -33
  193. package/esm/advancedGroupsFilter/advancedGroupsFilterFormSection.js +317 -65
  194. package/esm/advancedGroupsFilter/advancedGroupsFilterSectionTooltip.d.ts +0 -1
  195. package/esm/advancedGroupsFilter/advancedGroupsFilterSectionTooltip.js +77 -8
  196. package/esm/alertRaw/alertRaw.js +165 -51
  197. package/esm/banner/bannerMultipLine.js +121 -20
  198. package/esm/banner/bannerSingleLine.js +100 -13
  199. package/esm/betaPill/betaPill.js +105 -19
  200. package/esm/bookmark/bookmark.js +89 -27
  201. package/esm/bulkEditControl/bulkEditControl.js +161 -33
  202. package/esm/calendar/calendar.js +937 -272
  203. package/esm/calendar/calendarUtils.js +151 -84
  204. package/esm/card/card.js +233 -101
  205. package/esm/chart/accessibleChart/accessibleChartNarrative.js +642 -554
  206. package/esm/chart/accessibleChart/accessibleChartTable.js +239 -85
  207. package/esm/chart/chart.js +30 -20
  208. package/esm/chart/chartAxis/chartAxis.js +79 -6
  209. package/esm/checkboxListWithAction/checkboxListWithAction.js +218 -68
  210. package/esm/chip/chip.js +189 -90
  211. package/esm/columnsSelector/columnsSelector.js +91 -11
  212. package/esm/columnsSelector/columnsTab/columnsTab.js +53 -14
  213. package/esm/columnsSelector/columnsTabGroup/columnsTabGroup.js +75 -33
  214. package/esm/comboboxSelected/comboboxSelected.js +1 -3
  215. package/esm/dataFeed/feedExpandControl/feedExpandControl.js +21 -9
  216. package/esm/dataGrid/columns/checkboxColumn/checkboxHeaderCell.js +86 -10
  217. package/esm/dataGrid/dataGrid.js +221 -116
  218. package/esm/dataGrid/emptySearchList/emptySearchList.js +50 -8
  219. package/esm/dataGrid/entitiesListActions/actions/columnsListButton.js +45 -6
  220. package/esm/dataGrid/entitiesListActions/actions/fullscreenButton.js +58 -17
  221. package/esm/dataGrid/withFlexibleColumns/components/columnSettings.js +78 -9
  222. package/esm/dataGrid/withFlexibleColumns/components/columnSettingsSidePanel.js +44 -15
  223. package/esm/dataGrid/withSelectableRows/components/bulkActions/bulkActions.js +217 -31
  224. package/esm/dataGrid/withSelectableRows/withSelectableRows.js +280 -212
  225. package/esm/dataGrid/withSortableColumns/columns/sortableColumnWrapper.js +172 -94
  226. package/esm/dateInputInner/dateInputInner.js +785 -475
  227. package/esm/dateInputInner/dateInputInnerControlBlock.js +119 -21
  228. package/esm/dateInputRaw/dateInputRaw.js +309 -103
  229. package/esm/dateInputRaw/utils/getLabel.js +32 -6
  230. package/esm/dateRangeInner/dateRangeInner.js +166 -57
  231. package/esm/dateRangeRaw/dateRangeRaw.js +595 -238
  232. package/esm/dateRangeRaw/utils/dateRangeUtils.js +622 -239
  233. package/esm/dateSelectionWrapper/dateSelectionWrapper.js +146 -13
  234. package/esm/dialog/dialogContent.js +117 -39
  235. package/esm/dropdownRaw/dropdownHelper.d.ts +2 -2
  236. package/esm/dropdownRaw/dropdownHelper.js +10 -10
  237. package/esm/dropdownRaw/dropdownList.js +412 -56
  238. package/esm/dropdownRaw/dropdownPopup.js +212 -19
  239. package/esm/dropdownRaw/dropdownRaw.js +862 -507
  240. package/esm/dropdownRaw/dropdownSearchableTrigger.js +217 -45
  241. package/esm/dropdownRaw/stateReducer/stateAction.d.ts +5 -1
  242. package/esm/dropdownRaw/stateReducer/stateActionType.d.ts +2 -1
  243. package/esm/dropdownRaw/stateReducer/stateActionType.js +1 -0
  244. package/esm/dropdownRaw/stateReducer/stateReducer.d.ts +6 -1
  245. package/esm/dropdownRaw/stateReducer/stateReducer.js +24 -12
  246. package/esm/dropdownRaw/stateReducer/stateReducerHelper.d.ts +2 -0
  247. package/esm/dropdownRaw/stateReducer/stateReducerHelper.js +18 -0
  248. package/esm/dropdownRaw/stateReducer/stateReducerTestData.d.ts +39 -0
  249. package/esm/dropdownRaw/stateReducer/stateReducerTestData.js +71 -0
  250. package/esm/dropdownRaw/types.d.ts +1 -0
  251. package/esm/favoriteButton/favoriteButton.js +53 -9
  252. package/esm/filters/components/filtersContainer.js +141 -61
  253. package/esm/filters/components/filtersEmptySelectedList.js +24 -3
  254. package/esm/filters/components/filtersSaveModal.js +134 -41
  255. package/esm/filters/components/filtersSavedChipComponent.js +312 -107
  256. package/esm/filters/components/filtersSearchItemData.js +121 -46
  257. package/esm/filters/components/filtersSearchList.js +375 -178
  258. package/esm/filters/components/filtersSelect.js +122 -60
  259. package/esm/filters/components/filtersSelectListItem.js +119 -12
  260. package/esm/filters/components/filtersSidePanel.js +504 -177
  261. package/esm/filters/filters.js +435 -265
  262. package/esm/filtersBar/components/filtersBarPeriodPicker/getRangeOption.js +722 -270
  263. package/esm/filtersBar/components/resetComponentButton.js +39 -4
  264. package/esm/filtersBar/filtersBarActions/filtersBarActions.js +120 -14
  265. package/esm/filtersBar/filtersBarSidePanel/components/filtersBarSidePanelRange/filtersBarSidePanelRange.js +149 -48
  266. package/esm/filtersBar/filtersBarSidePanel/filtersBarSidePanel.js +354 -103
  267. package/esm/filtersBar/filtersContainer/filtersContainer.js +198 -133
  268. package/esm/formField/components/formFieldWithLabel.d.ts +2 -1
  269. package/esm/formField/components/formFieldWithLabel.js +3 -2
  270. package/esm/formField/components/formFieldWithoutLabel.d.ts +2 -1
  271. package/esm/formField/components/formFieldWithoutLabel.js +3 -3
  272. package/esm/formField/components/trailingComponent.d.ts +8 -0
  273. package/esm/formField/components/trailingComponent.js +7 -0
  274. package/esm/formField/formField.js +12 -11
  275. package/esm/formField/hooks/useError.js +94 -35
  276. package/esm/formGroup/components/reviewListToggle/reviewListToggle.js +66 -6
  277. package/esm/formGroup/hooks/useToggle.js +31 -10
  278. package/esm/formGroup/utils/getControls.js +8 -7
  279. package/esm/formLayout/hooks/useError.js +49 -14
  280. package/esm/formLayout/hooks/useFormButtons.js +122 -26
  281. package/esm/formSection/components/formSectionModal.js +1 -1
  282. package/esm/formSection/formSection.js +1 -1
  283. package/esm/formSection/hooks/useError.js +64 -21
  284. package/esm/formStepper/components/formStep.js +59 -9
  285. package/esm/formStepper/formStepper.js +123 -32
  286. package/esm/formStepperButtons/formStepperButtons.js +178 -37
  287. package/esm/groupsFilter/groupsHelper.d.ts +1 -1
  288. package/esm/groupsFilterRaw/groupsFilterAdjustmentState.js +152 -14
  289. package/esm/groupsFilterRaw/groupsFilterBox.js +131 -31
  290. package/esm/groupsFilterRaw/groupsFilterCommon.js +69 -7
  291. package/esm/groupsFilterRaw/groupsFilterCurrentlySelectedState.js +178 -24
  292. package/esm/groupsFilterRaw/groupsFilterHelper.d.ts +2 -1
  293. package/esm/groupsFilterRaw/groupsFilterHelper.js +279 -168
  294. package/esm/groupsFilterRaw/groupsFilterInitialState.js +260 -17
  295. package/esm/groupsFilterRaw/groupsFilterMenu.js +118 -8
  296. package/esm/groupsFilterRaw/groupsFilterRaw.d.ts +1 -0
  297. package/esm/groupsFilterRaw/groupsFilterRaw.js +811 -308
  298. package/esm/groupsFilterRaw/groupsFilterTestData.d.ts +155 -2
  299. package/esm/groupsFilterRaw/groupsFilterTestData.js +152 -57
  300. package/esm/groupsFilterRaw/groupsFilterTrigger.js +133 -34
  301. package/esm/groupsFilterRaw/groupsHelper.js +733 -207
  302. package/esm/groupsFilterRaw/stateReducer/stateReducerHelper.js +3 -1
  303. package/esm/groupsFilterRaw/types.d.ts +1 -0
  304. package/esm/header/components/collapsedItemsControl/collapsedItemsControl.js +101 -51
  305. package/esm/header/components/mobileFilterControl/mobileFilterControl.js +56 -8
  306. package/esm/header/components/mobileSearchControl/mobileSearchControl.js +113 -13
  307. package/esm/header/headerBack.js +58 -19
  308. package/esm/index.d.ts +1 -0
  309. package/esm/index.js +1 -0
  310. package/esm/list/itemData/itemDataInternal.js +210 -50
  311. package/esm/list/listItem/listItem.js +162 -54
  312. package/esm/menu/components/menuErrorItem.js +27 -4
  313. package/esm/mobileSheet/mobileSheet.js +189 -68
  314. package/esm/modal/modal.js +265 -120
  315. package/esm/nav/nav.js +1 -1
  316. package/esm/nav/navFooter/navFooter.js +76 -38
  317. package/esm/nav/navFooter/navFooterAction/navFooterAction.js +46 -12
  318. package/esm/nav/navHeader/navHeader.js +80 -35
  319. package/esm/nav/navHeader/navHeaderSearch/navHeaderSearch.js +82 -28
  320. package/esm/nav/navItem/navItem.d.ts +3 -3
  321. package/esm/nav/navItem/navItem.js +35 -33
  322. package/esm/nav/navMobileBar/navMobileBar.js +61 -20
  323. package/esm/notification/notification.js +114 -18
  324. package/esm/pagination/paginationArrow.js +75 -10
  325. package/esm/pagination/paginationText/paginationText.js +39 -10
  326. package/esm/pill/components/pillNonActionable/pillNonActionable.js +87 -23
  327. package/esm/pillBox/components/pillBoxItem.js +46 -8
  328. package/esm/pillBox/pillBox.js +115 -19
  329. package/esm/pillExpandable/pillExpandable.js +327 -138
  330. package/esm/rangeRaw/rangeRaw.js +480 -140
  331. package/esm/rangeRaw/utils/rangeHelper.js +203 -38
  332. package/esm/searchInputRaw/searchInputRaw.js +145 -43
  333. package/esm/skeleton/skeleton.js +45 -5
  334. package/esm/sortControl/sortControl.js +146 -41
  335. package/esm/stepperRaw/stepperRaw.js +112 -41
  336. package/esm/storybookHelpers/dataGridWithDifferentCellOptions/components/EntitiesListAction.js +178 -19
  337. package/esm/summary/summary.js +88 -7
  338. package/esm/table/actions/actionsMenu.js +165 -77
  339. package/esm/table/flexible/columnSettings.js +74 -9
  340. package/esm/table/flexible/columnsList.js +104 -42
  341. package/esm/table/flexible/columnsPopup.js +71 -19
  342. package/esm/table/nested/useNestedRows.js +161 -76
  343. package/esm/table/selectable/selectableHeader.js +174 -40
  344. package/esm/table/selectable/useSelectableRows.js +264 -190
  345. package/esm/table/sortable/sortableHeader.js +147 -74
  346. package/esm/tabs/tabs.js +221 -117
  347. package/esm/timePickerRaw/timePickerRaw.js +272 -57
  348. package/esm/toastRaw/toastRaw.js +132 -31
  349. package/esm/toggleButton/toggleButton.d.ts +0 -1
  350. package/esm/toggleButtonRaw/toggleButtonRaw.d.ts +1 -0
  351. package/esm/toggleButtonRaw/toggleButtonRaw.js +111 -18
  352. package/esm/utils/formatDate.js +995 -116
  353. package/{dist/utils/localization/translations/cs-json.js → esm/utils/localization/translations/cs.json} +11 -15
  354. package/{dist/utils/localization/translations/da-DK-json.js → esm/utils/localization/translations/da-DK.json} +31 -26
  355. package/{dist/utils/localization/translations/de-json.js → esm/utils/localization/translations/de.json} +12 -16
  356. package/esm/utils/localization/translations/en.json +308 -0
  357. package/{dist/utils/localization/translations/es-json.js → esm/utils/localization/translations/es.json} +11 -15
  358. package/{dist/utils/localization/translations/fi-FI-json.js → esm/utils/localization/translations/fi-FI.json} +31 -26
  359. package/{dist/utils/localization/translations/fr-FR-json.js → esm/utils/localization/translations/fr-FR.json} +12 -15
  360. package/{dist/utils/localization/translations/fr-json.js → esm/utils/localization/translations/fr.json} +11 -15
  361. package/{dist/utils/localization/translations/hu-HU-json.js → esm/utils/localization/translations/hu-HU.json} +31 -26
  362. package/{dist/utils/localization/translations/id-json.js → esm/utils/localization/translations/id.json} +11 -16
  363. package/{dist/utils/localization/translations/it-json.js → esm/utils/localization/translations/it.json} +11 -15
  364. package/{dist/utils/localization/translations/ja-json.js → esm/utils/localization/translations/ja.json} +11 -15
  365. package/{dist/utils/localization/translations/ko-KR-json.js → esm/utils/localization/translations/ko-KR.json} +24 -26
  366. package/{dist/utils/localization/translations/ms-json.js → esm/utils/localization/translations/ms.json} +11 -15
  367. package/{dist/utils/localization/translations/nb-NO-json.js → esm/utils/localization/translations/nb-NO.json} +31 -26
  368. package/{dist/utils/localization/translations/nl-json.js → esm/utils/localization/translations/nl.json} +11 -15
  369. package/{dist/utils/localization/translations/pl-json.js → esm/utils/localization/translations/pl.json} +11 -15
  370. package/{dist/utils/localization/translations/pt-BR-json.js → esm/utils/localization/translations/pt-BR.json} +11 -15
  371. package/{dist/utils/localization/translations/sk-SK-json.js → esm/utils/localization/translations/sk-SK.json} +31 -26
  372. package/{dist/utils/localization/translations/sv-json.js → esm/utils/localization/translations/sv.json} +11 -15
  373. package/{dist/utils/localization/translations/th-json.js → esm/utils/localization/translations/th.json} +11 -15
  374. package/{dist/utils/localization/translations/tr-json.js → esm/utils/localization/translations/tr.json} +11 -15
  375. package/{dist/utils/localization/translations/zh-Hans-json.js → esm/utils/localization/translations/zh-Hans.json} +11 -15
  376. package/{dist/utils/localization/translations/zh-TW-json.js → esm/utils/localization/translations/zh-TW.json} +11 -26
  377. package/esm/utils/localization/translationsDictionary.d.ts +2 -0
  378. package/esm/utils/localization/translationsDictionary.js +59 -0
  379. package/esm/utils/localization/useLanguage.js +1 -50
  380. package/package.json +17 -10
  381. package/dist/utils/localization/translations/cs-json.d.ts +0 -251
  382. package/dist/utils/localization/translations/da-DK-json.d.ts +0 -252
  383. package/dist/utils/localization/translations/de-json.d.ts +0 -251
  384. package/dist/utils/localization/translations/en-json.d.ts +0 -314
  385. package/dist/utils/localization/translations/en-json.js +0 -317
  386. package/dist/utils/localization/translations/es-json.d.ts +0 -251
  387. package/dist/utils/localization/translations/fi-FI-json.d.ts +0 -252
  388. package/dist/utils/localization/translations/fr-FR-json.d.ts +0 -250
  389. package/dist/utils/localization/translations/fr-json.d.ts +0 -251
  390. package/dist/utils/localization/translations/hu-HU-json.d.ts +0 -252
  391. package/dist/utils/localization/translations/id-json.d.ts +0 -252
  392. package/dist/utils/localization/translations/it-json.d.ts +0 -251
  393. package/dist/utils/localization/translations/ja-json.d.ts +0 -251
  394. package/dist/utils/localization/translations/ko-KR-json.d.ts +0 -258
  395. package/dist/utils/localization/translations/ms-json.d.ts +0 -251
  396. package/dist/utils/localization/translations/nb-NO-json.d.ts +0 -252
  397. package/dist/utils/localization/translations/nl-json.d.ts +0 -251
  398. package/dist/utils/localization/translations/pl-json.d.ts +0 -251
  399. package/dist/utils/localization/translations/pt-BR-json.d.ts +0 -251
  400. package/dist/utils/localization/translations/sk-SK-json.d.ts +0 -251
  401. package/dist/utils/localization/translations/sv-json.d.ts +0 -251
  402. package/dist/utils/localization/translations/th-json.d.ts +0 -251
  403. package/dist/utils/localization/translations/tr-json.d.ts +0 -251
  404. package/dist/utils/localization/translations/zh-Hans-json.d.ts +0 -251
  405. package/dist/utils/localization/translations/zh-TW-json.d.ts +0 -271
  406. package/esm/utils/localization/translations/cs-json.d.ts +0 -251
  407. package/esm/utils/localization/translations/da-DK-json.d.ts +0 -252
  408. package/esm/utils/localization/translations/de-json.d.ts +0 -251
  409. package/esm/utils/localization/translations/en-json.d.ts +0 -314
  410. package/esm/utils/localization/translations/en-json.js +0 -314
  411. package/esm/utils/localization/translations/es-json.d.ts +0 -251
  412. package/esm/utils/localization/translations/fi-FI-json.d.ts +0 -252
  413. package/esm/utils/localization/translations/fr-FR-json.d.ts +0 -250
  414. package/esm/utils/localization/translations/fr-json.d.ts +0 -251
  415. package/esm/utils/localization/translations/hu-HU-json.d.ts +0 -252
  416. package/esm/utils/localization/translations/id-json.d.ts +0 -252
  417. package/esm/utils/localization/translations/it-json.d.ts +0 -251
  418. package/esm/utils/localization/translations/ja-json.d.ts +0 -251
  419. package/esm/utils/localization/translations/ko-KR-json.d.ts +0 -258
  420. package/esm/utils/localization/translations/ms-json.d.ts +0 -251
  421. package/esm/utils/localization/translations/nb-NO-json.d.ts +0 -252
  422. package/esm/utils/localization/translations/nl-json.d.ts +0 -251
  423. package/esm/utils/localization/translations/pl-json.d.ts +0 -251
  424. package/esm/utils/localization/translations/pt-BR-json.d.ts +0 -251
  425. package/esm/utils/localization/translations/sk-SK-json.d.ts +0 -251
  426. package/esm/utils/localization/translations/sv-json.d.ts +0 -251
  427. package/esm/utils/localization/translations/th-json.d.ts +0 -251
  428. package/esm/utils/localization/translations/tr-json.d.ts +0 -251
  429. package/esm/utils/localization/translations/zh-Hans-json.d.ts +0 -251
  430. 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, jsxs as _jsxs } from "react/jsx-runtime";
2
3
  import { useCallback, useMemo } from "react";
3
4
  import { classNames } from "../commonHelpers/classNames/classNames";
@@ -6,12 +7,55 @@ import { IconStarFilled } from "../icons/iconStarFilled";
6
7
  import { useLanguage } from "../utils/localization/useLanguage";
7
8
  import { useDriveClassName } from "../utils/theme/useDriveClassName";
8
9
  import { useDrive } from "../utils/theme/useDrive";
9
- export const FavoriteButton = ({ isFavorite, onChange, className }) => {
10
- const { translate } = useLanguage();
11
- const driveClassName = useDriveClassName("zen-favorite-button");
12
- const isDrive = useDrive();
13
- const iconSize = useMemo(() => isDrive ? "huge" : "large", [isDrive]);
14
- const filledClassName = isFavorite ? "zen-favorite-button--filled" : "";
15
- const onClick = useCallback(() => onChange(!isFavorite), [isFavorite, onChange]);
16
- return (_jsxs("button", { onClick: onClick, className: classNames(["zen-favorite-button", driveClassName || "", filledClassName, className || ""]), title: translate("Favorite"), "aria-label": translate("Favorite"), "aria-pressed": isFavorite, children: [_jsx(IconStar, { size: iconSize, className: "zen-favorite-button__empty" }), _jsx(IconStarFilled, { size: iconSize, className: "zen-favorite-button__filled" })] }));
17
- };
10
+ injectString("cs", "Favorite", "Obl\xEDben\xE9");
11
+ injectString("da-DK", "Favorite", "Favorit");
12
+ injectString("de", "Favorite", "Favorit");
13
+ injectString("en", "Favorite", "Favorite");
14
+ injectString("es", "Favorite", "Favorito");
15
+ injectString("fi-FI", "Favorite", "Suosikki");
16
+ injectString("fr", "Favorite", "Favori");
17
+ injectString("fr-FR", "Favorite", "Favori");
18
+ injectString("hu-HU", "Favorite", "Kedvenc");
19
+ injectString("id", "Favorite", "Favorit");
20
+ injectString("it", "Favorite", "Preferito");
21
+ injectString("ja", "Favorite", "\u304A\u6C17\u306B\u5165\u308A");
22
+ injectString("ko-KR", "Favorite", "\uC990\uACA8\uCC3E\uAE30");
23
+ injectString("ms", "Favorite", "Kegemaran");
24
+ injectString("nb-NO", "Favorite", "Favoritt");
25
+ injectString("nl", "Favorite", "Favoriet");
26
+ injectString("pl", "Favorite", "Ulubione");
27
+ injectString("pt-BR", "Favorite", "Favorito");
28
+ injectString("sk-SK", "Favorite", "Ob\u013E\xFAben\xE9");
29
+ injectString("sv", "Favorite", "Favorit");
30
+ injectString("th", "Favorite", "\u0E23\u0E32\u0E22\u0E01\u0E32\u0E23\u0E42\u0E1B\u0E23\u0E14");
31
+ injectString("tr", "Favorite", "Favori");
32
+ injectString("zh-Hans", "Favorite", "\u6536\u85CF");
33
+ injectString("zh-TW", "Favorite", "\u6211\u7684\u6700\u611B");
34
+ export const FavoriteButton = ({
35
+ isFavorite,
36
+ onChange,
37
+ className
38
+ }) => {
39
+ const {
40
+ translate
41
+ } = useLanguage();
42
+ const driveClassName = useDriveClassName("zen-favorite-button");
43
+ const isDrive = useDrive();
44
+ const iconSize = useMemo(() => isDrive ? "huge" : "large", [isDrive]);
45
+ const filledClassName = isFavorite ? "zen-favorite-button--filled" : "";
46
+ const onClick = useCallback(() => onChange(!isFavorite), [isFavorite, onChange]);
47
+ return _jsxs("button", {
48
+ onClick: onClick,
49
+ className: classNames(["zen-favorite-button", driveClassName || "", filledClassName, className || ""]),
50
+ title: translate("Favorite"),
51
+ "aria-label": translate("Favorite"),
52
+ "aria-pressed": isFavorite,
53
+ children: [_jsx(IconStar, {
54
+ size: iconSize,
55
+ className: "zen-favorite-button__empty"
56
+ }), _jsx(IconStarFilled, {
57
+ size: iconSize,
58
+ className: "zen-favorite-button__filled"
59
+ })]
60
+ });
61
+ };
@@ -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, useMemo } from "react";
3
4
  import { classNames } from "../../commonHelpers/classNames/classNames";
@@ -10,64 +11,143 @@ import { IconClose } from "../../icons/iconClose";
10
11
  import { useChipStatus } from "../../chip/chipStatusProvider";
11
12
  import { useLanguage } from "../../utils/localization/useLanguage";
12
13
  import { useMobile } from "../../commonHelpers/hooks/useMobile";
13
- export const FiltersContainer = ({ className, isPinned = false, onPinChange, filtersClickHandler, hasSavedFilters, filtersForCalculation, children, filtersChipRef }) => {
14
- const chipStatus = useChipStatus();
15
- const { translate } = useLanguage();
16
- const isMobile = useMobile();
17
- const numberOfChangedFilters = useMemo(() => {
18
- const suppressedFilters = new Set();
19
- filtersForCalculation.forEach(filter => {
20
- const filterProps = filter.props;
21
- const inhibited = filterProps.inhibit;
22
- if (inhibited) {
23
- inhibited.forEach((id) => suppressedFilters.add(id));
24
- }
25
- });
26
- const filteredState = getFiltersState(filtersForCalculation.filter(f => !suppressedFilters.has(f.props.id)));
27
- return getNumberOfChangedFilters(filteredState);
28
- }, [filtersForCalculation]);
29
- const filtersChipComponent = useMemo(() => _jsx(Chip, { quantity: numberOfChangedFilters, isOpen: false, status: numberOfChangedFilters > 0 ? chipStatus || "active" : undefined, onClick: filtersClickHandler, icon: IconFilter, title: translate("All Filters"), triggerRef: filtersChipRef, children: "+" }), [numberOfChangedFilters, chipStatus, filtersClickHandler, translate, filtersChipRef]);
30
- const childrenSignature = useMemo(() => {
31
- const childrenArray = React.Children.toArray(children).filter(Boolean);
32
- return childrenArray
33
- .map(child => {
34
- if (!React.isValidElement(child)) {
35
- return "invalid";
36
- }
37
- const childId = child.props.id || "no-id";
38
- const state = child.props.state;
39
- const defaultState = child.props.defaultState;
40
- const childPropsQuery = JSON.stringify(child.props.fetchState || {});
41
- const childPropsDataItems = JSON.stringify(child.props.dataItems || "no-data-items");
42
- const stateHash = createStateHash(state);
43
- const defaultStateHash = createStateHash(defaultState);
44
- const propsHash = createPropsHash(child.props);
45
- return `${childId}|${stateHash}|${defaultStateHash}|${propsHash}|${childPropsQuery}|${childPropsDataItems}`;
46
- })
47
- .join("||");
48
- }, [children]);
49
- const memoizedChildren = useMemo(() => stabilizeChildrenWithId(children).filter(Boolean),
50
- // eslint-disable-next-line react-hooks/exhaustive-deps
51
- [childrenSignature]);
52
- const handleRemovalClick = useCallback(() => {
53
- const defaultState = createStateObject(filtersForCalculation, "defaultState");
54
- filtersForCalculation.forEach((child) => {
55
- var _a;
56
- // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
57
- if (child) {
58
- const childProps = child.props;
59
- if (childProps.id) {
60
- const childDefaultState = defaultState[childProps.id];
61
- (_a = childProps.onChange) === null || _a === void 0 ? void 0 : _a.call(childProps, childDefaultState);
62
- }
63
- }
64
- });
65
- onPinChange === null || onPinChange === void 0 ? void 0 : onPinChange(false);
66
- filtersChipRef.current.focus();
67
- }, [filtersChipRef, filtersForCalculation, onPinChange]);
68
- const chipRemovalComponent = useMemo(() => numberOfChangedFilters ?
69
- _jsx(Chip, { title: translate("Clear"), className: "zen-filters-container__removal-chip", active: false, status: isPinned ? "accent" : undefined, onChange: handleRemovalClick, icon: IconClose })
70
- : null, [isPinned, handleRemovalClick, translate, numberOfChangedFilters]);
71
- const memoizedFiltersElements = useMemo(() => _jsxs(_Fragment, { children: [memoizedChildren, hasSavedFilters ? _jsx(FiltersSavedChipComponent, {}) : null, filtersChipComponent, chipRemovalComponent] }), [chipRemovalComponent, filtersChipComponent, hasSavedFilters, memoizedChildren]);
72
- return _jsx("div", { className: classNames(["zen-filters-container", isMobile ? "zen-filters-container--mobile" : "", className || ""]), children: isMobile ? _jsx("div", { className: "zen-filters-container__mobile-scroll-wrapper", children: memoizedFiltersElements }) : memoizedFiltersElements });
73
- };
14
+ injectString("cs", "All Filters", "V\u0161echny filtry");
15
+ injectString("da-DK", "All Filters", "Alle filtre");
16
+ injectString("de", "All Filters", "Alle Filter");
17
+ injectString("en", "All Filters", "All Filters");
18
+ injectString("es", "All Filters", "Todos los filtros");
19
+ injectString("fi-FI", "All Filters", "Kaikki suodattimet");
20
+ injectString("fr", "All Filters", "Tous les filtres");
21
+ injectString("fr-FR", "All Filters", "Tous les filtres");
22
+ injectString("hu-HU", "All Filters", "Minden sz\u0171r\u0151");
23
+ injectString("id", "All Filters", "Semua Filter");
24
+ injectString("it", "All Filters", "Tutti i filtri");
25
+ injectString("ja", "All Filters", "\u3059\u3079\u3066\u306E\u30D5\u30A3\u30EB\u30BF\u30FC");
26
+ injectString("ko-KR", "All Filters", "\uBAA8\uB4E0 \uD544\uD130");
27
+ injectString("ms", "All Filters", "Semua Penyaring");
28
+ injectString("nb-NO", "All Filters", "Alle filtre");
29
+ injectString("nl", "All Filters", "Alle filters");
30
+ injectString("pl", "All Filters", "Wszystkie filtry");
31
+ injectString("pt-BR", "All Filters", "Todos os filtros");
32
+ injectString("sk-SK", "All Filters", "V\u0161etky filtre");
33
+ injectString("sv", "All Filters", "Alla filter");
34
+ injectString("th", "All Filters", "\u0E15\u0E31\u0E27\u0E01\u0E23\u0E2D\u0E07\u0E17\u0E31\u0E49\u0E07\u0E2B\u0E21\u0E14");
35
+ injectString("tr", "All Filters", "T\xFCm Filtreler");
36
+ injectString("zh-Hans", "All Filters", "\u6240\u6709\u7B5B\u9009\u5668");
37
+ injectString("zh-TW", "All Filters", "\u6240\u6709\u7BE9\u9078\u5668");
38
+ injectString("cs", "Clear", "Vymazat");
39
+ injectString("da-DK", "Clear", "Ryd");
40
+ injectString("de", "Clear", "L\xF6schen");
41
+ injectString("en", "Clear", "Clear");
42
+ injectString("es", "Clear", "Borrar");
43
+ injectString("fi-FI", "Clear", "Tyhjenn\xE4");
44
+ injectString("fr", "Clear", "Effacer");
45
+ injectString("fr-FR", "Clear", "Effacer");
46
+ injectString("hu-HU", "Clear", "T\xF6r\xF6ld.");
47
+ injectString("id", "Clear", "Hapus");
48
+ injectString("it", "Clear", "Cancella");
49
+ injectString("ja", "Clear", "\u30AF\u30EA\u30A2");
50
+ injectString("ko-KR", "Clear", "\uC9C0\uC6B0\uAE30");
51
+ injectString("ms", "Clear", "Kosongkan");
52
+ injectString("nb-NO", "Clear", "T\xF8m");
53
+ injectString("nl", "Clear", "Wissen");
54
+ injectString("pl", "Clear", "Wyczy\u015B\u0107");
55
+ injectString("pt-BR", "Clear", "Limpar");
56
+ injectString("sk-SK", "Clear", "Vyma\u017E");
57
+ injectString("sv", "Clear", "Rensa");
58
+ injectString("th", "Clear", "\u0E25\u0E49\u0E32\u0E07");
59
+ injectString("tr", "Clear", "Temizle");
60
+ injectString("zh-Hans", "Clear", "\u6E05\u9664");
61
+ injectString("zh-TW", "Clear", "\u6E05\u9664");
62
+ export const FiltersContainer = ({
63
+ className,
64
+ isPinned = false,
65
+ onPinChange,
66
+ filtersClickHandler,
67
+ hasSavedFilters,
68
+ filtersForCalculation,
69
+ children,
70
+ filtersChipRef
71
+ }) => {
72
+ const chipStatus = useChipStatus();
73
+ const {
74
+ translate
75
+ } = useLanguage();
76
+ const isMobile = useMobile();
77
+ const numberOfChangedFilters = useMemo(() => {
78
+ const suppressedFilters = new Set();
79
+ filtersForCalculation.forEach(filter => {
80
+ const filterProps = filter.props;
81
+ const inhibited = filterProps.inhibit;
82
+ if (inhibited) {
83
+ inhibited.forEach(id => suppressedFilters.add(id));
84
+ }
85
+ });
86
+ const filteredState = getFiltersState(filtersForCalculation.filter(f => !suppressedFilters.has(f.props.id)));
87
+ return getNumberOfChangedFilters(filteredState);
88
+ }, [filtersForCalculation]);
89
+ const filtersChipComponent = useMemo(() => _jsx(Chip, {
90
+ quantity: numberOfChangedFilters,
91
+ isOpen: false,
92
+ status: numberOfChangedFilters > 0 ? chipStatus || "active" : undefined,
93
+ onClick: filtersClickHandler,
94
+ icon: IconFilter,
95
+ title: translate("All Filters"),
96
+ triggerRef: filtersChipRef,
97
+ children: "+"
98
+ }), [numberOfChangedFilters, chipStatus, filtersClickHandler, translate, filtersChipRef]);
99
+ const childrenSignature = useMemo(() => {
100
+ const childrenArray = React.Children.toArray(children).filter(Boolean);
101
+ return childrenArray.map(child => {
102
+ if (!React.isValidElement(child)) {
103
+ return "invalid";
104
+ }
105
+ const childId = child.props.id || "no-id";
106
+ const state = child.props.state;
107
+ const defaultState = child.props.defaultState;
108
+ const childPropsQuery = JSON.stringify(child.props.fetchState || {});
109
+ const childPropsDataItems = JSON.stringify(child.props.dataItems || "no-data-items");
110
+ const stateHash = createStateHash(state);
111
+ const defaultStateHash = createStateHash(defaultState);
112
+ const propsHash = createPropsHash(child.props);
113
+ return `${childId}|${stateHash}|${defaultStateHash}|${propsHash}|${childPropsQuery}|${childPropsDataItems}`;
114
+ }).join("||");
115
+ }, [children]);
116
+ const memoizedChildren = useMemo(() => stabilizeChildrenWithId(children).filter(Boolean),
117
+ // eslint-disable-next-line react-hooks/exhaustive-deps
118
+ [childrenSignature]);
119
+ const handleRemovalClick = useCallback(() => {
120
+ const defaultState = createStateObject(filtersForCalculation, "defaultState");
121
+ filtersForCalculation.forEach(child => {
122
+ var _a;
123
+ // eslint-disable-next-line @typescript-eslint/no-unnecessary-condition
124
+ if (child) {
125
+ const childProps = child.props;
126
+ if (childProps.id) {
127
+ const childDefaultState = defaultState[childProps.id];
128
+ (_a = childProps.onChange) === null || _a === void 0 ? void 0 : _a.call(childProps, childDefaultState);
129
+ }
130
+ }
131
+ });
132
+ onPinChange === null || onPinChange === void 0 ? void 0 : onPinChange(false);
133
+ filtersChipRef.current.focus();
134
+ }, [filtersChipRef, filtersForCalculation, onPinChange]);
135
+ const chipRemovalComponent = useMemo(() => numberOfChangedFilters ? _jsx(Chip, {
136
+ title: translate("Clear"),
137
+ className: "zen-filters-container__removal-chip",
138
+ active: false,
139
+ status: isPinned ? "accent" : undefined,
140
+ onChange: handleRemovalClick,
141
+ icon: IconClose
142
+ }) : null, [isPinned, handleRemovalClick, translate, numberOfChangedFilters]);
143
+ const memoizedFiltersElements = useMemo(() => _jsxs(_Fragment, {
144
+ children: [memoizedChildren, hasSavedFilters ? _jsx(FiltersSavedChipComponent, {}) : null, filtersChipComponent, chipRemovalComponent]
145
+ }), [chipRemovalComponent, filtersChipComponent, hasSavedFilters, memoizedChildren]);
146
+ return _jsx("div", {
147
+ className: classNames(["zen-filters-container", isMobile ? "zen-filters-container--mobile" : "", className || ""]),
148
+ children: isMobile ? _jsx("div", {
149
+ className: "zen-filters-container__mobile-scroll-wrapper",
150
+ children: memoizedFiltersElements
151
+ }) : memoizedFiltersElements
152
+ });
153
+ };
@@ -1,7 +1,28 @@
1
+ import { injectString } from "../../utils/localization/translationsDictionary";
1
2
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
3
  import { useLanguage } from "../../utils/localization/useLanguage";
3
4
  import { ImageLooking } from "../../images/imageLooking";
5
+ injectString("en", "No Filters Selected", "No Filters Selected");
6
+ injectString("en", "Selected filters will appear here.", "Selected filters will appear here.");
4
7
  export const FiltersEmptySelectedList = () => {
5
- const { translate } = useLanguage();
6
- return _jsxs("div", { className: "zen-filters-empty-selected-list", children: [_jsx(ImageLooking, { className: "zen-filters-empty-selected-list__image", title: translate("No Filters Selected"), description: translate("Selected filters will appear here.") }), _jsxs("div", { className: "zen-filters-empty-selected-list__text", children: [_jsx("div", { className: "zen-filters-empty-selected-list__header", children: translate("No Filters Selected") }), _jsx("div", { className: "zen-filters-empty-selected-list__description", children: translate("Selected filters will appear here.") })] })] });
7
- };
8
+ const {
9
+ translate
10
+ } = useLanguage();
11
+ return _jsxs("div", {
12
+ className: "zen-filters-empty-selected-list",
13
+ children: [_jsx(ImageLooking, {
14
+ className: "zen-filters-empty-selected-list__image",
15
+ title: translate("No Filters Selected"),
16
+ description: translate("Selected filters will appear here.")
17
+ }), _jsxs("div", {
18
+ className: "zen-filters-empty-selected-list__text",
19
+ children: [_jsx("div", {
20
+ className: "zen-filters-empty-selected-list__header",
21
+ children: translate("No Filters Selected")
22
+ }), _jsx("div", {
23
+ className: "zen-filters-empty-selected-list__description",
24
+ children: translate("Selected filters will appear here.")
25
+ })]
26
+ })]
27
+ });
28
+ };
@@ -1,3 +1,4 @@
1
+ import { injectString } from "../../utils/localization/translationsDictionary";
1
2
  import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
3
  import { useCallback, useMemo, useState } from "react";
3
4
  import { Modal } from "../../modal/modal";
@@ -6,44 +7,136 @@ import { TextInput } from "../../textInput/textInput";
6
7
  import { useFiltersSavedItems } from "./filtersSavedItemsProvider";
7
8
  import { IconDisk } from "../../icons/iconDisk";
8
9
  import { useDriveClassName } from "../../utils/theme/useDriveClassName";
9
- export const FiltersSaveModal = ({ isOpen, onClose, onSave, className, prioritize }) => {
10
- const { translate } = useLanguage();
11
- const { items } = useFiltersSavedItems();
12
- const iconDriveClassName = useDriveClassName("icon");
13
- const [filterName, setFilterName] = useState("");
14
- const toggleSaveModal = useCallback(() => {
15
- onClose(!isOpen);
16
- }, [isOpen, onClose]);
17
- const handleCancelSaveModal = useCallback(() => {
18
- onClose(false);
19
- setFilterName("");
20
- }, [onClose]);
21
- const isValidFilterName = useCallback((name, existingNames) => {
22
- if (!name) {
23
- return false;
24
- }
25
- return !existingNames.map((item) => item.toLowerCase().trim()).includes(name.toLowerCase().trim());
26
- }, []);
27
- const handleApplySaveModal = useCallback(() => {
28
- if (!isValidFilterName(filterName, Array.from(items))) {
29
- return;
30
- }
31
- onClose(false);
32
- onSave(filterName);
33
- setFilterName("");
34
- }, [filterName, isValidFilterName, items, onClose, onSave]);
35
- const handleSaveModalFieldChange = useCallback((e) => {
36
- setFilterName(e.target.value);
37
- }, []);
38
- const errorText = useMemo(() => {
39
- if (!filterName) {
40
- return "";
41
- }
42
- if (!isValidFilterName(filterName, Array.from(items))) {
43
- return translate("Title already in use");
44
- }
45
- return "";
46
- }, [filterName, isValidFilterName, items, translate]);
47
- const saveIcon = useCallback(() => _jsx(IconDisk, { description: translate("Save"), className: "svgIcon", size: iconDriveClassName ? "huge" : "large" }), [iconDriveClassName, translate]);
48
- return _jsxs(Modal, { focus: "content", modalContainerClassName: prioritize ? "zen-filters-prioritized-modal" : "", isOpen: isOpen, onClose: toggleSaveModal, title: translate("Save filters"), className: className || "", children: [_jsx("div", { className: "zen-filters-modal__content", children: _jsx(TextInput, { value: filterName, ariaLabel: translate("Filter title"), placeholder: translate("Filter title"), onChange: handleSaveModalFieldChange, maxLength: 100, error: errorText }) }), _jsx(Modal.SecondaryButton, { onClick: handleCancelSaveModal, title: translate("Cancel"), children: translate("Cancel") }), _jsx(Modal.PrimaryButton, { onClick: handleApplySaveModal, icon: saveIcon, title: translate("Save"), children: translate("Save") })] });
49
- };
10
+ injectString("en", "Title already in use", "Title already in use");
11
+ injectString("cs", "Save", "Ulo\u017Eit");
12
+ injectString("da-DK", "Save", "Spare");
13
+ injectString("de", "Save", "Speichern");
14
+ injectString("en", "Save", "Save");
15
+ injectString("es", "Save", "Guardar");
16
+ injectString("fi-FI", "Save", "S\xE4\xE4st\xE4\xE4");
17
+ injectString("fr", "Save", "Enregistrer");
18
+ injectString("fr-FR", "Save", "Enregistrer");
19
+ injectString("hu-HU", "Save", "Ment\xE9s");
20
+ injectString("id", "Save", "Simpan");
21
+ injectString("it", "Save", "Salvare");
22
+ injectString("ja", "Save", "\u4FDD\u5B58");
23
+ injectString("ko-KR", "Save", "\uC800\uC7A5");
24
+ injectString("ms", "Save", "Simpan");
25
+ injectString("nb-NO", "Save", "Lagre");
26
+ injectString("nl", "Save", "Opslaan");
27
+ injectString("pl", "Save", "Zapisz");
28
+ injectString("pt-BR", "Save", "Salvar");
29
+ injectString("sk-SK", "Save", "Ulo\u017Ei\u0165");
30
+ injectString("sv", "Save", "Spara");
31
+ injectString("th", "Save", "\u0E1A\u0E31\u0E19\u0E17\u0E36\u0E01");
32
+ injectString("tr", "Save", "Kaydet");
33
+ injectString("zh-Hans", "Save", "\u4FDD\u5B58");
34
+ injectString("zh-TW", "Save", "\u5132\u5B58");
35
+ injectString("en", "Save filters", "Save filters");
36
+ injectString("en", "Filter title", "Filter title");
37
+ injectString("cs", "Cancel", "Zru\u0161it");
38
+ injectString("da-DK", "Cancel", "Annuller");
39
+ injectString("de", "Cancel", "Abbrechen");
40
+ injectString("en", "Cancel", "Cancel");
41
+ injectString("es", "Cancel", "Cancelar");
42
+ injectString("fi-FI", "Cancel", "Peruuta");
43
+ injectString("fr", "Cancel", "Annuler");
44
+ injectString("fr-FR", "Cancel", "Annuler");
45
+ injectString("hu-HU", "Cancel", "M\xE9gse");
46
+ injectString("id", "Cancel", "Batalkan");
47
+ injectString("it", "Cancel", "Annullare");
48
+ injectString("ja", "Cancel", "\u30AD\u30E3\u30F3\u30BB\u30EB");
49
+ injectString("ko-KR", "Cancel", "\uCDE8\uC18C");
50
+ injectString("ms", "Cancel", "Batal");
51
+ injectString("nb-NO", "Cancel", "Avbryt");
52
+ injectString("nl", "Cancel", "Annuleren");
53
+ injectString("pl", "Cancel", "Anuluj");
54
+ injectString("pt-BR", "Cancel", "Cancelar");
55
+ injectString("sk-SK", "Cancel", "Zru\u0161.");
56
+ injectString("sv", "Cancel", "Avbryt");
57
+ injectString("th", "Cancel", "\u0E22\u0E01\u0E40\u0E25\u0E34\u0E01");
58
+ injectString("tr", "Cancel", "\u0130ptal");
59
+ injectString("zh-Hans", "Cancel", "\u53D6\u6D88");
60
+ injectString("zh-TW", "Cancel", "\u53D6\u6D88");
61
+ export const FiltersSaveModal = ({
62
+ isOpen,
63
+ onClose,
64
+ onSave,
65
+ className,
66
+ prioritize
67
+ }) => {
68
+ const {
69
+ translate
70
+ } = useLanguage();
71
+ const {
72
+ items
73
+ } = useFiltersSavedItems();
74
+ const iconDriveClassName = useDriveClassName("icon");
75
+ const [filterName, setFilterName] = useState("");
76
+ const toggleSaveModal = useCallback(() => {
77
+ onClose(!isOpen);
78
+ }, [isOpen, onClose]);
79
+ const handleCancelSaveModal = useCallback(() => {
80
+ onClose(false);
81
+ setFilterName("");
82
+ }, [onClose]);
83
+ const isValidFilterName = useCallback((name, existingNames) => {
84
+ if (!name) {
85
+ return false;
86
+ }
87
+ return !existingNames.map(item => item.toLowerCase().trim()).includes(name.toLowerCase().trim());
88
+ }, []);
89
+ const handleApplySaveModal = useCallback(() => {
90
+ if (!isValidFilterName(filterName, Array.from(items))) {
91
+ return;
92
+ }
93
+ onClose(false);
94
+ onSave(filterName);
95
+ setFilterName("");
96
+ }, [filterName, isValidFilterName, items, onClose, onSave]);
97
+ const handleSaveModalFieldChange = useCallback(e => {
98
+ setFilterName(e.target.value);
99
+ }, []);
100
+ const errorText = useMemo(() => {
101
+ if (!filterName) {
102
+ return "";
103
+ }
104
+ if (!isValidFilterName(filterName, Array.from(items))) {
105
+ return translate("Title already in use");
106
+ }
107
+ return "";
108
+ }, [filterName, isValidFilterName, items, translate]);
109
+ const saveIcon = useCallback(() => _jsx(IconDisk, {
110
+ description: translate("Save"),
111
+ className: "svgIcon",
112
+ size: iconDriveClassName ? "huge" : "large"
113
+ }), [iconDriveClassName, translate]);
114
+ return _jsxs(Modal, {
115
+ focus: "content",
116
+ modalContainerClassName: prioritize ? "zen-filters-prioritized-modal" : "",
117
+ isOpen: isOpen,
118
+ onClose: toggleSaveModal,
119
+ title: translate("Save filters"),
120
+ className: className || "",
121
+ children: [_jsx("div", {
122
+ className: "zen-filters-modal__content",
123
+ children: _jsx(TextInput, {
124
+ value: filterName,
125
+ ariaLabel: translate("Filter title"),
126
+ placeholder: translate("Filter title"),
127
+ onChange: handleSaveModalFieldChange,
128
+ maxLength: 100,
129
+ error: errorText
130
+ })
131
+ }), _jsx(Modal.SecondaryButton, {
132
+ onClick: handleCancelSaveModal,
133
+ title: translate("Cancel"),
134
+ children: translate("Cancel")
135
+ }), _jsx(Modal.PrimaryButton, {
136
+ onClick: handleApplySaveModal,
137
+ icon: saveIcon,
138
+ title: translate("Save"),
139
+ children: translate("Save")
140
+ })]
141
+ });
142
+ };