From a385d5cfd67e1f460696e7e3bfa15d6acd9af0b1 Mon Sep 17 00:00:00 2001 From: Yue Yang Date: Wed, 31 Jul 2019 18:56:14 +0800 Subject: [PATCH] fix: Fix relativeTime Plugin .FromNow() result error in UTC mode --- src/plugin/relativeTime/index.js | 7 +++++-- test/plugin/relativeTime.test.js | 25 ++++++++++++++++++++++++- 2 files changed, 29 insertions(+), 3 deletions(-) diff --git a/src/plugin/relativeTime/index.js b/src/plugin/relativeTime/index.js index e3e6a09d3..07d585c19 100644 --- a/src/plugin/relativeTime/index.js +++ b/src/plugin/relativeTime/index.js @@ -59,10 +59,13 @@ export default (o, c, d) => { proto.from = function (input, withoutSuffix) { return fromTo(input, withoutSuffix, this) } + + const makeNow = thisDay => (thisDay.$u ? d.utc() : d()) + proto.toNow = function (withoutSuffix) { - return this.to(d(), withoutSuffix) + return this.to(makeNow(this), withoutSuffix) } proto.fromNow = function (withoutSuffix) { - return this.from(d(), withoutSuffix) + return this.from(makeNow(this), withoutSuffix) } } diff --git a/test/plugin/relativeTime.test.js b/test/plugin/relativeTime.test.js index 38e35459c..de9e10d10 100644 --- a/test/plugin/relativeTime.test.js +++ b/test/plugin/relativeTime.test.js @@ -2,6 +2,7 @@ import MockDate from 'mockdate' import moment from 'moment' import dayjs from '../../src' import relativeTime from '../../src/plugin/relativeTime' +import utc from '../../src/plugin/utc' dayjs.extend(relativeTime) @@ -70,7 +71,6 @@ it('Time from now', () => { expect(dayjs().fromNow(true)).toBe(moment().fromNow(true)) }) - it('Time to now', () => { expect(dayjs().toNow()).toBe(moment().toNow()) expect(dayjs().toNow(true)).toBe(moment().toNow(true)) @@ -82,3 +82,26 @@ it('Time to X', () => { // past date expect(dayjs().to(dayjs().subtract(3, 'year'))).toBe(moment().to(moment().subtract(3, 'year'))) }) + +// https://github.com/iamkun/dayjs/issues/646 +it('Time from now with UTC', () => { + dayjs.extend(utc) + + expect(dayjs.utc().fromNow()).toBe(moment.utc().fromNow()) + + const currentTime = new Date() + const currentTimestamp = currentTime.getTime() + const currentTimestampAfter37hrs = currentTimestamp + (37 * 60 * 60 * 1000) + + let dutc = dayjs.utc(currentTimestampAfter37hrs) + let mutc = moment.utc(currentTimestampAfter37hrs) + + expect(dutc.fromNow()).toBe(mutc.fromNow()) + + // More precise + const currentTimestampAfter36hrs = currentTimestamp + (36.0001 * 60 * 60 * 1000) + dutc = dayjs.utc(currentTimestampAfter36hrs) + mutc = moment.utc(currentTimestampAfter36hrs) + + expect(dutc.fromNow()).toBe(mutc.fromNow()) +})