dateUtils.ts 1.3 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. import { format } from 'date-fns';
  2. import ArrayUtils from "~/services/utils/arrayUtils";
  3. import { enUS, fr } from 'date-fns/locale'
  4. export const enum supportedLocales {
  5. FR = 'fr',
  6. EN = 'en'
  7. }
  8. export default class DateUtils {
  9. public static format(date: Date, fmt: string): string {
  10. return format(date, fmt)
  11. }
  12. /**
  13. * Formate la ou les dates au format donné et retourne la liste concaténée
  14. *
  15. * @param dates
  16. * @param fmt
  17. * @param sep
  18. */
  19. public static formatAndConcat (dates: Date | Array<Date>, fmt: string, sep: string = ' - '): string {
  20. dates = Array.isArray(dates) ? dates : [dates]
  21. return dates.map((d) => this.format(d, fmt)).join(sep)
  22. }
  23. /**
  24. * Trie les dates par ordre chronologique
  25. *
  26. * @param dates
  27. * @param reverse
  28. */
  29. public static sort(dates: Array<Date>, reverse: boolean = false): Array<Date> {
  30. return ArrayUtils.sort(dates, reverse) as Array<Date>
  31. }
  32. public static getFnsLocale(code: supportedLocales): Locale {
  33. return {
  34. 'en': enUS,
  35. 'fr' : fr
  36. }[code]
  37. }
  38. public static getShortFormatPattern(code: supportedLocales): string {
  39. return {
  40. 'en': 'MM/dd/yyyy',
  41. 'fr': 'dd/MM/yyyy'
  42. }[code]
  43. }
  44. public static formatIsoShortDate(date: Date): string {
  45. return format(date, 'yyyy-MM-dd')
  46. }
  47. }