2018-04-13 00:45:14 +00:00
|
|
|
import { assert } from 'chai';
|
2018-04-13 20:27:06 +00:00
|
|
|
import { shuffle } from 'lodash';
|
2018-04-13 00:45:14 +00:00
|
|
|
|
2018-11-14 18:47:19 +00:00
|
|
|
import { IMAGE_JPEG } from '../../../types/MIME';
|
2018-04-13 20:27:06 +00:00
|
|
|
import {
|
2018-11-14 18:47:19 +00:00
|
|
|
groupMediaItemsByDate,
|
2018-04-13 20:27:06 +00:00
|
|
|
Section,
|
2018-11-14 18:47:19 +00:00
|
|
|
} from '../../../components/conversation/media-gallery/groupMediaItemsByDate';
|
|
|
|
import { MediaItemType } from '../../../components/LightboxGallery';
|
2018-04-13 00:45:14 +00:00
|
|
|
|
2018-11-14 18:47:19 +00:00
|
|
|
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',
|
|
|
|
},
|
2018-04-13 00:45:14 +00:00
|
|
|
});
|
|
|
|
|
2018-11-14 18:47:19 +00:00
|
|
|
describe('groupMediaItemsByDate', () => {
|
|
|
|
it('should group mediaItems', () => {
|
2018-04-13 14:53:15 +00:00
|
|
|
const referenceTime = new Date('2018-04-12T18:00Z').getTime(); // Thu
|
2018-11-14 18:47:19 +00:00
|
|
|
const input: Array<MediaItemType> = shuffle([
|
2018-04-13 00:45:14 +00:00
|
|
|
// Today
|
2018-11-14 18:47:19 +00:00
|
|
|
toMediaItem(new Date('2018-04-12T12:00Z')), // Thu
|
|
|
|
toMediaItem(new Date('2018-04-12T00:01Z')), // Thu
|
2018-04-13 00:45:14 +00:00
|
|
|
// This week
|
2018-11-14 18:47:19 +00:00
|
|
|
toMediaItem(new Date('2018-04-11T23:59Z')), // Wed
|
|
|
|
toMediaItem(new Date('2018-04-09T00:01Z')), // Mon
|
2018-04-13 00:45:14 +00:00
|
|
|
// This month
|
2018-11-14 18:47:19 +00:00
|
|
|
toMediaItem(new Date('2018-04-08T23:59Z')), // Sun
|
|
|
|
toMediaItem(new Date('2018-04-01T00:01Z')),
|
2018-04-13 00:45:14 +00:00
|
|
|
// March 2018
|
2018-11-14 18:47:19 +00:00
|
|
|
toMediaItem(new Date('2018-03-31T23:59Z')),
|
|
|
|
toMediaItem(new Date('2018-03-01T14:00Z')),
|
2018-04-13 00:45:14 +00:00
|
|
|
// February 2011
|
2018-11-14 18:47:19 +00:00
|
|
|
toMediaItem(new Date('2011-02-28T23:59Z')),
|
|
|
|
toMediaItem(new Date('2011-02-01T10:00Z')),
|
2018-04-13 20:27:06 +00:00
|
|
|
]);
|
2018-04-13 00:45:14 +00:00
|
|
|
|
2018-04-13 20:27:06 +00:00
|
|
|
const expected: Array<Section> = [
|
|
|
|
{
|
|
|
|
type: 'today',
|
2018-11-14 18:47:19 +00:00
|
|
|
mediaItems: [
|
2018-04-13 20:27:06 +00:00
|
|
|
{
|
2018-11-14 18:47:19 +00:00
|
|
|
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',
|
|
|
|
},
|
2018-04-13 00:45:14 +00:00
|
|
|
},
|
2018-04-13 20:27:06 +00:00
|
|
|
{
|
2018-11-14 18:47:19 +00:00
|
|
|
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',
|
|
|
|
},
|
2018-04-13 00:45:14 +00:00
|
|
|
},
|
2018-04-13 20:27:06 +00:00
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: 'yesterday',
|
2018-11-14 18:47:19 +00:00
|
|
|
mediaItems: [
|
2018-04-13 20:27:06 +00:00
|
|
|
{
|
2018-11-14 18:47:19 +00:00
|
|
|
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',
|
|
|
|
},
|
2018-04-13 00:45:14 +00:00
|
|
|
},
|
2018-04-13 20:27:06 +00:00
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: 'thisWeek',
|
2018-11-14 18:47:19 +00:00
|
|
|
mediaItems: [
|
2018-04-13 20:27:06 +00:00
|
|
|
{
|
2018-11-14 18:47:19 +00:00
|
|
|
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',
|
|
|
|
},
|
2018-04-13 00:45:14 +00:00
|
|
|
},
|
2018-04-13 20:27:06 +00:00
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: 'thisMonth',
|
2018-11-14 18:47:19 +00:00
|
|
|
mediaItems: [
|
2018-04-13 20:27:06 +00:00
|
|
|
{
|
2018-11-14 18:47:19 +00:00
|
|
|
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',
|
|
|
|
},
|
2018-04-13 00:45:14 +00:00
|
|
|
},
|
2018-04-13 20:27:06 +00:00
|
|
|
{
|
2018-11-14 18:47:19 +00:00
|
|
|
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',
|
|
|
|
},
|
2018-04-13 00:45:14 +00:00
|
|
|
},
|
2018-04-13 20:27:06 +00:00
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: 'yearMonth',
|
|
|
|
year: 2018,
|
|
|
|
month: 2,
|
2018-11-14 18:47:19 +00:00
|
|
|
mediaItems: [
|
2018-04-13 20:27:06 +00:00
|
|
|
{
|
2018-11-14 18:47:19 +00:00
|
|
|
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',
|
|
|
|
},
|
2018-04-13 00:45:14 +00:00
|
|
|
},
|
2018-04-13 20:27:06 +00:00
|
|
|
{
|
2018-11-14 18:47:19 +00:00
|
|
|
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',
|
|
|
|
},
|
2018-04-13 00:45:14 +00:00
|
|
|
},
|
2018-04-13 20:27:06 +00:00
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
type: 'yearMonth',
|
|
|
|
year: 2011,
|
|
|
|
month: 1,
|
2018-11-14 18:47:19 +00:00
|
|
|
mediaItems: [
|
2018-04-13 20:27:06 +00:00
|
|
|
{
|
2018-11-14 18:47:19 +00:00
|
|
|
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',
|
|
|
|
},
|
2018-04-13 00:45:14 +00:00
|
|
|
},
|
2018-04-13 20:27:06 +00:00
|
|
|
{
|
2018-11-14 18:47:19 +00:00
|
|
|
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',
|
|
|
|
},
|
2018-04-13 00:45:14 +00:00
|
|
|
},
|
2018-04-13 20:27:06 +00:00
|
|
|
],
|
|
|
|
},
|
|
|
|
];
|
2018-04-13 00:45:14 +00:00
|
|
|
|
2018-11-14 18:47:19 +00:00
|
|
|
const actual = groupMediaItemsByDate(referenceTime, input);
|
2018-04-13 00:45:14 +00:00
|
|
|
assert.deepEqual(actual, expected);
|
|
|
|
});
|
|
|
|
});
|