@transferwise/components 45.26.0 → 45.26.2

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 (54) hide show
  1. package/build/i18n/en.json +1 -0
  2. package/build/index.esm.js +185 -99
  3. package/build/index.esm.js.map +1 -1
  4. package/build/index.js +185 -99
  5. package/build/index.js.map +1 -1
  6. package/build/main.css +1 -1
  7. package/build/styles/dateLookup/DateLookup.css +1 -1
  8. package/build/styles/main.css +1 -1
  9. package/build/styles/typeahead/typeaheadOption/TypeaheadOption.css +1 -1
  10. package/build/types/dateLookup/DateLookup.d.ts.map +1 -1
  11. package/build/types/dateLookup/getFocusableTime/getFocusableTime.d.ts +9 -0
  12. package/build/types/dateLookup/getFocusableTime/getFocusableTime.d.ts.map +1 -0
  13. package/build/types/dateLookup/monthCalendar/table/MonthCalendarTable.d.ts +1 -1
  14. package/build/types/dateLookup/monthCalendar/table/MonthCalendarTable.d.ts.map +1 -1
  15. package/build/types/dateLookup/tableLink/TableLink.d.ts +14 -4
  16. package/build/types/dateLookup/tableLink/TableLink.d.ts.map +1 -1
  17. package/build/types/dateLookup/tableLink/index.d.ts +1 -1
  18. package/build/types/dateLookup/tableLink/index.d.ts.map +1 -1
  19. package/build/types/dateLookup/yearCalendar/table/YearCalendarTable.d.ts.map +1 -1
  20. package/build/types/info/Info.d.ts +1 -1
  21. package/build/types/info/Info.d.ts.map +1 -1
  22. package/build/types/info/Info.messages.d.ts +8 -0
  23. package/build/types/info/Info.messages.d.ts.map +1 -0
  24. package/build/types/summary/Summary.d.ts.map +1 -1
  25. package/package.json +1 -1
  26. package/src/dateLookup/DateLookup.css +1 -1
  27. package/src/dateLookup/DateLookup.js +19 -4
  28. package/src/dateLookup/DateLookup.keyboardEvents.spec.js +12 -0
  29. package/src/dateLookup/DateLookup.less +39 -49
  30. package/src/dateLookup/DateLookup.story.js +8 -7
  31. package/src/dateLookup/dayCalendar/table/DayCalendarTable.js +28 -3
  32. package/src/dateLookup/dayCalendar/table/DayCalendarTable.spec.js +25 -0
  33. package/src/dateLookup/getFocusableTime/getFocusable.spec.ts +40 -0
  34. package/src/dateLookup/getFocusableTime/getFocusableTime.tsx +14 -0
  35. package/src/dateLookup/monthCalendar/table/MonthCalendarTable.js +33 -20
  36. package/src/dateLookup/monthCalendar/table/MonthCalendarTable.spec.js +33 -0
  37. package/src/dateLookup/tableLink/TableLink.spec.js +6 -15
  38. package/src/dateLookup/tableLink/TableLink.tsx +79 -0
  39. package/src/dateLookup/yearCalendar/table/YearCalendarTable.js +33 -11
  40. package/src/dateLookup/yearCalendar/table/YearCalendarTable.spec.js +26 -0
  41. package/src/i18n/en.json +1 -0
  42. package/src/info/Info.messages.ts +8 -0
  43. package/src/info/Info.spec.js +10 -4
  44. package/src/info/Info.tsx +5 -2
  45. package/src/main.css +1 -1
  46. package/src/popover/Popover.js +1 -1
  47. package/src/popover/__snapshots__/Popover.spec.js.snap +2 -2
  48. package/src/summary/Summary.tsx +0 -1
  49. package/src/typeahead/Typeahead.story.js +6 -0
  50. package/src/typeahead/typeaheadOption/TypeaheadOption.css +1 -1
  51. package/src/typeahead/typeaheadOption/TypeaheadOption.js +1 -1
  52. package/src/typeahead/typeaheadOption/TypeaheadOption.less +2 -1
  53. package/src/dateLookup/tableLink/TableLink.js +0 -70
  54. /package/src/dateLookup/tableLink/{index.js → index.ts} +0 -0
