@geotab/zenith 1.16.1 → 1.17.0-beta.1

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 (231) hide show
  1. package/README.md +15 -0
  2. package/dist/alertRaw/alertRaw.test.js +20 -10
  3. package/dist/alertRaw/alertRaw.test.js.map +1 -1
  4. package/dist/betaPill/betaPill.d.ts +13 -3
  5. package/dist/betaPill/betaPill.js +19 -6
  6. package/dist/betaPill/betaPill.js.map +1 -1
  7. package/dist/betaPill/betaPillContext.d.ts +20 -0
  8. package/dist/betaPill/betaPillContext.js +11 -0
  9. package/dist/betaPill/betaPillContext.js.map +1 -0
  10. package/dist/button/button.d.ts +2 -0
  11. package/dist/button/button.js +2 -2
  12. package/dist/button/button.js.map +1 -1
  13. package/dist/calendar/calendar.js.map +1 -1
  14. package/dist/calendar/calendar.mocked.test.js +2 -3
  15. package/dist/calendar/calendar.mocked.test.js.map +1 -1
  16. package/dist/calendar/calendar.test.js +53 -55
  17. package/dist/calendar/calendar.test.js.map +1 -1
  18. package/dist/calendar/calendarUtils.js.map +1 -1
  19. package/dist/calendar/calendarUtils.test.js +12 -22
  20. package/dist/calendar/calendarUtils.test.js.map +1 -1
  21. package/dist/calendar/dateUtils.js.map +1 -1
  22. package/dist/calendar/dateUtils.test.js +7 -115
  23. package/dist/calendar/dateUtils.test.js.map +1 -1
  24. package/dist/card/card.js.map +1 -1
  25. package/dist/card/components/titleLink.js.map +1 -1
  26. package/dist/card/components/titleLink.test.js +4 -4
  27. package/dist/card/components/titleLink.test.js.map +1 -1
  28. package/dist/checkbox/checkboxIconMinus.js.map +1 -1
  29. package/dist/dataFeed/dataFeed.js.map +1 -1
  30. package/dist/dataFeed/dataFeed.test.js +10 -7
  31. package/dist/dataFeed/dataFeed.test.js.map +1 -1
  32. package/dist/dataFeed/dataFeedColumnsItems.js.map +1 -1
  33. package/dist/dataFeed/feedExpandControl/feedExpandControl.js.map +1 -1
  34. package/dist/dataFeed/hooks/useVisibleColumns.js.map +1 -1
  35. package/dist/dataFeed/hooks/useVisibleColumns.test.js +12 -12
  36. package/dist/dataFeed/hooks/useVisibleColumns.test.js.map +1 -1
  37. package/dist/dataGrid/dataGrid.accessibility.test.js +124 -0
  38. package/dist/dataGrid/dataGrid.accessibility.test.js.map +1 -0
  39. package/dist/dataGrid/dataGrid.test.js +8 -39
  40. package/dist/dataGrid/dataGrid.test.js.map +1 -1
  41. package/dist/dataGrid/withLoading/withLoading.js.map +1 -1
  42. package/dist/dataGrid/withLoading/withLoading.test.js +47 -25
  43. package/dist/dataGrid/withLoading/withLoading.test.js.map +1 -1
  44. package/dist/dataGrid/withSelectableRows/components/bulkActions/bulkActions.accessibility.test.js +39 -0
  45. package/dist/dataGrid/withSelectableRows/components/bulkActions/bulkActions.accessibility.test.js.map +1 -0
  46. package/dist/dataGrid/withSelectableRows/components/bulkActions/bulkActions.test.js +0 -5
  47. package/dist/dataGrid/withSelectableRows/components/bulkActions/bulkActions.test.js.map +1 -1
  48. package/dist/dateInput/dateInput.js.map +1 -1
  49. package/dist/dateInput/dateInput.test.js +219 -105
  50. package/dist/dateInput/dateInput.test.js.map +1 -1
  51. package/dist/dateInputInner/dateInputInner.js.map +1 -1
  52. package/dist/dateInputInner/dateInputInner.mocked.test.js +19 -5
  53. package/dist/dateInputInner/dateInputInner.mocked.test.js.map +1 -1
  54. package/dist/dateInputInner/dateInputInner.test.js +264 -55
  55. package/dist/dateInputInner/dateInputInner.test.js.map +1 -1
  56. package/dist/dateInputInner/dateInputInnerControlBlock.js.map +1 -1
  57. package/dist/dateInputInner/dateInputInnerReducer.js.map +1 -0
  58. package/dist/dateRange/dateRange.accessibility.test.js +79 -0
  59. package/dist/dateRange/dateRange.accessibility.test.js.map +1 -0
  60. package/dist/dateRange/dateRange.js.map +1 -1
  61. package/dist/dateRange/dateRange.test.js +84 -57
  62. package/dist/dateRange/dateRange.test.js.map +1 -1
  63. package/dist/dateRange/dateRangeUtils.js.map +1 -1
  64. package/dist/dateRangeInner/dateRangeInner.js.map +1 -1
  65. package/dist/dateRangeInner/dateRangeInner.test.js +15 -11
  66. package/dist/dateRangeInner/dateRangeInner.test.js.map +1 -1
  67. package/dist/dropdown/dropdown.js +18 -13
  68. package/dist/dropdown/dropdown.js.map +1 -1
  69. package/dist/dropdown/dropdown.test.js +240 -72
  70. package/dist/dropdown/dropdown.test.js.map +1 -1
  71. package/dist/dropdownOld/dropdownOld.js +1 -1
  72. package/dist/dropdownOld/dropdownOld.js.map +1 -1
  73. package/dist/feedbackContainer/hooks/useFeedbackAlert.test.js +259 -0
  74. package/dist/feedbackContainer/hooks/useFeedbackAlert.test.js.map +1 -1
  75. package/dist/feedbackContainer/hooks/useFeedbackToast.test.js +197 -0
  76. package/dist/feedbackContainer/hooks/useFeedbackToast.test.js.map +1 -1
  77. package/dist/filtersBar/components/filtersBarDropdown/filtersBarDropdown.d.ts +1 -1
  78. package/dist/filtersBar/components/filtersBarDropdown/filtersBarDropdown.js.map +1 -1
  79. package/dist/filtersBar/components/filtersBarDropdown/filtersBarDropdown.test.js +29 -19
  80. package/dist/filtersBar/components/filtersBarDropdown/filtersBarDropdown.test.js.map +1 -1
  81. package/dist/filtersBar/components/filtersBarPeriodPicker/filtersBarPeriodPicker.js.map +1 -1
  82. package/dist/filtersBar/components/filtersBarPeriodPicker/getRangeOption.js.map +1 -1
  83. package/dist/filtersBar/components/filtersBarPeriodPicker/getRangeOption.test.js +122 -0
  84. package/dist/filtersBar/components/filtersBarPeriodPicker/getRangeOption.test.js.map +1 -1
  85. package/dist/filtersBar/components/filtersBarPeriodPicker/normalizeDates.js.map +1 -1
  86. package/dist/filtersBar/components/filtersBarPeriodPicker/normalizeDates.test.js +4 -3
  87. package/dist/filtersBar/components/filtersBarPeriodPicker/normalizeDates.test.js.map +1 -1
  88. package/dist/filtersBar/filtersBar.d.ts +4 -0
  89. package/dist/filtersBar/filtersBar.js +13 -4
  90. package/dist/filtersBar/filtersBar.js.map +1 -1
  91. package/dist/filtersBar/filtersBarProvider.d.ts +18 -0
  92. package/dist/filtersBar/filtersBarProvider.js +28 -0
  93. package/dist/filtersBar/filtersBarProvider.js.map +1 -0
  94. package/dist/filtersBar/filtersBarProviderSearch.d.ts +13 -0
  95. package/dist/filtersBar/filtersBarProviderSearch.js +31 -0
  96. package/dist/filtersBar/filtersBarProviderSearch.js.map +1 -0
  97. package/dist/filtersBar/filtersBarSidePanel/filtersBarSidePanel.accessibility.test.js +27 -0
  98. package/dist/filtersBar/filtersBarSidePanel/filtersBarSidePanel.accessibility.test.js.map +1 -0
  99. package/dist/filtersBar/filtersBarSidePanel/filtersBarSidePanel.test.js +78 -67
  100. package/dist/filtersBar/filtersBarSidePanel/filtersBarSidePanel.test.js.map +1 -1
  101. package/dist/groupsFilter/groupsFilter.accessibility.test.js +69 -0
  102. package/dist/groupsFilter/groupsFilter.accessibility.test.js.map +1 -0
  103. package/dist/groupsFilter/groupsFilter.test.js +0 -37
  104. package/dist/groupsFilter/groupsFilter.test.js.map +1 -1
  105. package/dist/header/components/collapsedItemsControl/collapsedItemsControl.js.map +1 -1
  106. package/dist/header/header.js +44 -39
  107. package/dist/header/header.js.map +1 -1
  108. package/dist/header/header.test.js +98 -5
  109. package/dist/header/header.test.js.map +1 -1
  110. package/dist/header/headerContext.js.map +1 -0
  111. package/dist/header/headerHelpers.d.ts +0 -1
  112. package/dist/header/headerHelpers.js +1 -12
  113. package/dist/header/headerHelpers.js.map +1 -1
  114. package/dist/header/headerHelpers.test.js +8 -9
  115. package/dist/header/headerHelpers.test.js.map +1 -1
  116. package/dist/header/headerMenu.js.map +1 -1
  117. package/dist/headerTitle/headerTitle.d.ts +3 -0
  118. package/dist/headerTitle/headerTitle.js +2 -2
  119. package/dist/headerTitle/headerTitle.js.map +1 -1
  120. package/dist/index.css +687 -678
  121. package/dist/index.d.ts +2 -1
  122. package/dist/index.js +17 -15
  123. package/dist/index.js.map +1 -1
  124. package/dist/inputAdornments/inputAdornments.js.map +1 -1
  125. package/dist/lineChart/utils.d.ts +3 -3
  126. package/dist/menu/components/menuItem.js.map +1 -1
  127. package/dist/menu/controlledMenu.accessibility.test.js +75 -0
  128. package/dist/menu/controlledMenu.accessibility.test.js.map +1 -0
  129. package/dist/menu/controlledMenu.test.js +0 -44
  130. package/dist/menu/controlledMenu.test.js.map +1 -1
  131. package/dist/parallelSelection/parallelSelection.js.map +1 -1
  132. package/dist/pillExpandable/pillExpandable.d.ts +2 -0
  133. package/dist/pillExpandable/pillExpandable.js +3 -3
  134. package/dist/pillExpandable/pillExpandable.js.map +1 -1
  135. package/dist/pillExpandable/pillExpandableSimple.d.ts +1 -0
  136. package/dist/pillExpandable/pillExpandableSimple.js +4 -2
  137. package/dist/pillExpandable/pillExpandableSimple.js.map +1 -1
  138. package/dist/searchInputRaw/searchInputRaw.accessibility.test.js +46 -0
  139. package/dist/searchInputRaw/searchInputRaw.accessibility.test.js.map +1 -0
  140. package/dist/searchInputRaw/searchInputRaw.test.js +0 -14
  141. package/dist/searchInputRaw/searchInputRaw.test.js.map +1 -1
  142. package/dist/select/select.d.ts +8 -23
  143. package/dist/select/select.js +4 -147
  144. package/dist/select/select.js.map +1 -1
  145. package/dist/selectField/selectField.d.ts +4 -4
  146. package/dist/selectField/selectField.js +1 -6
  147. package/dist/selectField/selectField.js.map +1 -1
  148. package/dist/selectList/selectList.d.ts +2 -2
  149. package/dist/selectList/selectList.js +4 -5
  150. package/dist/selectList/selectList.js.map +1 -1
  151. package/dist/selectList/selectList.test.js +1 -2
  152. package/dist/selectList/selectList.test.js.map +1 -1
  153. package/dist/selectList/selectListItem.js +6 -1
  154. package/dist/selectList/selectListItem.js.map +1 -1
  155. package/dist/selectRaw/hooks/usePopupWidth.d.ts +8 -0
  156. package/dist/selectRaw/hooks/usePopupWidth.js +72 -0
  157. package/dist/selectRaw/hooks/usePopupWidth.js.map +1 -0
  158. package/dist/selectRaw/hooks/usePopupWidth.test.js +193 -0
  159. package/dist/selectRaw/hooks/usePopupWidth.test.js.map +1 -0
  160. package/dist/selectRaw/select.actionTypes.js.map +1 -0
  161. package/dist/{select → selectRaw}/select.helpers.d.ts +2 -2
  162. package/dist/selectRaw/select.helpers.js.map +1 -0
  163. package/dist/selectRaw/select.helpers.test.js.map +1 -0
  164. package/dist/{select → selectRaw}/select.reducer.d.ts +2 -2
  165. package/dist/selectRaw/select.reducer.js.map +1 -0
  166. package/dist/selectRaw/select.reducer.test.js.map +1 -0
  167. package/dist/selectRaw/selectRaw.d.ts +30 -0
  168. package/dist/selectRaw/selectRaw.js +153 -0
  169. package/dist/selectRaw/selectRaw.js.map +1 -0
  170. package/dist/{select/select.test.js → selectRaw/selectRaw.test.js} +95 -117
  171. package/dist/selectRaw/selectRaw.test.js.map +1 -0
  172. package/dist/selectRaw/utils/constants.d.ts +2 -0
  173. package/dist/selectRaw/utils/constants.js +5 -0
  174. package/dist/selectRaw/utils/constants.js.map +1 -0
  175. package/dist/selectRaw/utils/getValidWidth.d.ts +1 -0
  176. package/dist/selectRaw/utils/getValidWidth.js +6 -0
  177. package/dist/selectRaw/utils/getValidWidth.js.map +1 -0
  178. package/dist/selectRaw/utils/getValidWidth.test.js +19 -0
  179. package/dist/selectRaw/utils/getValidWidth.test.js.map +1 -0
  180. package/dist/sortControl/sortControl.js +1 -1
  181. package/dist/sortControl/sortControl.js.map +1 -1
  182. package/dist/table/expandable/useFeedExpandable.js.map +1 -0
  183. package/dist/table/expandable/{useFeedbackExpandable.test.js → useFeedExpandable.test.js} +17 -17
  184. package/dist/table/expandable/useFeedExpandable.test.js.map +1 -0
  185. package/dist/table/flexible/useFlexibleColumns.js.map +1 -1
  186. package/dist/table/loading/useLoading.js +8 -7
  187. package/dist/table/loading/useLoading.js.map +1 -1
  188. package/dist/table/table.js.map +1 -1
  189. package/dist/table/table.test.js +46 -0
  190. package/dist/table/table.test.js.map +1 -1
  191. package/dist/textareaRaw/textareaRaw.d.ts +1 -0
  192. package/dist/textareaRaw/textareaRaw.js.map +1 -1
  193. package/dist/timePicker/timePicker.js.map +1 -1
  194. package/dist/toastRaw/toastRaw.test.js +2 -2
  195. package/dist/toastRaw/toastRaw.test.js.map +1 -1
  196. package/dist/utils/dateInputUtils/useTodayButton.js.map +1 -0
  197. package/dist/utils/localization/translations/cs-json.js.map +1 -1
  198. package/dist/utils/localization/translations/de-json.js.map +1 -1
  199. package/dist/utils/localization/translations/en-json.d.ts +3 -0
  200. package/dist/utils/localization/translations/en-json.js +3 -0
  201. package/dist/utils/localization/translations/en-json.js.map +1 -1
  202. package/dist/utils/localization/translations/es-json.js.map +1 -1
  203. package/dist/utils/localization/translations/fr-FR-json.js.map +1 -1
  204. package/dist/utils/localization/translations/fr-json.js.map +1 -1
  205. package/dist/utils/localization/translations/id-json.js.map +1 -1
  206. package/dist/utils/localization/translations/it-json.js.map +1 -1
  207. package/dist/utils/localization/translations/ja-json.js.map +1 -1
  208. package/dist/utils/localization/translations/ms-json.js.map +1 -1
  209. package/dist/utils/localization/translations/nl-json.js.map +1 -1
  210. package/dist/utils/localization/translations/pl-json.js.map +1 -1
  211. package/dist/utils/localization/translations/pt-BR-json.js.map +1 -1
  212. package/dist/utils/localization/translations/sv-json.js.map +1 -1
  213. package/dist/utils/localization/translations/th-json.js.map +1 -1
  214. package/dist/utils/localization/translations/tr-json.js.map +1 -1
  215. package/dist/utils/localization/translations/zh-Hans-json.js.map +1 -1
  216. package/package.json +4 -4
  217. package/dist/select/select.actionTypes.js.map +0 -1
  218. package/dist/select/select.helpers.js.map +0 -1
  219. package/dist/select/select.helpers.test.js.map +0 -1
  220. package/dist/select/select.reducer.js.map +0 -1
  221. package/dist/select/select.reducer.test.js.map +0 -1
  222. package/dist/select/select.test.js.map +0 -1
  223. package/dist/table/expandable/useFeedbackExpandable.js +0 -18
  224. package/dist/table/expandable/useFeedbackExpandable.js.map +0 -1
  225. package/dist/table/expandable/useFeedbackExpandable.test.js.map +0 -1
  226. /package/dist/{select → selectRaw}/select.actionTypes.d.ts +0 -0
  227. /package/dist/{select → selectRaw}/select.actionTypes.js +0 -0
  228. /package/dist/{select → selectRaw}/select.helpers.js +0 -0
  229. /package/dist/{select → selectRaw}/select.helpers.test.js +0 -0
  230. /package/dist/{select → selectRaw}/select.reducer.js +0 -0
  231. /package/dist/{select → selectRaw}/select.reducer.test.js +0 -0
