Skip to content

Commit 8490db2

Browse files
authored
Merge pull request #298 from leduyquang753/applyDuration
Make `applyDuration` reversible
2 parents 9a9f987 + e16b828 commit 8490db2

File tree

2 files changed

+26
-14
lines changed

2 files changed

+26
-14
lines changed

Diff for: src/duration.ts

+15-6
Original file line numberDiff line numberDiff line change
@@ -86,12 +86,21 @@ export class Duration {
8686

8787
export function applyDuration(date: Date | number, duration: Duration): Date {
8888
const r = new Date(date)
89-
r.setFullYear(r.getFullYear() + duration.years)
90-
r.setMonth(r.getMonth() + duration.months)
91-
r.setDate(r.getDate() + duration.weeks * 7 + duration.days)
92-
r.setHours(r.getHours() + duration.hours)
93-
r.setMinutes(r.getMinutes() + duration.minutes)
94-
r.setSeconds(r.getSeconds() + duration.seconds)
89+
if (duration.sign < 0) {
90+
r.setUTCSeconds(r.getUTCSeconds() + duration.seconds)
91+
r.setUTCMinutes(r.getUTCMinutes() + duration.minutes)
92+
r.setUTCHours(r.getUTCHours() + duration.hours)
93+
r.setUTCDate(r.getUTCDate() + duration.weeks * 7 + duration.days)
94+
r.setUTCMonth(r.getUTCMonth() + duration.months)
95+
r.setUTCFullYear(r.getUTCFullYear() + duration.years)
96+
} else {
97+
r.setUTCFullYear(r.getUTCFullYear() + duration.years)
98+
r.setUTCMonth(r.getUTCMonth() + duration.months)
99+
r.setUTCDate(r.getUTCDate() + duration.weeks * 7 + duration.days)
100+
r.setUTCHours(r.getUTCHours() + duration.hours)
101+
r.setUTCMinutes(r.getUTCMinutes() + duration.minutes)
102+
r.setUTCSeconds(r.getUTCSeconds() + duration.seconds)
103+
}
95104
return r
96105
}
97106

Diff for: test/duration.ts

+11-8
Original file line numberDiff line numberDiff line change
@@ -81,16 +81,19 @@ suite('duration', function () {
8181
})
8282

8383
suite('applyDuration', function () {
84-
const referenceDate = '2022-10-21T16:48:44.104Z'
8584
const tests = new Set([
86-
{input: 'P4Y', expected: '2026-10-21T16:48:44.104Z'},
87-
{input: '-P4Y', expected: '2018-10-21T16:48:44.104Z'},
88-
{input: '-P3MT5M', expected: '2022-07-21T16:43:44.104Z'},
89-
{input: 'P1Y2M3DT4H5M6S', expected: '2023-12-24T20:53:50.104Z'},
90-
{input: 'P5W', expected: '2022-11-25T16:48:44.104Z'},
91-
{input: '-P5W', expected: '2022-09-16T16:48:44.104Z'},
85+
{referenceDate: '2022-10-21T16:48:44.104Z', input: 'P5W', expected: '2022-11-25T16:48:44.104Z'},
86+
{referenceDate: '2022-11-25T16:48:44.104Z', input: '-P5W', expected: '2022-10-21T16:48:44.104Z'},
87+
{referenceDate: '2022-07-21T16:43:44.104Z', input: 'P3MT5M', expected: '2022-10-21T16:48:44.104Z'},
88+
{referenceDate: '2022-10-21T16:48:44.104Z', input: '-P3MT5M', expected: '2022-07-21T16:43:44.104Z'},
89+
{referenceDate: '2022-10-21T16:48:44.104Z', input: 'P4Y', expected: '2026-10-21T16:48:44.104Z'},
90+
{referenceDate: '2026-10-21T16:48:44.104Z', input: '-P4Y', expected: '2022-10-21T16:48:44.104Z'},
91+
{referenceDate: '2022-10-21T16:48:44.104Z', input: 'P1Y2M3DT4H5M6S', expected: '2023-12-24T20:53:50.104Z'},
92+
{referenceDate: '2023-12-24T20:53:50.104Z', input: '-P1Y2M3DT4H5M6S', expected: '2022-10-21T16:48:44.104Z'},
93+
{referenceDate: '2023-08-15T00:00:00.000Z', input: 'P1Y3M25D', expected: '2024-12-10T00:00:00.000Z'},
94+
{referenceDate: '2024-12-10T00:00:00.000Z', input: '-P1Y3M25D', expected: '2023-08-15T00:00:00.000Z'},
9295
])
93-
for (const {input, expected} of tests) {
96+
for (const {referenceDate, input, expected} of tests) {
9497
test(`${referenceDate} -> ${input} -> ${expected}`, () => {
9598
assert.equal(applyDuration(new Date(referenceDate), Duration.from(input))?.toISOString(), expected)
9699
})

0 commit comments

Comments
 (0)