// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import type { Meta } from '@storybook/react'; import { setupI18n } from '../../util/setupI18n'; import { DurationInSeconds } from '../../util/durations'; import enMessages from '../../../_locales/en/messages.json'; import type { Props } from './TimerNotification'; import { TimerNotification } from './TimerNotification'; const i18n = setupI18n('en', enMessages); export default { title: 'Components/Conversation/TimerNotification', argTypes: { type: { control: { type: 'select' }, options: ['fromOther', 'fromMe', 'fromSync'], }, disabled: { control: { type: 'boolean' } }, expireTimer: { control: { type: 'number' } }, }, args: { i18n, type: 'fromOther', title: '', disabled: false, expireTimer: DurationInSeconds.fromHours(0), }, } satisfies Meta; export function SetByOther(args: Props): JSX.Element { const props: Props = { ...args, disabled: false, expireTimer: DurationInSeconds.fromHours(1), type: 'fromOther', title: 'Mr. Fire', }; return ( <>
); } export function SetByOtherWithALongName(args: Props): JSX.Element { const longName = '🦴🧩📴'.repeat(50); const props: Props = { ...args, disabled: false, expireTimer: DurationInSeconds.fromHours(1), type: 'fromOther', title: longName, }; return ( <>
); } export function SetByYou(args: Props): JSX.Element { const props: Props = { ...args, disabled: false, expireTimer: DurationInSeconds.fromHours(1), type: 'fromMe', title: 'Mr. Fire', }; return ( <>
); } export function SetBySync(args: Props): JSX.Element { const props: Props = { ...args, disabled: false, expireTimer: DurationInSeconds.fromHours(1), type: 'fromSync', title: 'Mr. Fire', }; return ( <>
); } export function SetByUnknownContact(args: Props): JSX.Element { const props: Props = { ...args, disabled: false, expireTimer: DurationInSeconds.fromHours(1), type: 'fromMember', title: 'Unknown contact', }; return ( <>
); }