@@ -1 +1 @@
1
- .typeahead__option.tw-dropdown-item .dropdown-item:active strong{color:#fff}.typeahead__option.tw-dropdown-item--focused{background-color:#86a7bd1a;background-color:var(--color-background-neutral)}
1
+ .typeahead__option.tw-dropdown-item .dropdown-item:active strong{color:#fff}.typeahead__option.tw-dropdown-item--focused{border-radius:10px;border-radius:var(--radius-small);box-shadow:inset 0 0 0 1px #c9cbce;box-shadow:inset 0 0 0 1px var(--color-interactive-secondary)}
@@ -1 +1 @@
1
- {"version":3,"file":"DateLookup.d.ts","sourceRoot":"","sources":["../../../src/dateLookup/DateLookup.js"],"names":[],"mappings":";AAqBA;IAmBE;;;;;;aAqBC;IAnCD,wBAYC;IAhBD,wCAAsB;IAEtB,yCAAuB;IAIrB;;;;;;;;;MASC;IA0BH,6CAMC;IAFC,uCAAyE;IAI3E,6BAGC;IAED,iBAOE;IAEF,kBAME;IAEF,oCA0CE;IAEF,wEAgBE;IAEF,+DAOE;IAEF,gCAIE;IAEF,yBAA+C;IAE/C,2BAAmD;IAEnD,0BAAiD;IAEjD,sDAME;IAEF;;;eAEE;IAEF,+CA8BE;IAEF,wBAGE;IAEF,sCA0BC;CACF"}
1
+ {"version":3,"file":"DateLookup.d.ts","sourceRoot":"","sources":["../../../src/dateLookup/DateLookup.js"],"names":[],"mappings":";AAqBA;IAoBE;;;;;;aAqBC;IApCD,wBAaC;IAjBD,wCAAsB;IAEtB,yCAAuB;IAIrB;;;;;;;;;;MAUC;IA0BH,6CAMC;IAFC,uCAAyE;IAI3E,6BAGC;IAED,iBAOE;IAEF,oBAME;IAEF,kBAME;IAEF,oCA6CE;IAEF,wEAmBE;IAEF,+DAOE;IAEF,gCAIE;IAEF,yBAA+C;IAE/C,2BAAmD;IAEnD,0BAAiD;IAEjD,sDAME;IAEF;;;eAEE;IAEF,+CA8BE;IAEF,wBAGE;IAEF,sCA0BC;CACF"}
@@ -0,0 +1,9 @@
1
+ interface FocusableTimeProps {
2
+ isActive: (time: number) => boolean;
3
+ isNow: (time: number) => boolean;
4
+ isDisabled: (time: number) => boolean;
5
+ timeSpan: number[];
6
+ }
7
+ export declare function getFocusableTime(props: FocusableTimeProps): number | undefined;
8
+ export {};
9
+ //# sourceMappingURL=getFocusableTime.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"getFocusableTime.d.ts","sourceRoot":"","sources":["../../../../src/dateLookup/getFocusableTime/getFocusableTime.tsx"],"names":[],"mappings":"AAAA,UAAU,kBAAkB;IAC1B,QAAQ,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC;IACpC,KAAK,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC;IACjC,UAAU,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,OAAO,CAAC;IACtC,QAAQ,EAAE,MAAM,EAAE,CAAC;CACpB;AAED,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,kBAAkB,GAAG,MAAM,GAAG,SAAS,CAM9E"}
@@ -1,5 +1,5 @@
1
1
  export default MonthCalendarTable;
2
- declare function MonthCalendarTable({ selectedDate: selected, min, max, viewYear, placeholder, onSelect, }: {
2
+ declare function MonthCalendarTable({ selectedDate, min, max, viewYear, placeholder, onSelect }: {
3
3
  selectedDate: any;
4
4
  min: any;
5
5
  max: any;
@@ -1 +1 @@
1
- {"version":3,"file":"MonthCalendarTable.d.ts","sourceRoot":"","sources":["../../../../../src/dateLookup/monthCalendar/table/MonthCalendarTable.js"],"names":[],"mappings":";AAUA;;;;;;;gCAgDC"}
1
+ {"version":3,"file":"MonthCalendarTable.d.ts","sourceRoot":"","sources":["../../../../../src/dateLookup/monthCalendar/table/MonthCalendarTable.js"],"names":[],"mappings":";AAWA;;;;;;;gCA4DC"}
@@ -1,5 +1,15 @@
1
- declare const _default: import("react").FC<import("react-intl").WithIntlProps<any>> & {
2
- WrappedComponent: import("react").ComponentType<any>;
3
- };
4
- export default _default;
1
+ /// <reference types="react" />
2
+ interface TableLinkProps {
3
+ item: number;
4
+ type: 'day' | 'month' | 'year';
5
+ title?: string;
6
+ longTitle?: string;
7
+ active: boolean;
8
+ disabled: boolean;
9
+ today: boolean;
10
+ autofocus?: boolean;
11
+ onClick: (item: number) => void;
12
+ }
13
+ declare const TableLink: ({ item, type, title, longTitle, active, disabled, today, autofocus, onClick, }: TableLinkProps) => import("react").JSX.Element;
14
+ export default TableLink;
5
15
  //# sourceMappingURL=TableLink.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"TableLink.d.ts","sourceRoot":"","sources":["../../../../src/dateLookup/tableLink/TableLink.js"],"names":[],"mappings":""}
1
+ {"version":3,"file":"TableLink.d.ts","sourceRoot":"","sources":["../../../../src/dateLookup/tableLink/TableLink.tsx"],"names":[],"mappings":";AAMA,UAAU,cAAc;IACtB,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,KAAK,GAAG,OAAO,GAAG,MAAM,CAAC;IAC/B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,EAAE,OAAO,CAAC;IAChB,QAAQ,EAAE,OAAO,CAAC;IAClB,KAAK,EAAE,OAAO,CAAC;IACf,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,OAAO,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;CACjC;AAED,QAAA,MAAM,SAAS,mFAUZ,cAAc,gCAgDhB,CAAC;AAEF,eAAe,SAAS,CAAC"}
@@ -1,2 +1,2 @@
1
- export { default } from "./TableLink";
1
+ export { default } from './TableLink';
2
2
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/dateLookup/tableLink/index.js"],"names":[],"mappings":""}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../../src/dateLookup/tableLink/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,aAAa,CAAC"}
@@ -1 +1 @@
1
- {"version":3,"file":"YearCalendarTable.d.ts","sourceRoot":"","sources":["../../../../../src/dateLookup/yearCalendar/table/YearCalendarTable.js"],"names":[],"mappings":";AAUA;;;;;;;gCAkCC"}
1
+ {"version":3,"file":"YearCalendarTable.d.ts","sourceRoot":"","sources":["../../../../../src/dateLookup/yearCalendar/table/YearCalendarTable.js"],"names":[],"mappings":";AAWA;;;;;;;gCAuDC"}
@@ -1,7 +1,7 @@
1
1
  /// <reference types="react" />
2
2
  import { Position, SizeSmall, SizeLarge } from '../common';
3
3
  export interface Props {
4
- 'aria-label': string;
4
+ 'aria-label'?: string;
5
5
  /**
6
6
  * Extra classes applied to Info
7
7
  */
@@ -1 +1 @@
1
- {"version":3,"file":"Info.d.ts","sourceRoot":"","sources":["../../../src/info/Info.tsx"],"names":[],"mappings":";AAIA,OAAO,EAAQ,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAMjE,MAAM,WAAW,KAAK;IACpB,YAAY,EAAE,MAAM,CAAC;IACrB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;OAEG;IACH,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB;;OAEG;IACH,YAAY,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IACnC;;OAEG;IACH,IAAI,CAAC,EAAE,SAAS,GAAG,SAAS,CAAC;IAC7B;;OAEG;IACH,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB;;OAEG;IACH,kBAAkB,CAAC,EAAE,QAAQ,CAAC;CAC/B;AAED,QAAA,MAAM,IAAI,6GASP,KAAK,gCAgDP,CAAC;AAEF,eAAe,IAAI,CAAC"}
1
+ {"version":3,"file":"Info.d.ts","sourceRoot":"","sources":["../../../src/info/Info.tsx"],"names":[],"mappings":";AAKA,OAAO,EAAQ,QAAQ,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,WAAW,CAAC;AAOjE,MAAM,WAAW,KAAK;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;OAEG;IACH,OAAO,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB;;OAEG;IACH,YAAY,CAAC,EAAE,OAAO,GAAG,SAAS,CAAC;IACnC;;OAEG;IACH,IAAI,CAAC,EAAE,SAAS,GAAG,SAAS,CAAC;IAC7B;;OAEG;IACH,KAAK,CAAC,EAAE,KAAK,CAAC,SAAS,CAAC;IACxB;;OAEG;IACH,kBAAkB,CAAC,EAAE,QAAQ,CAAC;CAC/B;AAED,QAAA,MAAM,IAAI,6GASP,KAAK,gCAiDP,CAAC;AAEF,eAAe,IAAI,CAAC"}
@@ -0,0 +1,8 @@
1
+ declare const _default: {
2
+ ariaLabel: {
3
+ id: string;
4
+ defaultMessage: string;
5
+ };
6
+ };
7
+ export default _default;
8
+ //# sourceMappingURL=Info.messages.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Info.messages.d.ts","sourceRoot":"","sources":["../../../src/info/Info.messages.ts"],"names":[],"mappings":";;;;;;AAEA,wBAKG"}
@@ -1 +1 @@
1
- {"version":3,"file":"Summary.d.ts","sourceRoot":"","sources":["../../../src/summary/Summary.tsx"],"names":[],"mappings":"AAMA,OAAO,EAAE,WAAW,EAAgB,SAAS,EAAE,MAAM,OAAO,CAAC;AAI7D,OAAO,EAEL,UAAU,EACV,aAAa,EACb,aAAa,EAId,MAAM,WAAW,CAAC;AACnB,OAAa,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAC1C,OAAa,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAqB1C,MAAM,WAAW,KAAK;IACpB;;OAEG;IACH,MAAM,CAAC,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM,GAAG,YAAY,GAAG,QAAQ,GAAG,SAAS,CAAC,GAAG;QACvE,IAAI,EAAE,SAAS,CAAC;KACjB,CAAC;IACF;;OAEG;IACH,EAAE,CAAC,EAAE,WAAW,CAAC;IACjB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;OAEG;IACH,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB;;OAEG;IACH,WAAW,CAAC,EAAE,SAAS,CAAC;IACxB;;OAEG;IACH,IAAI,CAAC,EAAE;QACL,OAAO,EAAE,SAAS,CAAC;QACnB,KAAK,CAAC,EAAE,SAAS,CAAC;KACnB,CAAC;IACF;;OAEG;IACH,IAAI,CAAC,EAAE,IAAI,CAAC,SAAS,EAAE,YAAY,GAAG,SAAS,GAAG,SAAS,GAAG,cAAc,GAAG,OAAO,CAAC,CAAC;IACxF;;OAEG;IACH,YAAY,CAAC,EAAE,SAAS,CAAC;IACzB;;OAEG;IACH,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB;;OAEG;IACH,MAAM,CAAC,EAAE,aAAa,GAAG,UAAU,GAAG,aAAa,CAAC;IACpD;;OAEG;IACH,KAAK,EAAE,SAAS,CAAC;CAClB;AAED,QAAA,MAAM,OAAO,6GAaV,KAAK,gCAoFP,CAAC;AAEF,eAAe,OAAO,CAAC"}
1
+ {"version":3,"file":"Summary.d.ts","sourceRoot":"","sources":["../../../src/summary/Summary.tsx"],"names":[],"mappings":"AAMA,OAAO,EAAE,WAAW,EAAgB,SAAS,EAAE,MAAM,OAAO,CAAC;AAI7D,OAAO,EAEL,UAAU,EACV,aAAa,EACb,aAAa,EAId,MAAM,WAAW,CAAC;AACnB,OAAa,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAC1C,OAAa,EAAE,SAAS,EAAE,MAAM,SAAS,CAAC;AAqB1C,MAAM,WAAW,KAAK;IACpB;;OAEG;IACH,MAAM,CAAC,EAAE,IAAI,CAAC,SAAS,EAAE,MAAM,GAAG,YAAY,GAAG,QAAQ,GAAG,SAAS,CAAC,GAAG;QACvE,IAAI,EAAE,SAAS,CAAC;KACjB,CAAC;IACF;;OAEG;IACH,EAAE,CAAC,EAAE,WAAW,CAAC;IACjB;;OAEG;IACH,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB;;OAEG;IACH,OAAO,CAAC,EAAE,SAAS,CAAC;IACpB;;OAEG;IACH,WAAW,CAAC,EAAE,SAAS,CAAC;IACxB;;OAEG;IACH,IAAI,CAAC,EAAE;QACL,OAAO,EAAE,SAAS,CAAC;QACnB,KAAK,CAAC,EAAE,SAAS,CAAC;KACnB,CAAC;IACF;;OAEG;IACH,IAAI,CAAC,EAAE,IAAI,CAAC,SAAS,EAAE,YAAY,GAAG,SAAS,GAAG,SAAS,GAAG,cAAc,GAAG,OAAO,CAAC,CAAC;IACxF;;OAEG;IACH,YAAY,CAAC,EAAE,SAAS,CAAC;IACzB;;OAEG;IACH,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB;;OAEG;IACH,MAAM,CAAC,EAAE,aAAa,GAAG,UAAU,GAAG,aAAa,CAAC;IACpD;;OAEG;IACH,KAAK,EAAE,SAAS,CAAC;CAClB;AAED,QAAA,MAAM,OAAO,6GAYV,KAAK,gCAoFP,CAAC;AAEF,eAAe,OAAO,CAAC"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@transferwise/components",
3
- "version": "45.26.0",
3
+ "version": "45.26.2",
4
4
  "description": "Neptune React components",
5
5
  "license": "Apache-2.0",
6
6
  "repository": {
@@ -1 +1 @@
1
- .tw-date-lookup-menu{width:400px}.tw-date-lookup-calendar{min-width:300px;table-layout:fixed;text-align:center}.tw-date-lookup-calendar>tbody>tr>td{padding:4px;padding:var(--size-4)}@media (max-width:320px){.tw-date-lookup-calendar>tbody>tr>td{padding:0}}.tw-date-lookup-calendar>tbody>tr>td button{background-color:transparent;border:transparent;border-radius:10px;border-radius:var(--radius-small);color:#0097c7;color:var(--color-content-accent);font-weight:600;font-weight:var(--font-weight-semi-bold);padding:4px 0;padding:var(--size-4) 0;width:100%}@media (max-width:320px){.tw-date-lookup-calendar>tbody>tr>td button{padding:0}}.tw-date-lookup-calendar>tbody>tr>td button:not(.disabled,:disabled).active{background-color:#0081ba;background-color:var(--color-interactive-accent-active);color:#fff}.tw-date-lookup-calendar>tbody>tr>td button:not(.disabled,:disabled):hover{background-color:#008fc9;background-color:var(--color-interactive-accent-hover);color:#fff}.np-theme-personal .tw-date-lookup-calendar>tbody>tr>td button{color:#37517e;color:var(--color-content-primary)}.np-theme-personal .tw-date-lookup-calendar>tbody>tr>td button:not(.disabled,:disabled).active,.np-theme-personal .tw-date-lookup-calendar>tbody>tr>td button:not(.disabled,:disabled):hover{color:var(--color-interactive-control)}.np-theme-personal .tw-date-lookup-calendar>tbody>tr>td:nth-child(7n+6) button,.np-theme-personal .tw-date-lookup-calendar>tbody>tr>td:nth-child(7n+7) button,.np-theme-personal .tw-date-lookup-calendar>thead>tr>th:nth-child(7n+6),.np-theme-personal .tw-date-lookup-calendar>thead>tr>th:nth-child(7n+7){color:#5d7079;color:var(--color-content-secondary);font-weight:400;font-weight:var(--font-weight-regular)}.tw-date-lookup-calendar abbr{text-decoration:none}.np-theme-personal .tw-date-lookup-calendar{background-color:inherit}.np-theme-personal .tw-date-lookup-menu .table-bordered,.np-theme-personal.tw-date-lookup-menu .table-bordered{border:none}.np-theme-personal .tw-date-lookup-menu thead,.np-theme-personal.tw-date-lookup-menu thead{background-color:unset}.np-theme-personal .tw-date-lookup-menu td,.np-theme-personal.tw-date-lookup-menu td{border:none}.np-theme-personal .tw-date-lookup-menu .tw-date-lookup-header-current-container,.np-theme-personal.tw-date-lookup-menu .tw-date-lookup-header-current-container{display:inline-block}.np-theme-personal .tw-date-lookup-menu .tw-date-lookup-header-current-container .tw-date-lookup-header-current,.np-theme-personal.tw-date-lookup-menu .tw-date-lookup-header-current-container .tw-date-lookup-header-current{color:#37517e;color:var(--color-content-primary)}.np-theme-personal .tw-date-lookup-menu .tw-date-lookup-day-option,.np-theme-personal.tw-date-lookup-menu .tw-date-lookup-day-option{align-items:center;color:#37517e;color:var(--color-content-primary);display:inline-flex;height:32px;height:var(--size-32);justify-content:center;line-height:32px;line-height:var(--size-32)}.np-theme-personal .tw-date-lookup-menu .tw-date-lookup-day-option.active,.np-theme-personal.tw-date-lookup-menu .tw-date-lookup-day-option.active{background-color:#00a2dd;background-color:var(--color-interactive-accent);color:var(--color-interactive-primary)}
1
+ .tw-date-lookup-menu{width:400px}.tw-date-lookup-calendar{background-color:inherit;min-width:300px;table-layout:fixed;text-align:center}.tw-date-lookup-calendar>tbody>tr>td.weekend button{color:#5d7079;color:var(--color-content-secondary)}.tw-date-lookup-calendar>tbody>tr>td{padding:4px;padding:var(--size-4)}@media (max-width:320px){.tw-date-lookup-calendar>tbody>tr>td{padding:0}}.tw-date-lookup-calendar>tbody>tr>td:has(.tw-date-lookup-day-option){padding:1px}.tw-date-lookup-calendar>tbody>tr>td button{background-color:transparent;border:transparent;border-radius:10px;border-radius:var(--radius-small);color:#0097c7;color:var(--color-content-accent);color:#37517e;color:var(--color-content-primary);font-weight:600;font-weight:var(--font-weight-semi-bold);padding:4px 0;padding:var(--size-4) 0;width:100%}@media (max-width:320px){.tw-date-lookup-calendar>tbody>tr>td button{padding:0}}.tw-date-lookup-calendar>tbody>tr>td button.tw-date-lookup-day-option{align-items:center;border-radius:9999px;border-radius:var(--radius-full);display:inline-flex;height:40px;height:var(--size-40);justify-content:center;line-height:40px;line-height:var(--size-40);padding:0;width:40px;width:var(--size-40)}.tw-date-lookup-calendar>tbody>tr>td button.tw-date-lookup-day-option.today{text-decoration:underline;text-decoration-thickness:2px;text-underline-offset:4px}.tw-date-lookup-calendar>tbody>tr>td:hover button:not(.disabled,:disabled),.tw-date-lookup-calendar>tbody>tr>td:not(.disabled,:disabled) button.show-focus{background-color:var(--color-background-screen-hover)}.tw-date-lookup-calendar>tbody>tr>td:not(.disabled,:disabled) button.active{background-color:var(--color-interactive-primary);color:var(--color-interactive-contrast)}.tw-date-lookup-calendar abbr{text-decoration:none}.tw-date-lookup-header-current-container{display:inline}.np-theme-personal .tw-date-lookup-menu .table-bordered,.np-theme-personal.tw-date-lookup-menu .table-bordered{border:none}.np-theme-personal .tw-date-lookup-menu thead,.np-theme-personal.tw-date-lookup-menu thead{background-color:unset}.np-theme-personal .tw-date-lookup-menu td,.np-theme-personal.tw-date-lookup-menu td{border:none}.np-theme-personal .tw-date-lookup-menu .tw-date-lookup-header-current,.np-theme-personal.tw-date-lookup-menu .tw-date-lookup-header-current{color:#37517e;color:var(--color-content-primary)}
@@ -28,6 +28,7 @@ class DateLookup extends PureComponent {
28
28
  super(props);
29
29
  this.state = {
30
30
  selectedDate: getStartOfDay(props.value),
31
+ originalDate: null,
31
32
  min: getStartOfDay(props.min),
32
33
  max: getStartOfDay(props.max),
33
34
  viewMonth: (props.value || new Date()).getMonth(),
@@ -83,16 +84,24 @@ class DateLookup extends PureComponent {
83
84
  }
84
85
  };
85
86
 
87
+ discard = () => {
88
+ const { originalDate } = this.state;
89
+ if (originalDate !== null) {
90
+ this.props.onChange(originalDate);
91
+ }
92
+ this.close();
93
+ };
94
+
86
95
  close = () => {
87
96
  const { onBlur } = this.props;
88
- this.setState({ open: false });
97
+ this.setState({ open: false, originalDate: null });
89
98
  if (onBlur) {
90
99
  onBlur();
91
100
  }
92
101
  };
93
102
 
94
103
  handleKeyDown = (event) => {
95
- const { open } = this.state;
104
+ const { open, originalDate } = this.state;
96
105
  switch (event.keyCode) {
97
106
  case KeyCodes.LEFT:
98
107
  if (open) {
@@ -127,6 +136,9 @@ class DateLookup extends PureComponent {
127
136
  event.preventDefault();
128
137
  break;
129
138
  case KeyCodes.ESCAPE:
139
+ if (originalDate !== null) {
140
+ this.props.onChange(originalDate);
141
+ }
130
142
  this.close();
131
143
  event.preventDefault();
132
144
  break;
@@ -136,7 +148,10 @@ class DateLookup extends PureComponent {
136
148
  };
137
149
 
138
150
  adjustDate = (daysToAdd, monthsToAdd, yearsToAdd) => {
139
- const { selectedDate, min, max, mode } = this.state;
151
+ const { selectedDate, min, max, mode, originalDate } = this.state;
152
+ if (originalDate === null) {
153
+ this.setState({ originalDate: selectedDate });
154
+ }
140
155
  let date;
141
156
  if (selectedDate) {
142
157
  date = new Date(
@@ -243,7 +258,7 @@ class DateLookup extends PureComponent {
243
258
  open={open}
244
259
  className="tw-date-lookup-menu"
245
260
  position={Position.BOTTOM}
246
- onClose={this.close}
261
+ onClose={this.discard}
247
262
  >
248
263
  {this.getCalendar()}
249
264
  </ResponsivePanel>
@@ -80,6 +80,18 @@ describe('DateLookup (keyboard events)', () => {
80
80
  pressKey(KEY_CODES.DOWN);
81
81
  onChangeCalledWith(new Date(2019, 0, 3));
82
82
  });
83
+
84
+ it('resets to original date when escape key is pressed', () => {
85
+ pressKey(KEY_CODES.LEFT);
86
+ pressKey(KEY_CODES.ESCAPE);
87
+ onChangeCalledWith(date);
88
+ });
89
+
90
+ it('resets to original date when clicking outside modal', () => {
91
+ pressKey(KEY_CODES.LEFT);
92
+ component.find('.dimmer').simulate('click');
93
+ onChangeCalledWith(date);
94
+ });
83
95
  });
84
96
 
85
97
  describe('when open and in month mode', () => {
@@ -9,12 +9,21 @@
9
9
  text-align: center;
10
10
  table-layout: fixed;
11
11
 
12
+ > tbody > tr > td.weekend button {
13
+ color: var(--color-content-secondary);
14
+ &:extend(.np-text-body-default);
15
+ }
16
+
12
17
  > tbody > tr > td {
13
18
  padding: var(--size-4);
14
19
  @media (--screen-400-zoom) {
15
20
  padding: 0;
16
21
  }
17
22
 
23
+ &:has(.tw-date-lookup-day-option) {
24
+ padding: 1px;
25
+ }
26
+
18
27
  button {
19
28
  width: 100%;
20
29
  padding: var(--size-4) 0;
@@ -26,37 +35,34 @@
26
35
  border-radius: var(--radius-small);
27
36
  background-color: transparent;
28
37
  font-weight: var(--font-weight-semi-bold);
38
+ color: var(--color-content-primary);
29
39
 
30
- &:not(.disabled, :disabled).active {
31
- color: #fff;
32
- background-color: var(--color-interactive-accent-active);
33
- }
34
-
35
- &:not(.disabled, :disabled):hover {
36
- color: #fff;
37
- background-color: var(--color-interactive-accent-hover);
38
- }
39
-
40
- .np-theme-personal & {
41
- color: var(--color-content-primary);
42
-
43
- &:not(.disabled, :disabled).active {
44
- color: var(--color-interactive-control);
45
- }
46
-
47
- &:not(.disabled, :disabled):hover {
48
- color: var(--color-interactive-control);
40
+ &.tw-date-lookup-day-option {
41
+ height: var(--size-40);
42
+ border-radius: var(--radius-full);
43
+ line-height: var(--size-40);
44
+ width: var(--size-40);
45
+ padding: 0;
46
+ display: inline-flex;
47
+ align-items: center;
48
+ justify-content: center;
49
+
50
+ &.today {
51
+ text-decoration: underline;
52
+ text-decoration-thickness: 2px;
53
+ text-underline-offset: 4px;
49
54
  }
50
55
  }
51
56
  }
52
- }
53
- > thead > tr > th:nth-child(7n+6),
54
- > thead > tr > th:nth-child(7n+7),
55
- > tbody > tr > td:nth-child(7n+6) button,
56
- > tbody > tr > td:nth-child(7n+7) button {
57
- .np-theme-personal & {
58
- color: var(--color-content-secondary);
59
- font-weight: var(--font-weight-regular);
57
+
58
+ &:not(.disabled, :disabled) button.show-focus,
59
+ &:hover button:not(.disabled, :disabled) {
60
+ background-color: var(--color-background-screen-hover);
61
+ }
62
+
63
+ &:not(.disabled, :disabled) button.active {
64
+ background-color: var(--color-interactive-primary);
65
+ color: var(--color-interactive-contrast);
60
66
  }
61
67
  }
62
68
 
@@ -64,9 +70,11 @@
64
70
  text-decoration: none;
65
71
  }
66
72
 
67
- .np-theme-personal & {
68
- background-color: inherit;
69
- }
73
+ background-color: inherit;
74
+ }
75
+
76
+ .tw-date-lookup-header-current-container {
77
+ display: inline;
70
78
  }
71
79
 
72
80
  .np-theme-personal {
@@ -83,27 +91,9 @@
83
91
  td {
84
92
  border: none;
85
93
  }
86
-
87
- .tw-date-lookup-header-current-container {
88
- display: inline-block;
89
-
90
- .tw-date-lookup-header-current {
91
- color: var(--color-content-primary);
92
- }
93
- }
94
94
 
95
- .tw-date-lookup-day-option {
96
- height: var(--size-32);
97
- line-height: var(--size-32);
98
- display: inline-flex;
99
- align-items: center;
100
- justify-content: center;
95
+ .tw-date-lookup-header-current {
101
96
  color: var(--color-content-primary);
102
97
  }
103
-
104
- .tw-date-lookup-day-option.active {
105
- background-color: var(--color-interactive-accent);
106
- color: var(--color-interactive-primary);
107
- }
108
98
  }
109
99
  }
@@ -13,6 +13,8 @@ export default {
13
13
 
14
14
  let theFuture = new Date();
15
15
  theFuture.setDate(theFuture.getDate() + 10);
16
+ let thePast = new Date();
17
+ thePast.setDate(thePast.getDate() - 10);
16
18
 
17
19
  export const Basic = () => {
18
20
  const [value, setValue] = useState(null);
@@ -22,16 +24,13 @@ export const Basic = () => {
22
24
  const placeholder = text('placeholder', 'placeholder');
23
25
  const size = select('size', Object.values(Size), Size.MEDIUM);
24
26
 
25
- const minvalue = date('minvalue', new Date());
26
- const maxvalue = date('maxvalue', theFuture);
27
27
  const clearable = boolean('clearable', false);
28
28
 
29
29
  return (
30
30
  <DateLookup
31
31
  disabled={disabled}
32
32
  label={label}
33
- max={new Date(maxvalue)}
34
- min={new Date(minvalue)}
33
+ min={thePast}
35
34
  monthFormat={monthFormat}
36
35
  placeholder={placeholder}
37
36
  size={size}
@@ -42,9 +41,11 @@ export const Basic = () => {
42
41
  );
43
42
  };
44
43
 
45
- Basic.play = ({ canvasElement }) => {
44
+ Basic.play = async ({ canvasElement }) => {
45
+ // testing focus state on keyboard nav
46
46
  const canvas = within(canvasElement);
47
- userEvent.click(canvas.getByRole('button'));
47
+ userEvent.tab(canvas.getByRole('button'));
48
+ userEvent.keyboard('{space}');
48
49
  };
49
50
 
50
51
  export const Basic400Zoom = storyConfig(
@@ -60,7 +61,7 @@ export const RightAligned = () => {
60
61
  const placeholder = text('placeholder', 'placeholder');
61
62
  const size = select('size', Object.values(Size), Size.MEDIUM);
62
63
 
63
- const minvalue = date('minvalue', new Date());
64
+ const minvalue = date('minvalue', thePast);
64
65
  const maxvalue = date('maxvalue', theFuture);
65
66
  const clearable = boolean('clearable', false);
66
67
 
@@ -4,6 +4,7 @@ import { PureComponent } from 'react';
4
4
  import { injectIntl } from 'react-intl';
5
5
 
6
6
  import { getDayNames, isWithinRange } from '../../../common/dateUtils';
7
+ import { getFocusableTime } from '../../getFocusableTime/getFocusableTime';
7
8
  import { getStartOfDay } from '../../getStartOfDay';
8
9
  import TableLink from '../../tableLink';
9
10
 
@@ -65,6 +66,21 @@ class DayCalendarTable extends PureComponent {
65
66
  return !!(selectedDate && +new Date(viewYear, viewMonth, day) === +selectedDate);
66
67
  };
67
68
 
69
+ isToday = (day) => {
70
+ const { viewMonth, viewYear } = this.props;
71
+ return Number(getStartOfDay(new Date())) === Number(new Date(viewYear, viewMonth, day));
72
+ };
73
+
74
+ getAutofocusDay = (weeks) => {
75
+ const days = weeks.flatMap((week) => week);
76
+ return getFocusableTime({
77
+ isActive: this.isActive,
78
+ isNow: this.isToday,
79
+ isDisabled: this.isDisabled,
80
+ timeSpan: days,
81
+ });
82
+ };
83
+
68
84
  render() {
69
85
  const {
70
86
  viewMonth,
@@ -72,12 +88,20 @@ class DayCalendarTable extends PureComponent {
72
88
  intl: { locale },
73
89
  } = this.props;
74
90
  const weeks = this.getTableStructure();
91
+ let autoFocusDay = this.getAutofocusDay(weeks, viewMonth, viewYear);
75
92
  return (
76
93
  <table className="table table-condensed table-bordered tw-date-lookup-calendar m-b-0">
77
94
  <thead>
78
95
  <tr>
79
96
  {this.days.map((day, index) => (
80
- <th key={day} className="text-xs-center np-text-body-default-bold">
97
+ <th
98
+ key={day}
99
+ className={
100
+ index > 4
101
+ ? 'text-xs-center np-text-body-default'
102
+ : 'text-xs-center np-text-body-default-bold'
103
+ }
104
+ >
81
105
  <span className="hidden-xs">
82
106
  <abbr title={this.daysLong[index]}>{day.slice(0, 3)}</abbr>
83
107
  </span>
@@ -93,7 +117,7 @@ class DayCalendarTable extends PureComponent {
93
117
  {weeks.map((week, weekIndex) => (
94
118
  <tr key={weekIndex}>
95
119
  {week.map((day, dayIndex) => (
96
- <td key={dayIndex} className={dayIndex > 4 ? 'default' : ''}>
120
+ <td key={dayIndex} className={dayIndex > 4 ? 'weekend' : ''}>
97
121
  {day && (
98
122
  <TableLink
99
123
  item={day}
@@ -103,10 +127,11 @@ class DayCalendarTable extends PureComponent {
103
127
  locale,
104
128
  SHORT_DAY_FORMAT,
105
129
  )}
130
+ autofocus={day === autoFocusDay}
106
131
  longTitle={formatDate(new Date(viewYear, viewMonth, day), locale)}
107
132
  active={this.isActive(day)}
108
133
  disabled={this.isDisabled(day)}
109
- today={+getStartOfDay(new Date()) === +new Date(viewYear, viewMonth, day)}
134
+ today={this.isToday(day)}
110
135
  onClick={this.selectDay}
111
136
  />
112
137
  )}
@@ -117,6 +117,31 @@ describe('DayCalendarTable', () => {
117
117
  expect(props.onSelect).toHaveBeenCalledWith(new Date(2018, 11, 1));
118
118
  });
119
119
 
120
+ it('sets autofocus to true when 5 is the selected day', () => {
121
+ component.setProps({ selectedDate: new Date(2018, 11, 5) });
122
+ expect(getTableLinkAt(4).prop('autofocus')).toBe(true);
123
+ });
124
+
125
+ it('does not set autofocus to true when 5 is the selected day but not the right month', () => {
126
+ component.setProps({ selectedDate: new Date(2018, 10, 5) });
127
+ expect(getTableLinkAt(4).prop('autofocus')).toBe(false);
128
+ });
129
+
130
+ it('does not set autofocus to true when 5 is the selected day but not the right year', () => {
131
+ component.setProps({ selectedDate: new Date(2017, 11, 5) });
132
+ expect(getTableLinkAt(4).prop('autofocus')).toBe(false);
133
+ });
134
+
135
+ it('sets autofocus to true when selected date is null and current day is visible', () => {
136
+ const today = new Date();
137
+ component.setProps({
138
+ selectedDate: today,
139
+ viewMonth: today.getMonth(),
140
+ viewYear: today.getFullYear(),
141
+ });
142
+ expect(component.find(TableLink).find({ today: true }).prop('autofocus')).toBe(true);
143
+ });
144
+
120
145
  const getTableLinkAt = (i) => component.find(TableLink).at(i);
121
146
  const getTableDataAt = (i) => component.find('tbody td').at(i);
122
147
  });
@@ -0,0 +1,40 @@
1
+ import { getFocusableTime } from './getFocusableTime';
2
+
3
+ describe('getFocusableTime', () => {
4
+ const isActive = (value: number) => value === 2;
5
+ const isNow = (value: number) => value === 3;
6
+ const isDisabled = (value: number) => value === 4;
7
+ const values = [1, 2, 3, 4, 5];
8
+
9
+ it('returns first selected value', () => {
10
+ expect(getFocusableTime({ isActive, isNow, isDisabled, timeSpan: values })).toBe(2);
11
+ });
12
+
13
+ it('returns first now value if nothing is selected', () => {
14
+ expect(getFocusableTime({ isActive: () => false, isNow, isDisabled, timeSpan: values })).toBe(
15
+ 3,
16
+ );
17
+ });
18
+
19
+ it('returns first non disabled value when nothing is selected or now', () => {
20
+ expect(
21
+ getFocusableTime({
22
+ isActive: () => false,
23
+ isNow: () => false,
24
+ isDisabled,
25
+ timeSpan: values,
26
+ }),
27
+ ).toBe(1);
28
+ });
29
+
30
+ it('returns null if no selected, now, or non-disabled', () => {
31
+ expect(
32
+ getFocusableTime({
33
+ isActive: () => false,
34
+ isNow: () => false,
35
+ isDisabled: () => true,
36
+ timeSpan: values,
37
+ }),
38
+ ).toBeUndefined();
39
+ });
40
+ });
@@ -0,0 +1,14 @@
1
+ interface FocusableTimeProps {
2
+ isActive: (time: number) => boolean;
3
+ isNow: (time: number) => boolean;
4
+ isDisabled: (time: number) => boolean;
5
+ timeSpan: number[];
6
+ }
7
+
8
+ export function getFocusableTime(props: FocusableTimeProps): number | undefined {
9
+ return (
10
+ props.timeSpan.find((time: number) => props.isActive(time)) ||
11
+ props.timeSpan.find((time: number) => props.isNow(time) && !props.isDisabled(time)) ||
12
+ props.timeSpan.find((time: number) => !props.isDisabled(time))
13
+ );
14
+ }
@@ -2,33 +2,40 @@ import { formatDate } from '@transferwise/formatting';
2
2
  import PropTypes from 'prop-types';
3
3
  import { useIntl } from 'react-intl';
4
4
 
5
+ import { getFocusableTime } from '../../getFocusableTime/getFocusableTime';
5
6
  import TableLink from '../../tableLink';
6
7
 
7
8
  const ROWS = 3;
8
9
  const COLS = 4;
9
- const MONTH_ONLY_FORMAY = { month: 'short' };
10
+ const MONTH_ONLY_FORMAT = { month: 'short' };
10
11
 
11
- const MonthCalendarTable = ({
12
- selectedDate: selected,
13
- min,
14
- max,
15
- viewYear,
16
- placeholder,
17
- onSelect,
18
- }) => {
12
+ const MonthCalendarTable = ({ selectedDate, min, max, viewYear, placeholder, onSelect }) => {
19
13
  const { locale } = useIntl();
14
+ const getLink = (month) => {
15
+ return (
16
+ <TableLink
17
+ item={month}
18
+ type="month"
19
+ title={formatDate(new Date(viewYear, month), locale, MONTH_ONLY_FORMAT)}
20
+ active={isActive(month)}
21
+ disabled={isDisabled(month)}
22
+ today={viewYear === new Date().getFullYear() && month === new Date().getMonth()}
23
+ autofocus={autofocusMonth === month}
24
+ onClick={onSelect}
25
+ />
26
+ );
27
+ };
28
+
29
+ const isActive = (month) => {
30
+ return (
31
+ selectedDate && month === selectedDate.getMonth() && viewYear === selectedDate.getFullYear()
32
+ );
33
+ };
34
+
35
+ const isThisMonth = (month) => {
36
+ return viewYear === new Date().getFullYear() && month === new Date().getMonth();
37
+ };
20
38
 
21
- const getLink = (month) => (
22
- <TableLink
23
- item={month}
24
- type="month"
25
- title={formatDate(new Date(viewYear, month), locale, MONTH_ONLY_FORMAY)}
26
- active={!!(selected && month === selected.getMonth() && viewYear === selected.getFullYear())}
27
- disabled={isDisabled(month)}
28
- today={viewYear === new Date().getFullYear() && month === new Date().getMonth()}
29
- onClick={onSelect}
30
- />
31
- );
32
39
  const isDisabled = (month) => {
33
40
  const date = new Date(viewYear, month);
34
41
  return !!(
@@ -36,6 +43,12 @@ const MonthCalendarTable = ({
36
43
  (max && date > new Date(max.getFullYear(), max.getMonth()))
37
44
  );
38
45
  };
46
+
47
+ const autofocusMonth = (() => {
48
+ const months = [...new Array(ROWS * COLS)].map((_, index) => index);
49
+ return getFocusableTime({ isActive, isNow: isThisMonth, isDisabled, timeSpan: months });
50
+ })();
51
+
39
52
  return (
40
53
  <table className="table table-condensed table-bordered tw-date-lookup-calendar np-text-body-default-bold m-b-0">
41
54
  <thead className="sr-only">