@@ -14,13 +14,16 @@ describe("DateInput", () => {
14
14
  });
15
15
  beforeEach(() => {
16
16
  Element.prototype.scrollIntoView = scrollIntoViewMock;
17
+ jest.useFakeTimers();
17
18
  });
18
19
  afterEach(() => {
19
20
  window.innerWidth = windowInnerWidth;
20
21
  (0, react_1.cleanup)();
21
22
  jest.clearAllMocks();
23
+ jest.clearAllTimers();
24
+ jest.useRealTimers();
22
25
  });
23
- test("select new date", () => {
26
+ test("select new date", async () => {
24
27
  const defaultValue = "2022-01-01";
25
28
  const onChange = jest.fn();
26
29
  (0, react_1.render)((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", defaultValue: defaultValue, value: undefined, onChange: onChange }));
@@ -36,11 +39,17 @@ describe("DateInput", () => {
36
39
  (0, react_2.act)(() => {
37
40
  react_1.fireEvent.click(applyButton);
38
41
  });
39
- expect(onChange).toHaveBeenCalled();
40
- expect(onChange).toHaveBeenCalledTimes(1);
42
+ await (0, react_1.waitFor)(() => {
43
+ expect(onChange).toHaveBeenCalled();
44
+ expect(onChange).toHaveBeenCalledTimes(1);
45
+ });
41
46
  inputElement = react_1.screen.getByText("Pick a date");
42
- react_1.fireEvent.click(inputElement);
43
- expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toContain("-18");
47
+ (0, react_2.act)(() => {
48
+ react_1.fireEvent.click(inputElement);
49
+ });
50
+ await (0, react_1.waitFor)(() => {
51
+ expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toContain("-18");
52
+ });
44
53
  });
45
54
  test("when disableDatesAfter and disableDatesBefore pass", async () => {
46
55
  const defaultValue = new Date("2025-01-07T00:00:00.000Z").toISOString();
@@ -62,25 +71,49 @@ describe("DateInput", () => {
62
71
  (0, react_2.act)(() => {
63
72
  react_1.fireEvent.click(applyButton);
64
73
  });
65
- expect(onChange).toHaveBeenCalled();
66
- expect(onChange).toHaveBeenCalledTimes(1);
67
- expect(onChange).toHaveBeenCalledWith(newValue);
74
+ await (0, react_1.waitFor)(() => {
75
+ expect(onChange).toHaveBeenCalled();
76
+ expect(onChange).toHaveBeenCalledTimes(1);
77
+ expect(onChange).toHaveBeenCalledWith(newValue);
78
+ });
68
79
  rerender((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", defaultValue: defaultValue, value: newValue, disableDatesBefore: smallerDate, disableDatesAfter: largerDate, onChange: onChange, timeSelect: true }));
69
80
  triggerElement = container.querySelector(".zen-date-input");
70
- react_1.fireEvent.click(triggerElement);
71
- expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toBe("2025-01-18");
81
+ (0, react_2.act)(() => {
82
+ react_1.fireEvent.click(triggerElement);
83
+ });
84
+ await (0, react_1.waitFor)(() => {
85
+ expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toBe("2025-01-18");
86
+ });
72
87
  let inputElement = document.querySelector("input.zen-date-input-inner__text-input");
73
- react_1.fireEvent.change(inputElement, { target: { value: "2025-01-21" } });
74
- react_1.fireEvent.blur(inputElement);
75
- expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toBe("2025-01-18");
88
+ (0, react_2.act)(() => {
89
+ react_1.fireEvent.change(inputElement, { target: { value: "2025-01-21" } });
90
+ });
91
+ (0, react_2.act)(() => {
92
+ react_1.fireEvent.blur(inputElement);
93
+ });
94
+ await (0, react_1.waitFor)(() => {
95
+ expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toBe("2025-01-18");
96
+ });
76
97
  inputElement = document.querySelector("input.zen-date-input-inner__text-input");
77
- react_1.fireEvent.change(inputElement, { target: { value: "2025-01-03" } });
78
- react_1.fireEvent.blur(inputElement);
79
- expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toBe("2025-01-18");
98
+ (0, react_2.act)(() => {
99
+ react_1.fireEvent.change(inputElement, { target: { value: "2025-01-03" } });
100
+ });
101
+ (0, react_2.act)(() => {
102
+ react_1.fireEvent.blur(inputElement);
103
+ });
104
+ await (0, react_1.waitFor)(() => {
105
+ expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toBe("2025-01-18");
106
+ });
80
107
  inputElement = document.querySelector("input.zen-date-input-inner__text-input");
81
- react_1.fireEvent.change(inputElement, { target: { value: "2025-01-19" } });
82
- react_1.fireEvent.blur(inputElement);
83
- expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toBe("2025-01-19");
108
+ (0, react_2.act)(() => {
109
+ react_1.fireEvent.change(inputElement, { target: { value: "2025-01-19" } });
110
+ });
111
+ (0, react_2.act)(() => {
112
+ react_1.fireEvent.blur(inputElement);
113
+ });
114
+ await (0, react_1.waitFor)(() => {
115
+ expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toBe("2025-01-19");
116
+ });
84
117
  const timeButton = document.querySelector("button.zen-date-input-inner__text-input");
85
118
  expect(document.querySelector("button.zen-date-input-inner__text-input")?.textContent).toContain("00:00");
86
119
  (0, react_2.act)(() => {
@@ -103,18 +136,20 @@ describe("DateInput", () => {
103
136
  });
104
137
  await (0, react_1.waitFor)(() => {
105
138
  expect(document.querySelector("input.zen-date-input-inner__text-input")?.value).toBe("2025-01-19");
106
- expect(document.querySelector("button.zen-date-input-inner__text-input")?.textContent).toContain("18:59");
139
+ expect(document.querySelector("button.zen-date-input-inner__text-input")?.textContent).toContain("19:00");
107
140
  });
108
141
  applyButton = document.querySelector(".zen-date-input-popup__button-apply");
109
142
  expect(onChange).toHaveBeenCalledTimes(1);
110
143
  (0, react_2.act)(() => {
111
144
  react_1.fireEvent.click(applyButton);
112
145
  });
113
- expect(onChange).toHaveBeenCalledTimes(2);
114
- const lastValue = new Date("2025-01-19T23:59:00.000Z").toISOString();
115
- expect(onChange).toHaveBeenCalledWith(lastValue);
116
- expect(new Date(lastValue) < new Date(largerDate)).toBeTruthy();
117
- });
146
+ await (0, react_1.waitFor)(() => {
147
+ expect(onChange).toHaveBeenCalledTimes(2);
148
+ const lastValue = new Date("2025-01-20T00:00:00.000Z").toISOString();
149
+ expect(onChange).toHaveBeenCalledWith(lastValue);
150
+ expect(new Date(lastValue).toISOString() === new Date(largerDate).toISOString()).toBeTruthy();
151
+ });
152
+ }, 10000);
118
153
  test("custom timeZone", async () => {
119
154
  const offset = 8;
120
155
  const defaultValue = "2023-12-31T23:59:00.000Z";
@@ -137,8 +172,10 @@ describe("DateInput", () => {
137
172
  (0, react_2.act)(() => {
138
173
  react_1.fireEvent.click(triggerElement);
139
174
  });
140
- expect(document.querySelector("input.zen-date-input-inner__text-input")?.value).toBe("2024-01-01");
141
- expect(document.querySelector("button.zen-date-input-inner__text-input")?.textContent).toContain("07:59");
175
+ await (0, react_1.waitFor)(() => {
176
+ expect(document.querySelector("input.zen-date-input-inner__text-input")?.value).toBe("2024-01-01");
177
+ expect(document.querySelector("button.zen-date-input-inner__text-input")?.textContent).toContain("07:59");
178
+ });
142
179
  const day18 = document.querySelector("[data-id*='calendar-day-18']");
143
180
  (0, react_2.act)(() => {
144
181
  react_1.fireEvent.pointerDown(day18);
@@ -148,19 +185,27 @@ describe("DateInput", () => {
148
185
  (0, react_2.act)(() => {
149
186
  react_1.fireEvent.click(applyButton);
150
187
  });
151
- expect(onChange).toHaveBeenCalledTimes(1);
152
- expect(onChange).toHaveBeenCalledWith("2024-01-17T23:59:00.000Z");
188
+ await (0, react_1.waitFor)(() => {
189
+ expect(onChange).toHaveBeenCalledTimes(1);
190
+ expect(onChange).toHaveBeenCalledWith("2024-01-17T23:59:00.000Z");
191
+ });
153
192
  rerender((0, jsx_runtime_1.jsx)(userFormatProvider_1.UserFormatProvider, { toLocalDateTime: mockedToLocaleDateTime, toReverseOffsetDateTime: mockedToReverseOffsetDateTime, children: (0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", defaultValue: defaultValue, value: "2024-01-17T23:59:00.000Z", timeSelect: true, onChange: onChange }) }));
154
193
  triggerElement = container.querySelector(".zen-date-input");
155
194
  expect(triggerElement.textContent).toContain("2024-01-18 07:59");
156
195
  (0, react_2.act)(() => {
157
196
  react_1.fireEvent.click(triggerElement);
158
197
  });
159
- expect(document.querySelector("input.zen-date-input-inner__text-input")?.value).toBe("2024-01-18");
160
- expect(document.querySelector("button.zen-date-input-inner__text-input")?.textContent).toContain("07:59");
198
+ await (0, react_1.waitFor)(() => {
199
+ expect(document.querySelector("input.zen-date-input-inner__text-input")?.value).toBe("2024-01-18");
200
+ expect(document.querySelector("button.zen-date-input-inner__text-input")?.textContent).toContain("07:59");
201
+ });
161
202
  const inputElement = document.querySelector("input.zen-date-input-inner__text-input");
162
- react_1.fireEvent.change(inputElement, { target: { value: "2024-01-10" } });
163
- react_1.fireEvent.blur(inputElement);
203
+ (0, react_2.act)(() => {
204
+ react_1.fireEvent.change(inputElement, { target: { value: "2024-01-10" } });
205
+ });
206
+ (0, react_2.act)(() => {
207
+ react_1.fireEvent.blur(inputElement);
208
+ });
164
209
  const timeButton = document.querySelector("button.zen-date-input-inner__text-input");
165
210
  (0, react_2.act)(() => {
166
211
  react_1.fireEvent.click(timeButton);
@@ -176,14 +221,18 @@ describe("DateInput", () => {
176
221
  (0, react_2.act)(() => {
177
222
  react_1.fireEvent.click(timeApplyButton);
178
223
  });
179
- expect(document.querySelector("input.zen-date-input-inner__text-input")?.value).toBe("2024-01-10");
180
- expect(document.querySelector("button.zen-date-input-inner__text-input")?.textContent).toContain("07:30");
224
+ await (0, react_1.waitFor)(() => {
225
+ expect(document.querySelector("input.zen-date-input-inner__text-input")?.value).toBe("2024-01-10");
226
+ expect(document.querySelector("button.zen-date-input-inner__text-input")?.textContent).toContain("07:30");
227
+ });
181
228
  applyButton = document.querySelector(".zen-date-input-popup__button-apply");
182
229
  (0, react_2.act)(() => {
183
230
  react_1.fireEvent.click(applyButton);
184
231
  });
185
- expect(onChange).toHaveBeenCalledTimes(2);
186
- expect(onChange).toHaveBeenCalledWith("2024-01-09T23:30:00.000Z");
232
+ await (0, react_1.waitFor)(() => {
233
+ expect(onChange).toHaveBeenCalledTimes(2);
234
+ expect(onChange).toHaveBeenCalledWith("2024-01-09T23:30:00.000Z");
235
+ });
187
236
  });
188
237
  test("select new year", async () => {
189
238
  const defaultValue = "2022-01-01T12:00:00.000Z";
@@ -222,27 +271,37 @@ describe("DateInput", () => {
222
271
  (0, react_2.act)(() => {
223
272
  react_1.fireEvent.click(applyButton);
224
273
  });
225
- expect(onChange).toHaveBeenCalledTimes(1);
226
- expect(onChange).toHaveBeenCalledWith("2024-01-18T12:00:00.000Z");
274
+ await (0, react_1.waitFor)(() => {
275
+ expect(onChange).toHaveBeenCalledTimes(1);
276
+ expect(onChange).toHaveBeenCalledWith("2024-01-18T12:00:00.000Z");
277
+ });
227
278
  });
228
- test("apply button", () => {
279
+ test("apply button", async () => {
229
280
  jest.useFakeTimers().setSystemTime(new Date("2024-07-15"));
230
281
  const defaultValue = "2022-01-01";
231
282
  const onChange = jest.fn();
232
283
  const { rerender } = (0, react_1.render)((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", defaultValue: defaultValue, value: undefined, onChange: onChange }));
233
284
  const inputElement = react_1.screen.getByText("Pick a date");
234
- react_1.fireEvent.click(inputElement);
235
- expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toBe("");
285
+ (0, react_2.act)(() => {
286
+ react_1.fireEvent.click(inputElement);
287
+ });
288
+ await (0, react_1.waitFor)(() => {
289
+ expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toBe("");
290
+ });
236
291
  const day18 = document.querySelector("[data-id*='calendar-day-18']");
237
292
  (0, react_2.act)(() => {
238
293
  react_1.fireEvent.pointerDown(day18);
239
294
  });
240
- expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toContain("-18");
295
+ await (0, react_1.waitFor)(() => {
296
+ expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toContain("-18");
297
+ });
241
298
  let applyButton = document.querySelector(".zen-date-input-popup__button-apply");
242
299
  (0, react_2.act)(() => {
243
300
  react_1.fireEvent.click(applyButton);
244
301
  });
245
- expect(onChange).toHaveBeenCalled();
302
+ await (0, react_1.waitFor)(() => {
303
+ expect(onChange).toHaveBeenCalled();
304
+ });
246
305
  const timezoneOffset = new Date().getTimezoneOffset() / 60; // in hours
247
306
  const year = new Date().getFullYear();
248
307
  const month = new Date().getMonth() + 1;
@@ -251,17 +310,22 @@ describe("DateInput", () => {
251
310
  expect(onChange).toHaveBeenCalledWith(date);
252
311
  rerender((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", defaultValue: defaultValue, value: date, onChange: onChange }));
253
312
  const triggerEl = document.querySelector(".zen-date-input");
254
- react_1.fireEvent.click(triggerEl);
255
- applyButton = document.querySelector(".zen-date-input-popup__button-apply");
256
- expect(applyButton.getAttribute("disabled")).not.toBeNull();
257
- jest.clearAllTimers();
313
+ (0, react_2.act)(() => {
314
+ react_1.fireEvent.click(triggerEl);
315
+ });
316
+ await (0, react_1.waitFor)(() => {
317
+ applyButton = document.querySelector(".zen-date-input-popup__button-apply");
318
+ expect(applyButton.getAttribute("disabled")).not.toBeNull();
319
+ });
258
320
  });
259
321
  test("value not change without apply button", async () => {
260
322
  const defaultValue = "2022-01-01";
261
323
  const onChange = jest.fn();
262
324
  (0, react_1.render)((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", defaultValue: defaultValue, value: undefined, onChange: onChange }));
263
325
  const inputElement = react_1.screen.getByText("Pick a date");
264
- react_1.fireEvent.click(inputElement);
326
+ (0, react_2.act)(() => {
327
+ react_1.fireEvent.click(inputElement);
328
+ });
265
329
  await (0, react_1.waitFor)(() => {
266
330
  expect(document.querySelector(".zen-date-input-popup")).not.toBeNull();
267
331
  });
@@ -270,54 +334,70 @@ describe("DateInput", () => {
270
334
  (0, react_2.act)(() => {
271
335
  react_1.fireEvent.pointerDown(day18);
272
336
  });
273
- expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toContain("-18");
337
+ await (0, react_1.waitFor)(() => {
338
+ expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toContain("-18");
339
+ });
274
340
  (0, react_2.act)(() => {
275
341
  react_1.fireEvent.click(inputElement);
276
342
  });
277
- expect(document.querySelector(".zen-date-input-popup")).toBeNull();
278
- expect(onChange).not.toHaveBeenCalled();
343
+ await (0, react_1.waitFor)(() => {
344
+ expect(document.querySelector(".zen-date-input-popup")).toBeNull();
345
+ expect(onChange).not.toHaveBeenCalled();
346
+ });
279
347
  // it should be reset after cancel
280
- react_1.fireEvent.click(react_1.screen.getByText("Pick a date"));
281
- expect(".zen-date-input-popup").not.toBeNull();
282
- expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toContain("-18");
348
+ (0, react_2.act)(() => {
349
+ react_1.fireEvent.click(react_1.screen.getByText("Pick a date"));
350
+ });
351
+ await (0, react_1.waitFor)(() => {
352
+ expect(".zen-date-input-popup").not.toBeNull();
353
+ expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toContain("-18");
354
+ });
283
355
  });
284
- test("reset button", () => {
356
+ test("reset button", async () => {
285
357
  const defaultValue = "2022-01-01T12:00:00.000Z";
286
358
  const value = "2024-02-23T16:05:07.856Z";
287
359
  const onChange = jest.fn();
288
360
  (0, react_1.render)((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", defaultValue: defaultValue, value: value, onChange: onChange }));
289
361
  const inputElement = document.querySelector(".zen-date-input");
290
- react_1.fireEvent.click(inputElement);
291
- const resetButton = react_1.screen.getByText("Reset");
362
+ (0, react_2.act)(() => {
363
+ react_1.fireEvent.click(inputElement);
364
+ });
365
+ const clearButton = react_1.screen.getByText("Clear");
292
366
  const applyButton = react_1.screen.getByText("Apply");
293
367
  (0, react_2.act)(() => {
294
- react_1.fireEvent.click(resetButton);
368
+ react_1.fireEvent.click(clearButton);
295
369
  });
296
370
  expect(onChange).not.toHaveBeenCalled();
297
371
  (0, react_2.act)(() => {
298
372
  react_1.fireEvent.click(applyButton);
299
373
  });
300
- expect(onChange).toHaveBeenCalled();
301
- expect(onChange.mock.calls[0][0]).toContain("2022-01-01");
374
+ await (0, react_1.waitFor)(() => {
375
+ expect(onChange).toHaveBeenCalled();
376
+ expect(onChange.mock.calls[0][0]).toContain("2022-01-01");
377
+ });
302
378
  });
303
- test("clear and apply button", () => {
379
+ test("clear and apply button", async () => {
304
380
  const defaultValue = "2022-01-01T12:00:00.000Z";
305
381
  const value = "2024-02-23T16:05:07.856Z";
306
382
  const onChange = jest.fn();
307
383
  (0, react_1.render)((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", defaultValue: defaultValue, value: value, onChange: onChange }));
308
384
  const inputElement = document.querySelector(".zen-date-input");
309
- react_1.fireEvent.click(inputElement);
310
- const resetButton = react_1.screen.getByText("Reset");
311
385
  (0, react_2.act)(() => {
312
- react_1.fireEvent.click(resetButton);
386
+ react_1.fireEvent.click(inputElement);
387
+ });
388
+ const clearButton = react_1.screen.getByText("Clear");
389
+ (0, react_2.act)(() => {
390
+ react_1.fireEvent.click(clearButton);
313
391
  });
314
392
  expect(onChange).not.toHaveBeenCalled();
315
393
  const applyButton = react_1.screen.getByText("Apply");
316
394
  (0, react_2.act)(() => {
317
395
  react_1.fireEvent.click(applyButton);
318
396
  });
319
- expect(onChange).toHaveBeenCalled();
320
- expect(onChange.mock.calls[0][0]).toContain("2022-01-01");
397
+ await (0, react_1.waitFor)(() => {
398
+ expect(onChange).toHaveBeenCalled();
399
+ expect(onChange.mock.calls[0][0]).toContain("2022-01-01");
400
+ });
321
401
  });
322
402
  test("require selection", async () => {
323
403
  const defaultValue = "2022-01-01T12:00:00.000Z";
@@ -325,8 +405,12 @@ describe("DateInput", () => {
325
405
  const onChange = jest.fn();
326
406
  (0, react_1.render)((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", defaultValue: defaultValue, value: value, onChange: onChange, requireSelection: true }));
327
407
  let inputElement = document.querySelector(".zen-date-input");
328
- react_1.fireEvent.click(inputElement);
329
- expect(document.querySelector(".zen-form-field-error")).toBeNull();
408
+ (0, react_2.act)(() => {
409
+ react_1.fireEvent.click(inputElement);
410
+ });
411
+ await (0, react_1.waitFor)(() => {
412
+ expect(document.querySelector(".zen-form-field-error")).toBeNull();
413
+ });
330
414
  const day23 = document.querySelector("[data-id*='calendar-day-23']");
331
415
  (0, react_2.act)(() => {
332
416
  react_1.fireEvent.pointerDown(day23);
@@ -342,9 +426,11 @@ describe("DateInput", () => {
342
426
  react_1.fireEvent.pointerDown(day24);
343
427
  });
344
428
  applyButton = document.querySelector(".zen-date-input-popup__button-apply");
345
- expect(applyButton.getAttribute("disabled")).toBeNull();
346
- expect(document.querySelector(".zen-form-field-error")).toBeNull();
347
- expect(onChange).not.toHaveBeenCalled();
429
+ await (0, react_1.waitFor)(() => {
430
+ expect(applyButton.getAttribute("disabled")).toBeNull();
431
+ expect(document.querySelector(".zen-form-field-error")).toBeNull();
432
+ expect(onChange).not.toHaveBeenCalled();
433
+ });
348
434
  (0, react_2.act)(() => {
349
435
  react_1.fireEvent.click(applyButton);
350
436
  });
@@ -352,81 +438,109 @@ describe("DateInput", () => {
352
438
  expect(onChange).toHaveBeenCalledTimes(1);
353
439
  });
354
440
  inputElement = document.querySelector(".zen-date-input");
355
- react_1.fireEvent.click(inputElement);
356
- const resetButton = react_1.screen.getByText("Reset");
357
441
  (0, react_2.act)(() => {
358
- react_1.fireEvent.click(resetButton);
442
+ react_1.fireEvent.click(inputElement);
443
+ });
444
+ const clearButton = react_1.screen.getByText("Clear");
445
+ (0, react_2.act)(() => {
446
+ react_1.fireEvent.click(clearButton);
447
+ });
448
+ await (0, react_1.waitFor)(() => {
449
+ expect(onChange).toHaveBeenCalledTimes(1);
450
+ expect(document.querySelector(".zen-form-field-error")).toBeNull();
359
451
  });
360
- expect(onChange).toHaveBeenCalledTimes(1);
361
- expect(document.querySelector(".zen-form-field-error")).toBeNull();
362
452
  applyButton = document.querySelector(".zen-date-input-popup__button-apply");
363
453
  (0, react_2.act)(() => {
364
454
  react_1.fireEvent.click(applyButton);
365
455
  });
366
- expect(onChange).toHaveBeenCalledTimes(2);
367
- expect(onChange).toHaveBeenCalledWith("2022-01-01T12:00:00.000Z");
456
+ await (0, react_1.waitFor)(() => {
457
+ expect(onChange).toHaveBeenCalledTimes(2);
458
+ expect(onChange).toHaveBeenCalledWith("2022-01-01T12:00:00.000Z");
459
+ });
368
460
  });
369
- test("error property", () => {
370
- const { container, getByText } = (0, react_1.render)((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", value: "2024-02-23T16:05:07.856Z", onChange: jest.fn(), error: "Test error text" }));
461
+ test("error property", async () => {
462
+ const { container, getByText } = await (0, react_2.act)(() => (0, react_1.render)((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", value: "2024-02-23T16:05:07.856Z", onChange: jest.fn(), error: "Test error text" })));
371
463
  expect(container.querySelector(".zen-form-field-error")).not.toBeNull();
372
464
  expect(container.querySelector(".zen-date-input--error")).not.toBeNull();
373
465
  expect(getByText("Test error text")).not.toBeNull();
374
466
  });
375
- test("Drive class", () => {
467
+ test("Drive class", async () => {
376
468
  const { container } = (0, react_1.render)((0, jsx_runtime_1.jsx)(themeDrive_1.ThemeDrive, { children: (0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", value: "2024-02-23T16:05:07.856Z", onChange: jest.fn() }) }));
377
469
  const inputElement = container.querySelector(".zen-date-input");
378
- react_1.fireEvent.click(inputElement);
379
- expect(document.querySelector(".zen-date-input-popup")).not.toBeNull();
380
- expect(document.querySelector(".zen-date-input-inner")).not.toBeNull();
381
- expect(document.querySelector(".zen-date-input-inner--drive-tablet")).not.toBeNull();
382
- expect(document.querySelector(".zen-date-input-inner--drive")).toBeNull();
470
+ (0, react_2.act)(() => {
471
+ react_1.fireEvent.click(inputElement);
472
+ });
473
+ await (0, react_1.waitFor)(() => {
474
+ expect(document.querySelector(".zen-date-input-popup")).not.toBeNull();
475
+ expect(document.querySelector(".zen-date-input-inner")).not.toBeNull();
476
+ expect(document.querySelector(".zen-date-input-inner--drive-tablet")).not.toBeNull();
477
+ expect(document.querySelector(".zen-date-input-inner--drive")).toBeNull();
478
+ });
383
479
  });
384
- test("Drive class mobile", () => {
480
+ test("Drive class mobile", async () => {
385
481
  window.innerWidth = 639;
386
482
  const { container } = (0, react_1.render)((0, jsx_runtime_1.jsx)(themeDrive_1.ThemeDrive, { children: (0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", value: "2024-02-23T16:05:07.856Z", onChange: jest.fn() }) }));
387
483
  const inputElement = container.querySelector(".zen-date-input");
388
- react_1.fireEvent.click(inputElement);
389
- expect(document.querySelector(".zen-mobile-sheet")).not.toBeNull();
390
- expect(document.querySelector(".zen-date-input-inner")).not.toBeNull();
391
- expect(document.querySelector(".zen-date-input-inner--drive-tablet")).toBeNull();
392
- expect(document.querySelector(".zen-date-input-inner--drive")).not.toBeNull();
484
+ (0, react_2.act)(() => {
485
+ react_1.fireEvent.click(inputElement);
486
+ });
487
+ await (0, react_1.waitFor)(() => {
488
+ expect(document.querySelector(".zen-mobile-sheet")).not.toBeNull();
489
+ expect(document.querySelector(".zen-date-input-inner")).not.toBeNull();
490
+ expect(document.querySelector(".zen-date-input-inner--drive-tablet")).toBeNull();
491
+ expect(document.querySelector(".zen-date-input-inner--drive")).not.toBeNull();
492
+ });
393
493
  });
394
- test("apply class names", () => {
494
+ test("apply class names", async () => {
395
495
  const defaultValue = "2022-01-01T12:00:00.000Z";
396
496
  const value = "2024-02-23T16:05:07.856Z";
397
497
  const onChange = jest.fn();
398
498
  (0, react_1.render)((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", defaultValue: defaultValue, value: value, onChange: onChange, className: "anything", classNamePopup: "something" }));
399
499
  const inputElement = document.querySelector(".zen-date-input");
400
500
  expect(inputElement.className).toContain("anything");
401
- react_1.fireEvent.click(inputElement);
402
- const popup = document.querySelector(".zen-popup");
403
- expect(popup.className).toContain("something");
501
+ (0, react_2.act)(() => {
502
+ react_1.fireEvent.click(inputElement);
503
+ });
504
+ const popup = document.querySelector(".zen-date-input-popup");
505
+ await (0, react_1.waitFor)(() => {
506
+ expect(popup.className).toContain("something");
507
+ });
404
508
  });
405
- test("disabled", () => {
509
+ test("disabled", async () => {
406
510
  const value = "2024-02-23T16:05:07.856Z";
407
511
  const onChange = jest.fn();
408
512
  (0, react_1.render)((0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { value: value, onChange: onChange, disabled: true }));
409
513
  const inputElement = document.querySelector(".zen-date-input");
410
514
  expect(inputElement.className).toContain("zen-button--disabled");
411
- react_1.fireEvent.click(inputElement);
412
- expect(document.querySelector(".zen-popup")).toBeNull();
515
+ (0, react_2.act)(() => {
516
+ react_1.fireEvent.click(inputElement);
517
+ });
518
+ await (0, react_1.waitFor)(() => {
519
+ expect(document.querySelector(".zen-popup")).toBeNull();
520
+ });
413
521
  });
414
- test("user format", () => {
522
+ test("user format", async () => {
415
523
  const onChange = jest.fn();
416
524
  (0, react_1.render)((0, jsx_runtime_1.jsx)(userFormatProvider_1.UserFormatProvider, { weekStartsOnSunday: true, dateFormat: "yyyy/dd/MM", children: (0, jsx_runtime_1.jsx)(dateInput_1.DateInput, { id: "calendar", value: undefined, onChange: onChange }) }));
417
525
  const inputElement = react_1.screen.getByText("Pick a date");
418
- react_1.fireEvent.click(inputElement);
526
+ (0, react_2.act)(() => {
527
+ react_1.fireEvent.click(inputElement);
528
+ });
419
529
  const day18 = document.querySelector("[data-id*='calendar-day-18']");
420
530
  (0, react_2.act)(() => {
421
531
  react_1.fireEvent.pointerDown(day18);
422
532
  });
423
- expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toContain("/18/");
533
+ await (0, react_1.waitFor)(() => {
534
+ expect(document.querySelector(".zen-date-input-inner__text-input")?.value).toContain("/18/");
535
+ expect(onChange).not.toHaveBeenCalled();
536
+ });
424
537
  const applyButton = document.querySelector(".zen-date-input-popup__button-apply");
425
- expect(onChange).not.toHaveBeenCalled();
426
538
  (0, react_2.act)(() => {
427
539
  react_1.fireEvent.click(applyButton);
428
540
  });
429
- expect(onChange).toHaveBeenCalled();
541
+ await (0, react_1.waitFor)(() => {
542
+ expect(onChange).toHaveBeenCalled();
543
+ });
430
544
  });
431
545
  });
432
546
  //# sourceMappingURL=dateInput.test.js.map