@transferwise/components 46.144.1 → 46.146.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 (209) hide show
  1. package/build/calendar/Calendar.js +159 -0
  2. package/build/calendar/Calendar.js.map +1 -0
  3. package/build/{dateLookup/DateLookup.messages.js → calendar/Calendar.messages.js} +1 -1
  4. package/build/calendar/Calendar.messages.js.map +1 -0
  5. package/build/{dateLookup/DateLookup.messages.mjs → calendar/Calendar.messages.mjs} +1 -1
  6. package/build/calendar/Calendar.messages.mjs.map +1 -0
  7. package/build/calendar/Calendar.mjs +155 -0
  8. package/build/calendar/Calendar.mjs.map +1 -0
  9. package/build/{dateLookup → calendar}/dateHeader/DateHeader.js +4 -4
  10. package/build/calendar/dateHeader/DateHeader.js.map +1 -0
  11. package/build/{dateLookup → calendar}/dateHeader/DateHeader.mjs +1 -1
  12. package/build/calendar/dateHeader/DateHeader.mjs.map +1 -0
  13. package/build/{dateLookup → calendar}/dayCalendar/DayCalendar.js +2 -2
  14. package/build/calendar/dayCalendar/DayCalendar.js.map +1 -0
  15. package/build/{dateLookup → calendar}/dayCalendar/DayCalendar.mjs +1 -1
  16. package/build/calendar/dayCalendar/DayCalendar.mjs.map +1 -0
  17. package/build/calendar/dayCalendar/table/DayCalendarTable.js.map +1 -0
  18. package/build/calendar/dayCalendar/table/DayCalendarTable.mjs.map +1 -0
  19. package/build/calendar/getFocusableTime/getFocusableTime.js.map +1 -0
  20. package/build/calendar/getFocusableTime/getFocusableTime.mjs.map +1 -0
  21. package/build/calendar/getStartOfDay/getStartOfDay.js.map +1 -0
  22. package/build/calendar/getStartOfDay/getStartOfDay.mjs.map +1 -0
  23. package/build/{dateLookup → calendar}/monthCalendar/MonthCalendar.js +2 -2
  24. package/build/calendar/monthCalendar/MonthCalendar.js.map +1 -0
  25. package/build/{dateLookup → calendar}/monthCalendar/MonthCalendar.mjs +1 -1
  26. package/build/calendar/monthCalendar/MonthCalendar.mjs.map +1 -0
  27. package/build/calendar/monthCalendar/table/MonthCalendarTable.js.map +1 -0
  28. package/build/calendar/monthCalendar/table/MonthCalendarTable.mjs.map +1 -0
  29. package/build/{dateLookup → calendar}/tableLink/TableLink.js +2 -2
  30. package/build/calendar/tableLink/TableLink.js.map +1 -0
  31. package/build/{dateLookup → calendar}/tableLink/TableLink.mjs +1 -1
  32. package/build/calendar/tableLink/TableLink.mjs.map +1 -0
  33. package/build/{dateLookup → calendar}/yearCalendar/YearCalendar.js +2 -2
  34. package/build/calendar/yearCalendar/YearCalendar.js.map +1 -0
  35. package/build/{dateLookup → calendar}/yearCalendar/YearCalendar.mjs +1 -1
  36. package/build/calendar/yearCalendar/YearCalendar.mjs.map +1 -0
  37. package/build/calendar/yearCalendar/table/YearCalendarTable.js.map +1 -0
  38. package/build/calendar/yearCalendar/table/YearCalendarTable.mjs.map +1 -0
  39. package/build/dateLookup/DateLookup.js +28 -168
  40. package/build/dateLookup/DateLookup.js.map +1 -1
  41. package/build/dateLookup/DateLookup.mjs +29 -169
  42. package/build/dateLookup/DateLookup.mjs.map +1 -1
  43. package/build/index.js +2 -0
  44. package/build/index.js.map +1 -1
  45. package/build/index.mjs +1 -0
  46. package/build/index.mjs.map +1 -1
  47. package/build/main.css +624 -688
  48. package/build/prompt/InfoPrompt/InfoPrompt.js +1 -1
  49. package/build/prompt/InfoPrompt/InfoPrompt.js.map +1 -1
  50. package/build/prompt/InfoPrompt/InfoPrompt.mjs +2 -2
  51. package/build/prompt/InfoPrompt/InfoPrompt.mjs.map +1 -1
  52. package/build/sentimentSurface/SentimentSurface.js +9 -2
  53. package/build/sentimentSurface/SentimentSurface.js.map +1 -1
  54. package/build/sentimentSurface/SentimentSurface.mjs +9 -2
  55. package/build/sentimentSurface/SentimentSurface.mjs.map +1 -1
  56. package/build/styles/calendar/Calendar.css +83 -0
  57. package/build/styles/dateLookup/DateLookup.css +0 -90
  58. package/build/styles/main.css +624 -688
  59. package/build/styles/sentimentSurface/SentimentSurface.css +325 -337
  60. package/build/types/calendar/Calendar.d.ts +13 -0
  61. package/build/types/calendar/Calendar.d.ts.map +1 -0
  62. package/build/types/{dateLookup/DateLookup.messages.d.ts → calendar/Calendar.messages.d.ts} +1 -1
  63. package/build/types/calendar/Calendar.messages.d.ts.map +1 -0
  64. package/build/types/calendar/dateHeader/DateHeader.d.ts.map +1 -0
  65. package/build/types/calendar/dateHeader/index.d.ts.map +1 -0
  66. package/build/types/calendar/dayCalendar/DayCalendar.d.ts.map +1 -0
  67. package/build/types/calendar/dayCalendar/index.d.ts.map +1 -0
  68. package/build/types/calendar/dayCalendar/table/DayCalendarTable.d.ts.map +1 -0
  69. package/build/types/calendar/dayCalendar/table/index.d.ts.map +1 -0
  70. package/build/types/calendar/getFocusableTime/getFocusableTime.d.ts.map +1 -0
  71. package/build/types/calendar/getStartOfDay/getStartOfDay.d.ts.map +1 -0
  72. package/build/types/calendar/getStartOfDay/index.d.ts.map +1 -0
  73. package/build/types/calendar/index.d.ts +3 -0
  74. package/build/types/calendar/index.d.ts.map +1 -0
  75. package/build/types/{dateLookup → calendar}/monthCalendar/MonthCalendar.d.ts +1 -1
  76. package/build/types/calendar/monthCalendar/MonthCalendar.d.ts.map +1 -0
  77. package/build/types/calendar/monthCalendar/index.d.ts.map +1 -0
  78. package/build/types/{dateLookup → calendar}/monthCalendar/table/MonthCalendarTable.d.ts +1 -1
  79. package/build/types/calendar/monthCalendar/table/MonthCalendarTable.d.ts.map +1 -0
  80. package/build/types/calendar/monthCalendar/table/index.d.ts.map +1 -0
  81. package/build/types/calendar/tableLink/TableLink.d.ts.map +1 -0
  82. package/build/types/calendar/tableLink/index.d.ts.map +1 -0
  83. package/build/types/{dateLookup → calendar}/yearCalendar/YearCalendar.d.ts +1 -1
  84. package/build/types/calendar/yearCalendar/YearCalendar.d.ts.map +1 -0
  85. package/build/types/calendar/yearCalendar/index.d.ts.map +1 -0
  86. package/build/types/{dateLookup → calendar}/yearCalendar/table/YearCalendarTable.d.ts +1 -1
  87. package/build/types/calendar/yearCalendar/table/YearCalendarTable.d.ts.map +1 -0
  88. package/build/types/calendar/yearCalendar/table/index.d.ts.map +1 -0
  89. package/build/types/dateLookup/DateLookup.d.ts +2 -26
  90. package/build/types/dateLookup/DateLookup.d.ts.map +1 -1
  91. package/build/types/index.d.ts +2 -0
  92. package/build/types/index.d.ts.map +1 -1
  93. package/build/types/prompt/InfoPrompt/InfoPrompt.d.ts +3 -2
  94. package/build/types/prompt/InfoPrompt/InfoPrompt.d.ts.map +1 -1
  95. package/build/types/sentimentSurface/SentimentSurface.d.ts.map +1 -1
  96. package/package.json +2 -2
  97. package/src/calendar/Calendar.css +83 -0
  98. package/src/calendar/Calendar.less +79 -0
  99. package/src/calendar/Calendar.story.tsx +92 -0
  100. package/src/calendar/Calendar.test.tsx +138 -0
  101. package/src/calendar/Calendar.tsx +165 -0
  102. package/src/{dateLookup → calendar}/dateHeader/DateHeader.tsx +1 -1
  103. package/src/{dateLookup → calendar}/dayCalendar/DayCalendar.tsx +1 -1
  104. package/src/calendar/index.ts +2 -0
  105. package/src/{dateLookup → calendar}/monthCalendar/MonthCalendar.tsx +2 -2
  106. package/src/{dateLookup → calendar}/monthCalendar/table/MonthCalendarTable.tsx +1 -1
  107. package/src/{dateLookup → calendar}/tableLink/TableLink.tsx +1 -1
  108. package/src/{dateLookup → calendar}/yearCalendar/YearCalendar.tsx +2 -2
  109. package/src/{dateLookup → calendar}/yearCalendar/table/YearCalendarTable.tsx +1 -1
  110. package/src/criticalBanner/CriticalCommsBanner.test.tsx +1 -1
  111. package/src/dateLookup/DateLookup.css +0 -90
  112. package/src/dateLookup/DateLookup.less +0 -91
  113. package/src/dateLookup/DateLookup.test.tsx +0 -124
  114. package/src/dateLookup/DateLookup.tsx +31 -161
  115. package/src/index.ts +2 -0
  116. package/src/main.css +624 -688
  117. package/src/main.less +1 -0
  118. package/src/prompt/InfoPrompt/InfoPrompt.story.tsx +42 -0
  119. package/src/prompt/InfoPrompt/InfoPrompt.test.tsx +65 -1
  120. package/src/prompt/InfoPrompt/InfoPrompt.tsx +15 -4
  121. package/src/sentimentSurface/SentimentSurface.css +325 -337
  122. package/src/sentimentSurface/SentimentSurface.docs.mdx +2 -0
  123. package/src/sentimentSurface/SentimentSurface.less +2 -322
  124. package/src/sentimentSurface/SentimentSurface.story.tsx +4 -0
  125. package/src/sentimentSurface/SentimentSurface.test.story.tsx +1 -5
  126. package/src/sentimentSurface/SentimentSurface.test.tsx +84 -3
  127. package/src/sentimentSurface/SentimentSurface.tsx +10 -2
  128. package/build/dateLookup/DateLookup.messages.js.map +0 -1
  129. package/build/dateLookup/DateLookup.messages.mjs.map +0 -1
  130. package/build/dateLookup/dateHeader/DateHeader.js.map +0 -1
  131. package/build/dateLookup/dateHeader/DateHeader.mjs.map +0 -1
  132. package/build/dateLookup/dayCalendar/DayCalendar.js.map +0 -1
  133. package/build/dateLookup/dayCalendar/DayCalendar.mjs.map +0 -1
  134. package/build/dateLookup/dayCalendar/table/DayCalendarTable.js.map +0 -1
  135. package/build/dateLookup/dayCalendar/table/DayCalendarTable.mjs.map +0 -1
  136. package/build/dateLookup/getFocusableTime/getFocusableTime.js.map +0 -1
  137. package/build/dateLookup/getFocusableTime/getFocusableTime.mjs.map +0 -1
  138. package/build/dateLookup/getStartOfDay/getStartOfDay.js.map +0 -1
  139. package/build/dateLookup/getStartOfDay/getStartOfDay.mjs.map +0 -1
  140. package/build/dateLookup/monthCalendar/MonthCalendar.js.map +0 -1
  141. package/build/dateLookup/monthCalendar/MonthCalendar.mjs.map +0 -1
  142. package/build/dateLookup/monthCalendar/table/MonthCalendarTable.js.map +0 -1
  143. package/build/dateLookup/monthCalendar/table/MonthCalendarTable.mjs.map +0 -1
  144. package/build/dateLookup/tableLink/TableLink.js.map +0 -1
  145. package/build/dateLookup/tableLink/TableLink.mjs.map +0 -1
  146. package/build/dateLookup/yearCalendar/YearCalendar.js.map +0 -1
  147. package/build/dateLookup/yearCalendar/YearCalendar.mjs.map +0 -1
  148. package/build/dateLookup/yearCalendar/table/YearCalendarTable.js.map +0 -1
  149. package/build/dateLookup/yearCalendar/table/YearCalendarTable.mjs.map +0 -1
  150. package/build/types/dateLookup/DateLookup.messages.d.ts.map +0 -1
  151. package/build/types/dateLookup/dateHeader/DateHeader.d.ts.map +0 -1
  152. package/build/types/dateLookup/dateHeader/index.d.ts.map +0 -1
  153. package/build/types/dateLookup/dayCalendar/DayCalendar.d.ts.map +0 -1
  154. package/build/types/dateLookup/dayCalendar/index.d.ts.map +0 -1
  155. package/build/types/dateLookup/dayCalendar/table/DayCalendarTable.d.ts.map +0 -1
  156. package/build/types/dateLookup/dayCalendar/table/index.d.ts.map +0 -1
  157. package/build/types/dateLookup/getFocusableTime/getFocusableTime.d.ts.map +0 -1
  158. package/build/types/dateLookup/getStartOfDay/getStartOfDay.d.ts.map +0 -1
  159. package/build/types/dateLookup/getStartOfDay/index.d.ts.map +0 -1
  160. package/build/types/dateLookup/monthCalendar/MonthCalendar.d.ts.map +0 -1
  161. package/build/types/dateLookup/monthCalendar/index.d.ts.map +0 -1
  162. package/build/types/dateLookup/monthCalendar/table/MonthCalendarTable.d.ts.map +0 -1
  163. package/build/types/dateLookup/monthCalendar/table/index.d.ts.map +0 -1
  164. package/build/types/dateLookup/tableLink/TableLink.d.ts.map +0 -1
  165. package/build/types/dateLookup/tableLink/index.d.ts.map +0 -1
  166. package/build/types/dateLookup/yearCalendar/YearCalendar.d.ts.map +0 -1
  167. package/build/types/dateLookup/yearCalendar/index.d.ts.map +0 -1
  168. package/build/types/dateLookup/yearCalendar/table/YearCalendarTable.d.ts.map +0 -1
  169. package/build/types/dateLookup/yearCalendar/table/index.d.ts.map +0 -1
  170. /package/build/{dateLookup → calendar}/dayCalendar/table/DayCalendarTable.js +0 -0
  171. /package/build/{dateLookup → calendar}/dayCalendar/table/DayCalendarTable.mjs +0 -0
  172. /package/build/{dateLookup → calendar}/getFocusableTime/getFocusableTime.js +0 -0
  173. /package/build/{dateLookup → calendar}/getFocusableTime/getFocusableTime.mjs +0 -0
  174. /package/build/{dateLookup → calendar}/getStartOfDay/getStartOfDay.js +0 -0
  175. /package/build/{dateLookup → calendar}/getStartOfDay/getStartOfDay.mjs +0 -0
  176. /package/build/{dateLookup → calendar}/monthCalendar/table/MonthCalendarTable.js +0 -0
  177. /package/build/{dateLookup → calendar}/monthCalendar/table/MonthCalendarTable.mjs +0 -0
  178. /package/build/{dateLookup → calendar}/yearCalendar/table/YearCalendarTable.js +0 -0
  179. /package/build/{dateLookup → calendar}/yearCalendar/table/YearCalendarTable.mjs +0 -0
  180. /package/build/types/{dateLookup → calendar}/dateHeader/DateHeader.d.ts +0 -0
  181. /package/build/types/{dateLookup → calendar}/dateHeader/index.d.ts +0 -0
  182. /package/build/types/{dateLookup → calendar}/dayCalendar/DayCalendar.d.ts +0 -0
  183. /package/build/types/{dateLookup → calendar}/dayCalendar/index.d.ts +0 -0
  184. /package/build/types/{dateLookup → calendar}/dayCalendar/table/DayCalendarTable.d.ts +0 -0
  185. /package/build/types/{dateLookup → calendar}/dayCalendar/table/index.d.ts +0 -0
  186. /package/build/types/{dateLookup → calendar}/getFocusableTime/getFocusableTime.d.ts +0 -0
  187. /package/build/types/{dateLookup → calendar}/getStartOfDay/getStartOfDay.d.ts +0 -0
  188. /package/build/types/{dateLookup → calendar}/getStartOfDay/index.d.ts +0 -0
  189. /package/build/types/{dateLookup → calendar}/monthCalendar/index.d.ts +0 -0
  190. /package/build/types/{dateLookup → calendar}/monthCalendar/table/index.d.ts +0 -0
  191. /package/build/types/{dateLookup → calendar}/tableLink/TableLink.d.ts +0 -0
  192. /package/build/types/{dateLookup → calendar}/tableLink/index.d.ts +0 -0
  193. /package/build/types/{dateLookup → calendar}/yearCalendar/index.d.ts +0 -0
  194. /package/build/types/{dateLookup → calendar}/yearCalendar/table/index.d.ts +0 -0
  195. /package/src/{dateLookup/DateLookup.messages.ts → calendar/Calendar.messages.ts} +0 -0
  196. /package/src/{dateLookup → calendar}/dateHeader/index.ts +0 -0
  197. /package/src/{dateLookup → calendar}/dayCalendar/index.ts +0 -0
  198. /package/src/{dateLookup → calendar}/dayCalendar/table/DayCalendarTable.tsx +0 -0
  199. /package/src/{dateLookup → calendar}/dayCalendar/table/index.ts +0 -0
  200. /package/src/{dateLookup → calendar}/getFocusableTime/getFocusable.test.ts +0 -0
  201. /package/src/{dateLookup → calendar}/getFocusableTime/getFocusableTime.tsx +0 -0
  202. /package/src/{dateLookup → calendar}/getStartOfDay/getStartOfDay.test.js +0 -0
  203. /package/src/{dateLookup → calendar}/getStartOfDay/getStartOfDay.tsx +0 -0
  204. /package/src/{dateLookup → calendar}/getStartOfDay/index.ts +0 -0
  205. /package/src/{dateLookup → calendar}/monthCalendar/index.ts +0 -0
  206. /package/src/{dateLookup → calendar}/monthCalendar/table/index.ts +0 -0
  207. /package/src/{dateLookup → calendar}/tableLink/index.ts +0 -0
  208. /package/src/{dateLookup → calendar}/yearCalendar/index.ts +0 -0
  209. /package/src/{dateLookup → calendar}/yearCalendar/table/index.ts +0 -0
