2023-03-28 20:31:24 +00:00
|
|
|
// Copyright 2023 Signal Messenger, LLC
|
|
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
|
|
|
|
import React, { useState, useEffect, useMemo } from 'react';
|
|
|
|
import type { Meta, Story } from '@storybook/react';
|
|
|
|
import { noop } from 'lodash';
|
|
|
|
|
|
|
|
import { Inbox } from './Inbox';
|
|
|
|
import type { PropsType } from './Inbox';
|
|
|
|
import { DAY, SECOND } from '../util/durations';
|
|
|
|
|
|
|
|
import { setupI18n } from '../util/setupI18n';
|
|
|
|
import enMessages from '../../_locales/en/messages.json';
|
|
|
|
|
|
|
|
const i18n = setupI18n('en', enMessages);
|
|
|
|
|
|
|
|
export default {
|
|
|
|
title: 'Components/Inbox',
|
|
|
|
argTypes: {
|
|
|
|
i18n: {
|
|
|
|
defaultValue: i18n,
|
|
|
|
},
|
|
|
|
hasInitialLoadCompleted: {
|
|
|
|
defaultValue: false,
|
|
|
|
},
|
|
|
|
daysAgo: {
|
|
|
|
control: 'select',
|
|
|
|
defaultValue: undefined,
|
|
|
|
options: [undefined, 1, 2, 3, 7, 14, 21],
|
|
|
|
},
|
|
|
|
isCustomizingPreferredReactions: {
|
|
|
|
defaultValue: false,
|
|
|
|
},
|
|
|
|
onConversationClosed: {
|
|
|
|
action: true,
|
|
|
|
},
|
|
|
|
onConversationOpened: {
|
|
|
|
action: true,
|
|
|
|
},
|
|
|
|
scrollToMessage: {
|
|
|
|
action: true,
|
|
|
|
},
|
|
|
|
showConversation: {
|
|
|
|
action: true,
|
|
|
|
},
|
|
|
|
showWhatsNewModal: {
|
|
|
|
action: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
} as Meta;
|
|
|
|
|
|
|
|
// eslint-disable-next-line react/function-component-definition
|
|
|
|
const Template: Story<PropsType & { daysAgo?: number }> = ({
|
|
|
|
daysAgo,
|
|
|
|
...args
|
|
|
|
}) => {
|
|
|
|
const now = useMemo(() => Date.now(), []);
|
2023-03-29 16:47:06 +00:00
|
|
|
const [dayOffset, setDayOffset] = useState(0);
|
2023-03-28 20:31:24 +00:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (daysAgo === undefined) {
|
2023-03-29 16:47:06 +00:00
|
|
|
setDayOffset(0);
|
2023-03-28 20:31:24 +00:00
|
|
|
return noop;
|
|
|
|
}
|
|
|
|
|
|
|
|
const interval = setInterval(() => {
|
2023-03-29 16:47:06 +00:00
|
|
|
// Increment day offset by 1 / 24 of a day (an hour), and wrap it when it
|
|
|
|
// reaches `daysAgo` value.
|
|
|
|
setDayOffset(prevValue => (prevValue + 1 / 24) % daysAgo);
|
2023-03-28 20:31:24 +00:00
|
|
|
}, SECOND / 10);
|
|
|
|
|
|
|
|
return () => clearInterval(interval);
|
|
|
|
}, [now, daysAgo]);
|
|
|
|
|
|
|
|
const firstEnvelopeTimestamp =
|
|
|
|
daysAgo === undefined ? undefined : now - daysAgo * DAY;
|
|
|
|
const envelopeTimestamp =
|
|
|
|
firstEnvelopeTimestamp === undefined
|
|
|
|
? undefined
|
2023-03-29 16:47:06 +00:00
|
|
|
: firstEnvelopeTimestamp + dayOffset * DAY;
|
2023-03-28 20:31:24 +00:00
|
|
|
|
|
|
|
return (
|
|
|
|
<Inbox
|
|
|
|
{...args}
|
|
|
|
firstEnvelopeTimestamp={firstEnvelopeTimestamp}
|
|
|
|
envelopeTimestamp={envelopeTimestamp}
|
|
|
|
renderCustomizingPreferredReactionsModal={() => <div />}
|
|
|
|
/>
|
|
|
|
);
|
|
|
|
};
|
|
|
|
|
|
|
|
export const Default = Template.bind({});
|
|
|
|
Default.story = {
|
|
|
|
name: 'Default',
|
|
|
|
};
|