2020-10-19 19:16:27 +00:00
|
|
|
import React from 'react';
|
|
|
|
import { assert } from 'chai';
|
2020-10-13 18:59:30 +00:00
|
|
|
|
2020-10-19 19:16:27 +00:00
|
|
|
import { LeftPane, RowType, HeaderType } from '../../components/LeftPane';
|
2020-10-13 18:59:30 +00:00
|
|
|
import { setup as setupI18n } from '../../../js/modules/i18n';
|
|
|
|
import enMessages from '../../../_locales/en/messages.json';
|
|
|
|
|
|
|
|
const i18n = setupI18n('en', enMessages);
|
|
|
|
|
|
|
|
describe('LeftPane', () => {
|
|
|
|
const defaultProps = {
|
|
|
|
archivedConversations: [],
|
|
|
|
conversations: [],
|
|
|
|
i18n,
|
|
|
|
openConversationInternal: () => null,
|
|
|
|
pinnedConversations: [],
|
2020-10-19 19:16:27 +00:00
|
|
|
renderExpiredBuildDialog: () => <div />,
|
|
|
|
renderMainHeader: () => <div />,
|
|
|
|
renderMessageSearchResult: () => <div />,
|
|
|
|
renderNetworkStatus: () => <div />,
|
|
|
|
renderRelinkDialog: () => <div />,
|
|
|
|
renderUpdateDialog: () => <div />,
|
2020-10-13 18:59:30 +00:00
|
|
|
showArchivedConversations: () => null,
|
|
|
|
showInbox: () => null,
|
|
|
|
startNewConversation: () => null,
|
|
|
|
};
|
|
|
|
|
|
|
|
describe('getRowFromIndex', () => {
|
|
|
|
describe('given only pinned chats', () => {
|
2020-10-19 19:16:27 +00:00
|
|
|
it('returns pinned chats, not headers', () => {
|
|
|
|
const leftPane = new LeftPane({
|
2020-10-13 18:59:30 +00:00
|
|
|
...defaultProps,
|
|
|
|
pinnedConversations: [
|
|
|
|
{
|
|
|
|
id: 'philly-convo',
|
|
|
|
isPinned: true,
|
|
|
|
isSelected: false,
|
|
|
|
lastUpdated: Date.now(),
|
2020-10-28 22:54:32 +00:00
|
|
|
markedUnread: false,
|
2020-10-13 18:59:30 +00:00
|
|
|
title: 'Philip Glass',
|
|
|
|
type: 'direct',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 'robbo-convo',
|
|
|
|
isPinned: true,
|
|
|
|
isSelected: false,
|
|
|
|
lastUpdated: Date.now(),
|
2020-10-28 22:54:32 +00:00
|
|
|
markedUnread: false,
|
2020-10-13 18:59:30 +00:00
|
|
|
title: 'Robert Moog',
|
|
|
|
type: 'direct',
|
|
|
|
},
|
|
|
|
],
|
2020-10-19 19:16:27 +00:00
|
|
|
});
|
2020-10-13 18:59:30 +00:00
|
|
|
|
2020-10-19 19:16:27 +00:00
|
|
|
assert.deepEqual(leftPane.getRowFromIndex(0), {
|
2020-10-13 18:59:30 +00:00
|
|
|
index: 0,
|
|
|
|
type: RowType.PinnedConversation,
|
|
|
|
});
|
2020-10-19 19:16:27 +00:00
|
|
|
assert.deepEqual(leftPane.getRowFromIndex(1), {
|
2020-10-13 18:59:30 +00:00
|
|
|
index: 1,
|
|
|
|
type: RowType.PinnedConversation,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('given only non-pinned chats', () => {
|
|
|
|
it('returns conversations, not headers', () => {
|
2020-10-19 19:16:27 +00:00
|
|
|
const leftPane = new LeftPane({
|
2020-10-13 18:59:30 +00:00
|
|
|
...defaultProps,
|
|
|
|
conversations: [
|
|
|
|
{
|
|
|
|
id: 'fred-convo',
|
|
|
|
isSelected: false,
|
|
|
|
lastUpdated: Date.now(),
|
2020-10-28 22:54:32 +00:00
|
|
|
markedUnread: false,
|
2020-10-13 18:59:30 +00:00
|
|
|
title: 'Fred Willard',
|
|
|
|
type: 'direct',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
id: 'robbo-convo',
|
|
|
|
isPinned: false,
|
|
|
|
isSelected: false,
|
|
|
|
lastUpdated: Date.now(),
|
2020-10-28 22:54:32 +00:00
|
|
|
markedUnread: false,
|
2020-10-13 18:59:30 +00:00
|
|
|
title: 'Robert Moog',
|
|
|
|
type: 'direct',
|
|
|
|
},
|
|
|
|
],
|
2020-10-19 19:16:27 +00:00
|
|
|
});
|
2020-10-13 18:59:30 +00:00
|
|
|
|
2020-10-19 19:16:27 +00:00
|
|
|
assert.deepEqual(leftPane.getRowFromIndex(0), {
|
2020-10-13 18:59:30 +00:00
|
|
|
index: 0,
|
|
|
|
type: RowType.Conversation,
|
|
|
|
});
|
2020-10-19 19:16:27 +00:00
|
|
|
assert.deepEqual(leftPane.getRowFromIndex(1), {
|
2020-10-13 18:59:30 +00:00
|
|
|
index: 1,
|
|
|
|
type: RowType.Conversation,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('given only pinned and non-pinned chats', () => {
|
2020-10-19 19:16:27 +00:00
|
|
|
it('returns headers and conversations', () => {
|
|
|
|
const leftPane = new LeftPane({
|
2020-10-13 18:59:30 +00:00
|
|
|
...defaultProps,
|
|
|
|
conversations: [
|
|
|
|
{
|
|
|
|
id: 'fred-convo',
|
|
|
|
isSelected: false,
|
|
|
|
lastUpdated: Date.now(),
|
2020-10-28 22:54:32 +00:00
|
|
|
markedUnread: false,
|
2020-10-13 18:59:30 +00:00
|
|
|
title: 'Fred Willard',
|
|
|
|
type: 'direct',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
pinnedConversations: [
|
|
|
|
{
|
|
|
|
id: 'philly-convo',
|
|
|
|
isPinned: true,
|
|
|
|
isSelected: false,
|
|
|
|
lastUpdated: Date.now(),
|
2020-10-28 22:54:32 +00:00
|
|
|
markedUnread: false,
|
2020-10-13 18:59:30 +00:00
|
|
|
title: 'Philip Glass',
|
|
|
|
type: 'direct',
|
|
|
|
},
|
|
|
|
],
|
2020-10-19 19:16:27 +00:00
|
|
|
});
|
2020-10-13 18:59:30 +00:00
|
|
|
|
2020-10-19 19:16:27 +00:00
|
|
|
assert.deepEqual(leftPane.getRowFromIndex(0), {
|
2020-10-13 18:59:30 +00:00
|
|
|
headerType: HeaderType.Pinned,
|
|
|
|
type: RowType.Header,
|
|
|
|
});
|
2020-10-19 19:16:27 +00:00
|
|
|
assert.deepEqual(leftPane.getRowFromIndex(1), {
|
2020-10-13 18:59:30 +00:00
|
|
|
index: 0,
|
|
|
|
type: RowType.PinnedConversation,
|
|
|
|
});
|
2020-10-19 19:16:27 +00:00
|
|
|
assert.deepEqual(leftPane.getRowFromIndex(2), {
|
2020-10-13 18:59:30 +00:00
|
|
|
headerType: HeaderType.Chats,
|
|
|
|
type: RowType.Header,
|
|
|
|
});
|
2020-10-19 19:16:27 +00:00
|
|
|
assert.deepEqual(leftPane.getRowFromIndex(3), {
|
2020-10-13 18:59:30 +00:00
|
|
|
index: 0,
|
|
|
|
type: RowType.Conversation,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
2020-10-16 22:05:40 +00:00
|
|
|
|
2020-10-13 18:59:30 +00:00
|
|
|
describe('given not showing archive with archived conversation', () => {
|
2020-10-19 19:16:27 +00:00
|
|
|
it('returns an archive button last', () => {
|
|
|
|
const leftPane = new LeftPane({
|
2020-10-13 18:59:30 +00:00
|
|
|
...defaultProps,
|
|
|
|
archivedConversations: [
|
|
|
|
{
|
|
|
|
id: 'jerry-convo',
|
|
|
|
isSelected: false,
|
|
|
|
lastUpdated: Date.now(),
|
2020-10-28 22:54:32 +00:00
|
|
|
markedUnread: false,
|
2020-10-13 18:59:30 +00:00
|
|
|
title: 'Jerry Jordan',
|
|
|
|
type: 'direct',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
conversations: [
|
|
|
|
{
|
|
|
|
id: 'fred-convo',
|
|
|
|
isSelected: false,
|
|
|
|
lastUpdated: Date.now(),
|
2020-10-28 22:54:32 +00:00
|
|
|
markedUnread: false,
|
2020-10-13 18:59:30 +00:00
|
|
|
title: 'Fred Willard',
|
|
|
|
type: 'direct',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
showArchived: false,
|
2020-10-19 19:16:27 +00:00
|
|
|
});
|
2020-10-13 18:59:30 +00:00
|
|
|
|
2020-10-19 19:16:27 +00:00
|
|
|
assert.deepEqual(leftPane.getRowFromIndex(1), {
|
2020-10-13 18:59:30 +00:00
|
|
|
type: RowType.ArchiveButton,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
|
|
|
|
describe('given showing archive and archive chats', () => {
|
2020-10-19 19:16:27 +00:00
|
|
|
it('returns archived conversations', () => {
|
|
|
|
const leftPane = new LeftPane({
|
2020-10-13 18:59:30 +00:00
|
|
|
...defaultProps,
|
|
|
|
archivedConversations: [
|
|
|
|
{
|
|
|
|
id: 'fred-convo',
|
|
|
|
isSelected: false,
|
|
|
|
lastUpdated: Date.now(),
|
2020-10-28 22:54:32 +00:00
|
|
|
markedUnread: false,
|
2020-10-13 18:59:30 +00:00
|
|
|
title: 'Fred Willard',
|
|
|
|
type: 'direct',
|
|
|
|
},
|
|
|
|
],
|
|
|
|
showArchived: true,
|
2020-10-19 19:16:27 +00:00
|
|
|
});
|
2020-10-13 18:59:30 +00:00
|
|
|
|
2020-10-19 19:16:27 +00:00
|
|
|
assert.deepEqual(leftPane.getRowFromIndex(0), {
|
2020-10-13 18:59:30 +00:00
|
|
|
index: 0,
|
|
|
|
type: RowType.ArchivedConversation,
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|
|
|
|
});
|