You cannot select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
	
	
		
			228 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			TypeScript
		
	
			
		
		
	
	
			228 lines
		
	
	
		
			5.8 KiB
		
	
	
	
		
			TypeScript
		
	
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<MediaItemType> = 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<Section> = [
 | 
						|
      {
 | 
						|
        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);
 | 
						|
  });
 | 
						|
});
 |