YearParser.js 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. import { Parser } from "../Parser.js";
  2. import { mapValue, normalizeTwoDigitYear, parseNDigits } from "../utils.js";
  3. // From http://www.unicode.org/reports/tr35/tr35-31/tr35-dates.html#Date_Format_Patterns
  4. // | Year | y | yy | yyy | yyyy | yyyyy |
  5. // |----------|-------|----|-------|-------|-------|
  6. // | AD 1 | 1 | 01 | 001 | 0001 | 00001 |
  7. // | AD 12 | 12 | 12 | 012 | 0012 | 00012 |
  8. // | AD 123 | 123 | 23 | 123 | 0123 | 00123 |
  9. // | AD 1234 | 1234 | 34 | 1234 | 1234 | 01234 |
  10. // | AD 12345 | 12345 | 45 | 12345 | 12345 | 12345 |
  11. export class YearParser extends Parser {
  12. priority = 130;
  13. incompatibleTokens = ["Y", "R", "u", "w", "I", "i", "e", "c", "t", "T"];
  14. parse(dateString, token, match) {
  15. const valueCallback = (year) => ({
  16. year,
  17. isTwoDigitYear: token === "yy",
  18. });
  19. switch (token) {
  20. case "y":
  21. return mapValue(parseNDigits(4, dateString), valueCallback);
  22. case "yo":
  23. return mapValue(
  24. match.ordinalNumber(dateString, {
  25. unit: "year",
  26. }),
  27. valueCallback,
  28. );
  29. default:
  30. return mapValue(parseNDigits(token.length, dateString), valueCallback);
  31. }
  32. }
  33. validate(_date, value) {
  34. return value.isTwoDigitYear || value.year > 0;
  35. }
  36. set(date, flags, value) {
  37. const currentYear = date.getFullYear();
  38. if (value.isTwoDigitYear) {
  39. const normalizedTwoDigitYear = normalizeTwoDigitYear(
  40. value.year,
  41. currentYear,
  42. );
  43. date.setFullYear(normalizedTwoDigitYear, 0, 1);
  44. date.setHours(0, 0, 0, 0);
  45. return date;
  46. }
  47. const year =
  48. !("era" in flags) || flags.era === 1 ? value.year : 1 - value.year;
  49. date.setFullYear(year, 0, 1);
  50. date.setHours(0, 0, 0, 0);
  51. return date;
  52. }
  53. }