From ca0e82a3c7e24822b485d1a3eebab9dcf5f6d359 Mon Sep 17 00:00:00 2001 From: james hadfield Date: Tue, 19 Nov 2024 10:22:40 +1300 Subject: [PATCH] [dates] handle 0-99CE root-node dates A root-date in the tree between 0-99CE would be interpreted by JS to be 1900-1999 by default. Closes #1892 --- src/util/dateHelpers.js | 12 +++++++++--- 1 file changed, 9 insertions(+), 3 deletions(-) diff --git a/src/util/dateHelpers.js b/src/util/dateHelpers.js index 847f3b396..e5460ac44 100644 --- a/src/util/dateHelpers.js +++ b/src/util/dateHelpers.js @@ -18,7 +18,9 @@ export const numericToDateObject = (numDate) => { const year = parseInt(numDate, 10); const nDaysInYear = isLeapYear(year) ? 366 : 365; const nDays = fracPart * nDaysInYear; - const date = new Date((new Date(year, 0, 1)).getTime() + nDays*24*60*60*1000); + const yearObj = new Date(year, 0, 1); + if (year<100) yearObj.setFullYear(year); + const date = new Date(yearObj.getTime() + nDays*24*60*60*1000); return date; }; @@ -130,8 +132,12 @@ export const getPreviousDate = (unit, date) => { case "DECADE": // decades start at "nice" numbers - i.e. multiples of 5 -- e.g. 2014 -> 2010, 2021 -> 2020 return new Date(Math.floor((date.getFullYear())/5)*5, 0, 1, 12); - case "CENTURY": - return new Date(Math.floor((date.getFullYear())/100)*100, 0, 1, 12); + case "CENTURY": { + const year = Math.floor((date.getFullYear())/100)*100; + const ret = new Date(year, 0, 1, 12); + ret.setFullYear(year); + return ret + } default: console.error("Unknown unit for `advanceDateTo`:", unit); return dateClone;