@@ -198,28 +198,6 @@ describe('DateLookup', () => {
198
198
  expect(handleChange).toHaveBeenCalledWith(initialValue);
199
199
  });
200
200
  });
201
-
202
- it('limits min value', async () => {
203
- const min = new Date(initialValue);
204
- min.setDate(min.getDate() - 1);
205
- const handleChange = jest.fn();
206
- await setupAndOpenWithMouse({ min, onChange: handleChange });
207
-
208
- await user.keyboard('{ArrowLeft}{ArrowLeft}');
209
-
210
- expect(handleChange).toHaveBeenCalledWith(min);
211
- });
212
-
213
- it('limits max value', async () => {
214
- const max = new Date(initialValue);
215
- max.setDate(max.getDate() + 1);
216
- const handleChange = jest.fn();
217
- await setupAndOpenWithMouse({ max, onChange: handleChange });
218
-
219
- await user.keyboard('{ArrowRight}{ArrowRight}');
220
-
221
- expect(handleChange).toHaveBeenCalledWith(max);
222
- });
223
201
  });
224
202
 
225
203
  describe('DateLookup propTypes', () => {
@@ -296,75 +274,6 @@ describe('DateLookup (events)', () => {
296
274
  );
297
275
  };
298
276
 
299
- it('switches to years', async () => {
300
- const view = await setup();
301
- await openDateLookup();
302
- await clickDateButton();
303
-
304
- expect(getActiveYearButton(view)).toHaveFocus();
305
-
306
- await closeDateLookup(view);
307
- });
308
-
309
- it('has aria-label for 20 years', async () => {
310
- const view = await setup();
311
- await openDateLookup();
312
- await clickDateButton();
313
-
314
- expect(getButtonByAriaLabel('next 20 years')).toBeInTheDocument();
315
- expect(getButtonByAriaLabel('previous 20 years')).toBeInTheDocument();
316
-
317
- await closeDateLookup(view);
318
- });
319
-
320
- it('switches to months', async () => {
321
- const view = await setup();
322
- await openDateLookup();
323
- await clickDateButton();
324
- await userEvent.click(getActiveYearButton(view));
325
-
326
- expect(getActiveMonthButton(view)).toHaveFocus();
327
-
328
- await closeDateLookup(view);
329
- });
330
-
331
- it('has aria label for year', async () => {
332
- const view = await setup();
333
- await openDateLookup();
334
- await clickDateButton();
335
- await userEvent.click(getActiveYearButton(view));
336
-
337
- expect(getButtonByAriaLabel('next year')).toBeInTheDocument();
338
- expect(getButtonByAriaLabel('previous year')).toBeInTheDocument();
339
-
340
- await closeDateLookup(view);
341
- });
342
-
343
- it('switches to days', async () => {
344
- const view = await setup();
345
- await openDateLookup();
346
- await clickDateButton();
347
- await userEvent.click(getActiveYearButton(view));
348
- await userEvent.click(getActiveMonthButton(view));
349
-
350
- expect(getActiveDayButton(view)).toHaveFocus();
351
-
352
- await closeDateLookup(view);
353
- });
354
-
355
- it('has aria label for month', async () => {
356
- const view = await setup();
357
- await openDateLookup();
358
- await clickDateButton();
359
- await userEvent.click(getActiveYearButton(view));
360
- await userEvent.click(getActiveMonthButton(view));
361
-
362
- expect(getButtonByAriaLabel('next month')).toBeInTheDocument();
363
- expect(getButtonByAriaLabel('previous month')).toBeInTheDocument();
364
-
365
- await closeDateLookup(view);
366
- });
367
-
368
277
  it('has aria label on selected date', async () => {
369
278
  const view = await setup();
370
279
  await openDateLookup();
@@ -440,44 +349,11 @@ describe('DateLookup (events)', () => {
440
349
  });
441
350
  };
442
351
 
443
- const getDateButton = () => {
444
- return screen.getByRole('button', {
445
- name: /Go to 20 year view/i,
446
- });
447
- };
448
-
449
352
  const openDateLookup = async () => userEvent.click(getOpenButton(labelProp));
450
353
 
451
- const clickDateButton = async () => userEvent.click(getDateButton());
452
-
453
354
  // Close dateLookup and removes events attached to documents.
454
355
  const closeDateLookup = async (view: RenderResult) => userEvent.click(view.container);
455
356
 
456
357
  // @ts-expect-error getClearButton returns node
457
358
  const clickClearButton = async (view: RenderResult) => userEvent.click(getClearButton(view));
458
-
459
- const getActiveYearButton = (view: RenderResult) => {
460
- return screen.getByRole('button', {
461
- name: /selected year/i,
462
- pressed: true,
463
- });
464
- };
465
-
466
- const getActiveMonthButton = (view: RenderResult) => {
467
- return screen.getByRole('button', {
468
- name: /selected month/i,
469
- pressed: true,
470
- });
471
- };
472
-
473
- const getActiveDayButton = (view: RenderResult) => {
474
- return screen.getByRole('button', {
475
- name: /selected day/i,
476
- pressed: true,
477
- });
478
- };
479
-
480
- const getButtonByAriaLabel = (ariaLabel: string) => {
481
- return screen.getByRole('button', { name: ariaLabel });
482
- };
483
359
  });
@@ -1,7 +1,6 @@
1
1
  import { clsx } from 'clsx';
2
2
  import { createRef, PureComponent, KeyboardEvent } from 'react';
3
- import { Breakpoint } from '@transferwise/neptune-tokens';
4
-
3
+ import Calendar from '../calendar';
5
4
  import {
6
5
  Size,
7
6
  MonthFormat,
@@ -10,15 +9,10 @@ import {
10
9
  type SizeMedium,
11
10
  type SizeLarge,
12
11
  } from '../common';
13
- import { isWithinRange, moveToWithinRange, returnDateView } from '../common/dateUtils';
14
12
  import ResponsivePanel from '../common/responsivePanel';
15
13
  import { WithInputAttributesProps, withInputAttributes } from '../inputs/contexts';
16
14
  import { OverlayIdProvider } from '../provider/overlay/OverlayIdProvider';
17
15
  import DateTrigger from './dateTrigger';
18
- import DayCalendar from './dayCalendar';
19
- import { getStartOfDay } from './getStartOfDay';
20
- import MonthCalendar from './monthCalendar';
21
- import YearCalendar from './yearCalendar';
22
16
 
23
17
  export interface DateLookupProps {
24
18
  id?: string;
@@ -40,15 +34,8 @@ export interface DateLookupProps {
40
34
  type DateLookupPropsWithInputAttributes = DateLookupProps & Partial<WithInputAttributesProps>;
41
35
 
42
36
  interface DateLookupState {
43
- selectedDate: Date | null;
44
37
  originalDate: Date | null;
45
- min: Date | null;
46
- max: Date | null;
47
- viewMonth: number;
48
- viewYear: number;
49
38
  open: boolean;
50
- mode: 'day' | 'month' | 'year';
51
- isMobile: boolean;
52
39
  }
53
40
 
54
41
  class DateLookup extends PureComponent<DateLookupPropsWithInputAttributes, DateLookupState> {
@@ -68,64 +55,25 @@ class DateLookup extends PureComponent<DateLookupPropsWithInputAttributes, DateL
68
55
  } satisfies Partial<DateLookupPropsWithInputAttributes>;
69
56
 
70
57
  element = createRef<HTMLDivElement>();
71
- dropdown = createRef<HTMLDivElement>();
72
58
 
73
59
  constructor(props: DateLookup['props']) {
74
60
  super(props);
75
- const dateView = returnDateView(props.value, props.min, props.max);
76
61
  this.state = {
77
- selectedDate: getStartOfDay(props.value),
78
62
  originalDate: null,
79
- min: getStartOfDay(props.min),
80
- max: getStartOfDay(props.max),
81
- viewMonth: dateView.getMonth(),
82
- viewYear: dateView.getFullYear(),
83
63
  open: false,
84
- mode: 'day',
85
- isMobile: false,
86
64
  };
87
65
  }
88
66
 
89
- static getDerivedStateFromProps(props: DateLookup['props'], state: DateLookupState) {
90
- const propsSelected = getStartOfDay(props.value);
91
- const propsMin = getStartOfDay(props.min);
92
- const propsMax = getStartOfDay(props.max);
93
- const hasSelectedChanged = state.selectedDate?.getTime() !== propsSelected?.getTime();
94
- const hasMinChanged = state.min?.getTime() !== propsMin?.getTime();
95
- const hasMaxChanged = state.max?.getTime() !== propsMax?.getTime();
96
- if (hasSelectedChanged || hasMinChanged || hasMaxChanged) {
97
- const selectedDate = hasSelectedChanged ? propsSelected : state.selectedDate;
98
- const min = hasMinChanged ? propsMin : state.min;
99
- const max = hasMaxChanged ? propsMax : state.max;
100
- if (selectedDate && !isWithinRange(selectedDate, min, max)) {
101
- props.onChange(moveToWithinRange(selectedDate, min, max));
102
- return null;
103
- }
104
- const viewDateThatIsWithinRange: Date = returnDateView(selectedDate, min, max);
105
- const viewMonth = viewDateThatIsWithinRange.getMonth();
106
- const viewYear = viewDateThatIsWithinRange.getFullYear();
107
- return { selectedDate, min, max, viewMonth, viewYear };
108
- }
109
- return null;
110
- }
111
-
112
67
  componentDidUpdate(previousProps: DateLookupPropsWithInputAttributes) {
113
68
  if (this.props.value?.getTime() !== previousProps.value?.getTime() && this.state.open) {
114
69
  this.focusOn('.active');
115
70
  }
116
- const mediaQuery = window.matchMedia(`(max-width: ${Breakpoint.SMALL}px)`);
117
- this.setState({ isMobile: mediaQuery.matches });
118
- }
119
-
120
- componentWillUnmount() {
121
- // Prevents memory leak by cleaning state.
122
- this.setState = () => {};
123
71
  }
124
72
 
125
73
  open = () => {
126
74
  const { onFocus } = this.props;
127
75
 
128
- this.setState({ open: true, mode: 'day' });
76
+ this.setState({ open: true });
129
77
  if (onFocus) {
130
78
  onFocus();
131
79
  }
@@ -151,36 +99,13 @@ class DateLookup extends PureComponent<DateLookupPropsWithInputAttributes, DateL
151
99
  const { open, originalDate } = this.state;
152
100
  switch (event.key) {
153
101
  case 'ArrowLeft':
154
- if (open) {
155
- this.adjustDate(-1, -1, -1);
156
- } else {
157
- this.open();
158
- }
159
- event.preventDefault();
160
- break;
161
102
  case 'ArrowUp':
162
- if (open) {
163
- this.adjustDate(-7, -4, -4);
164
- } else {
165
- this.open();
166
- }
167
- event.preventDefault();
168
- break;
169
103
  case 'ArrowRight':
170
- if (open) {
171
- this.adjustDate(1, 1, 1);
172
- } else {
173
- this.open();
174
- }
175
- event.preventDefault();
176
- break;
177
104
  case 'ArrowDown':
178
- if (open) {
179
- this.adjustDate(7, 4, 4);
180
- } else {
105
+ if (!open) {
181
106
  this.open();
107
+ event.preventDefault();
182
108
  }
183
- event.preventDefault();
184
109
  break;
185
110
  case 'Escape':
186
111
  if (originalDate !== null) {
@@ -194,27 +119,6 @@ class DateLookup extends PureComponent<DateLookupPropsWithInputAttributes, DateL
194
119
  }
195
120
  };
196
121
 
197
- adjustDate = (daysToAdd: number, monthsToAdd: number, yearsToAdd: number) => {
198
- const { selectedDate, min, max, mode, originalDate } = this.state;
199
- if (originalDate === null) {
200
- this.setState({ originalDate: selectedDate });
201
- }
202
- let date: Date | null;
203
- if (selectedDate) {
204
- date = new Date(
205
- mode === 'year' ? selectedDate.getFullYear() + yearsToAdd : selectedDate.getFullYear(),
206
- mode === 'month' ? selectedDate.getMonth() + monthsToAdd : selectedDate.getMonth(),
207
- mode === 'day' ? selectedDate.getDate() + daysToAdd : selectedDate.getDate(),
208
- );
209
- } else {
210
- date = getStartOfDay(new Date());
211
- }
212
- date &&= moveToWithinRange(date, min, max);
213
- if (date?.getTime() !== selectedDate?.getTime()) {
214
- this.props.onChange(date);
215
- }
216
- };
217
-
218
122
  focusOn = (preferredElement: string, fallbackElement?: string) => {
219
123
  const element = this.element.current?.querySelector(preferredElement) as HTMLElement | null;
220
124
  if (element) {
@@ -224,71 +128,37 @@ class DateLookup extends PureComponent<DateLookupPropsWithInputAttributes, DateL
224
128
  }
225
129
  };
226
130
 
227
- switchMode = (mode: 'day' | 'month' | 'year') => {
228
- this.setState({ mode }, () => {
229
- this.focusOn('.active', '.today');
230
- });
231
- };
232
-
233
- switchToDays = () => this.switchMode('day');
234
-
235
- switchToMonths = () => this.switchMode('month');
236
-
237
- switchToYears = () => this.switchMode('year');
238
-
239
- handleSelectedDateUpdate = (selectedDate: Date) => {
240
- this.setState({ selectedDate }, () => {
241
- this.props.onChange(selectedDate);
242
- this.close();
243
- this.focusOn('.btn');
244
- });
131
+ handleDateChange = (date: Date | null) => {
132
+ this.setState(
133
+ (state) => {
134
+ const originalDate = state.originalDate ?? this.props.value;
135
+ return { originalDate };
136
+ },
137
+ () => {
138
+ this.props.onChange(date);
139
+ },
140
+ );
245
141
  };
246
142
 
247
- handleViewDateUpdate = ({ month = this.state.viewMonth, year = this.state.viewYear }) => {
248
- this.setState({ viewMonth: month, viewYear: year });
143
+ handleDateSelect = (date: Date) => {
144
+ this.props.onChange(date);
145
+ this.close();
146
+ this.focusOn('.btn');
249
147
  };
250
148
 
251
149
  getCalendar = () => {
252
- const { selectedDate, min, max, viewMonth, viewYear, mode, isMobile } = this.state;
253
- const { placeholder, monthFormat } = this.props;
150
+ const { value, min, max, monthFormat, placeholder } = this.props;
254
151
  return (
255
- <div className={clsx({ 'p-a-1': !isMobile })}>
256
- {mode === 'day' && (
257
- <DayCalendar
258
- selectedDate={selectedDate}
259
- min={min}
260
- max={max}
261
- viewMonth={viewMonth}
262
- viewYear={viewYear}
263
- monthFormat={monthFormat}
264
- onSelect={this.handleSelectedDateUpdate}
265
- onLabelClick={this.switchToYears}
266
- onViewDateUpdate={this.handleViewDateUpdate}
267
- />
268
- )}
269
- {mode === 'month' && (
270
- <MonthCalendar
271
- selectedDate={selectedDate}
272
- min={min}
273
- max={max}
274
- viewYear={viewYear}
275
- placeholder={placeholder}
276
- onSelect={this.switchToDays}
277
- onLabelClick={this.switchToYears}
278
- onViewDateUpdate={this.handleViewDateUpdate}
279
- />
280
- )}
281
- {mode === 'year' && (
282
- <YearCalendar
283
- selectedDate={selectedDate}
284
- min={min}
285
- max={max}
286
- viewYear={viewYear}
287
- placeholder={placeholder}
288
- onSelect={this.switchToMonths}
289
- onViewDateUpdate={this.handleViewDateUpdate}
290
- />
291
- )}
152
+ <div className="p-a-1">
153
+ <Calendar
154
+ value={value}
155
+ min={min}
156
+ max={max}
157
+ monthFormat={monthFormat}
158
+ placeholder={placeholder}
159
+ onChange={this.handleDateChange}
160
+ onSelect={this.handleDateSelect}
161
+ />
292
162
  </div>
293
163
  );
294
164
  };
@@ -299,7 +169,7 @@ class DateLookup extends PureComponent<DateLookupPropsWithInputAttributes, DateL
299
169
  };
300
170
 
301
171
  render() {
302
- const { selectedDate, open } = this.state;
172
+ const { open } = this.state;
303
173
 
304
174
  const {
305
175
  inputAttributes,
@@ -329,7 +199,7 @@ class DateLookup extends PureComponent<DateLookupPropsWithInputAttributes, DateL
329
199
  <DateTrigger
330
200
  id={id}
331
201
  ariaLabelledBy={ariaLabelledBy}
332
- selectedDate={selectedDate}
202
+ selectedDate={value}
333
203
  size={size}
334
204
  placeholder={placeholder}
335
205
  label={label}
package/src/index.ts CHANGED
@@ -29,6 +29,7 @@ export type {
29
29
  export type { BottomSheetProps } from './common/bottomSheet';
30
30
  export type { DateInputProps } from './dateInput';
31
31
  export type { DateLookupProps } from './dateLookup';
32
+ export type { CalendarProps } from './calendar';
32
33
  export type { DecisionProps } from './decision/Decision';
33
34
  export type { DefinitionListProps, DefinitionListDefinition } from './definitionList';
34
35
  export type { DimmerProps } from './dimmer';
@@ -163,6 +164,7 @@ export { default as CriticalCommsBanner } from './criticalBanner';
163
164
  export type { CriticalCommsBannerProps } from './criticalBanner';
164
165
  export { default as DateInput } from './dateInput';
165
166
  export { default as DateLookup } from './dateLookup';
167
+ export { default as Calendar } from './calendar';
166
168
  export { default as Decision } from './decision';
167
169
  export { default as DefinitionList } from './definitionList';
168
170
  export { default as Dimmer } from './dimmer';