// Copyright 2020-2022 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import { action } from '@storybook/addon-actions'; import { setupI18n } from '../../../util/setupI18n'; import enMessages from '../../../../_locales/en/messages.json'; import { createPreparedMediaItems, createRandomDocuments, createRandomMedia, days, now, } from './AttachmentSection.stories'; import type { Props } from './MediaGallery'; import { MediaGallery } from './MediaGallery'; const i18n = setupI18n('en', enMessages); export default { title: 'Components/Conversation/MediaGallery/MediaGallery', }; const createProps = (overrideProps: Partial = {}): Props => ({ conversationId: '123', documents: overrideProps.documents || [], i18n, loadMediaItems: action('loadMediaItems'), media: overrideProps.media || [], saveAttachment: action('saveAttachment'), showLightboxWithMedia: action('showLightboxWithMedia'), }); export function Populated(): JSX.Element { const documents = createRandomDocuments(now, days(1)).slice(0, 1); const media = createPreparedMediaItems(createRandomMedia); const props = createProps({ documents, media }); return ; } export function NoDocuments(): JSX.Element { const media = createPreparedMediaItems(createRandomMedia); const props = createProps({ media }); return ; } export function NoMedia(): JSX.Element { const documents = createPreparedMediaItems(createRandomDocuments); const props = createProps({ documents }); return ; } export function OneEach(): JSX.Element { const media = createRandomMedia(now, days(1)).slice(0, 1); const documents = createRandomDocuments(now, days(1)).slice(0, 1); const props = createProps({ documents, media }); return ; } export function Empty(): JSX.Element { const props = createProps(); return ; }