fix(common): date pipe gives wrong week number (#37632)
Date pipe is giving wrong week number when used with the date format 'w'. If first week(according to Iso) has some days in previous year Fixes #33961 PR Close #37632
This commit is contained in:
parent
e36d5b201a
commit
ef1fb6dee4
|
@ -382,8 +382,10 @@ function weekGetter(size: number, monthBased = false): DateFormatter {
|
||||||
const today = date.getDate();
|
const today = date.getDate();
|
||||||
result = 1 + Math.floor((today + nbDaysBefore1stDayOfMonth) / 7);
|
result = 1 + Math.floor((today + nbDaysBefore1stDayOfMonth) / 7);
|
||||||
} else {
|
} else {
|
||||||
const firstThurs = getFirstThursdayOfYear(date.getFullYear());
|
|
||||||
const thisThurs = getThursdayThisWeek(date);
|
const thisThurs = getThursdayThisWeek(date);
|
||||||
|
// Some days of a year are part of next year according to ISO 8601.
|
||||||
|
// Compute the firstThurs from the year of this week's Thursday
|
||||||
|
const firstThurs = getFirstThursdayOfYear(thisThurs.getFullYear());
|
||||||
const diff = thisThurs.getTime() - firstThurs.getTime();
|
const diff = thisThurs.getTime() - firstThurs.getTime();
|
||||||
result = 1 + Math.round(diff / 6.048e8); // 6.048e8 ms per week
|
result = 1 + Math.round(diff / 6.048e8); // 6.048e8 ms per week
|
||||||
}
|
}
|
||||||
|
|
|
@ -71,6 +71,20 @@ import {JitReflector} from '@angular/platform-browser-dynamic/src/compiler_refle
|
||||||
describe('transform', () => {
|
describe('transform', () => {
|
||||||
it('should use "mediumDate" as the default format',
|
it('should use "mediumDate" as the default format',
|
||||||
() => expect(pipe.transform('2017-01-11T10:14:39+0000')).toEqual('Jan 11, 2017'));
|
() => expect(pipe.transform('2017-01-11T10:14:39+0000')).toEqual('Jan 11, 2017'));
|
||||||
|
|
||||||
|
it('should return first week if some dates fall in previous year but belong to next year according to ISO 8601 format',
|
||||||
|
() => {
|
||||||
|
expect(pipe.transform('2019-12-28T00:00:00', 'w')).toEqual('52');
|
||||||
|
expect(pipe.transform('2019-12-29T00:00:00', 'w')).toEqual('1');
|
||||||
|
expect(pipe.transform('2019-12-30T00:00:00', 'w')).toEqual('1');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('should return first week if some dates fall in previous leap year but belong to next year according to ISO 8601 format',
|
||||||
|
() => {
|
||||||
|
expect(pipe.transform('2012-12-29T00:00:00', 'w')).toEqual('52');
|
||||||
|
expect(pipe.transform('2012-12-30T00:00:00', 'w')).toEqual('1');
|
||||||
|
expect(pipe.transform('2012-12-31T00:00:00', 'w')).toEqual('1');
|
||||||
|
});
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue