import { assert } from 'chai'; import { shuffle } from 'lodash'; import { IMAGE_JPEG } from '../../../types/MIME'; import { groupMediaItemsByDate, Section, } from '../../../components/conversation/media-gallery/groupMediaItemsByDate'; import { MediaItemType } from '../../../components/LightboxGallery'; const toMediaItem = (date: Date): MediaItemType => ({ objectURL: date.toUTCString(), index: 0, message: { id: 'id', received_at: date.getTime(), attachments: [], }, attachment: { fileName: 'fileName', contentType: IMAGE_JPEG, url: 'url', }, }); describe('groupMediaItemsByDate', () => { it('should group mediaItems', () => { const referenceTime = new Date('2018-04-12T18:00Z').getTime(); // Thu const input: Array = shuffle([ // Today toMediaItem(new Date('2018-04-12T12:00Z')), // Thu toMediaItem(new Date('2018-04-12T00:01Z')), // Thu // This week toMediaItem(new Date('2018-04-11T23:59Z')), // Wed toMediaItem(new Date('2018-04-09T00:01Z')), // Mon // This month toMediaItem(new Date('2018-04-08T23:59Z')), // Sun toMediaItem(new Date('2018-04-01T00:01Z')), // March 2018 toMediaItem(new Date('2018-03-31T23:59Z')), toMediaItem(new Date('2018-03-01T14:00Z')), // February 2011 toMediaItem(new Date('2011-02-28T23:59Z')), toMediaItem(new Date('2011-02-01T10:00Z')), ]); const expected: Array
= [ { type: 'today', mediaItems: [ { objectURL: 'Thu, 12 Apr 2018 12:00:00 GMT', index: 0, message: { id: 'id', received_at: 1523534400000, attachments: [], }, attachment: { fileName: 'fileName', contentType: IMAGE_JPEG, url: 'url', }, }, { objectURL: 'Thu, 12 Apr 2018 00:01:00 GMT', index: 0, message: { id: 'id', received_at: 1523491260000, attachments: [], }, attachment: { fileName: 'fileName', contentType: IMAGE_JPEG, url: 'url', }, }, ], }, { type: 'yesterday', mediaItems: [ { objectURL: 'Wed, 11 Apr 2018 23:59:00 GMT', index: 0, message: { id: 'id', received_at: 1523491140000, attachments: [], }, attachment: { fileName: 'fileName', contentType: IMAGE_JPEG, url: 'url', }, }, ], }, { type: 'thisWeek', mediaItems: [ { objectURL: 'Mon, 09 Apr 2018 00:01:00 GMT', index: 0, message: { id: 'id', received_at: 1523232060000, attachments: [], }, attachment: { fileName: 'fileName', contentType: IMAGE_JPEG, url: 'url', }, }, ], }, { type: 'thisMonth', mediaItems: [ { objectURL: 'Sun, 08 Apr 2018 23:59:00 GMT', index: 0, message: { id: 'id', received_at: 1523231940000, attachments: [], }, attachment: { fileName: 'fileName', contentType: IMAGE_JPEG, url: 'url', }, }, { objectURL: 'Sun, 01 Apr 2018 00:01:00 GMT', index: 0, message: { id: 'id', received_at: 1522540860000, attachments: [], }, attachment: { fileName: 'fileName', contentType: IMAGE_JPEG, url: 'url', }, }, ], }, { type: 'yearMonth', year: 2018, month: 2, mediaItems: [ { objectURL: 'Sat, 31 Mar 2018 23:59:00 GMT', index: 0, message: { id: 'id', received_at: 1522540740000, attachments: [], }, attachment: { fileName: 'fileName', contentType: IMAGE_JPEG, url: 'url', }, }, { objectURL: 'Thu, 01 Mar 2018 14:00:00 GMT', index: 0, message: { id: 'id', received_at: 1519912800000, attachments: [], }, attachment: { fileName: 'fileName', contentType: IMAGE_JPEG, url: 'url', }, }, ], }, { type: 'yearMonth', year: 2011, month: 1, mediaItems: [ { objectURL: 'Mon, 28 Feb 2011 23:59:00 GMT', index: 0, message: { id: 'id', received_at: 1298937540000, attachments: [], }, attachment: { fileName: 'fileName', contentType: IMAGE_JPEG, url: 'url', }, }, { objectURL: 'Tue, 01 Feb 2011 10:00:00 GMT', index: 0, message: { id: 'id', received_at: 1296554400000, attachments: [], }, attachment: { fileName: 'fileName', contentType: IMAGE_JPEG, url: 'url', }, }, ], }, ]; const actual = groupMediaItemsByDate(referenceTime, input); assert.deepEqual(actual, expected); }); });