signal-desktop/ts/components/MediaPermissionsModal.stories.tsx

45 lines
1.4 KiB
TypeScript
Raw Normal View History

// Copyright 2025 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import React, { StrictMode } from 'react';
import { action } from '@storybook/addon-actions';
import enMessages from '../../_locales/en/messages.json';
import { type ComponentMeta } from '../storybook/types';
import { setupI18n } from '../util/setupI18n';
import type { PropsType } from './MediaPermissionsModal';
import { MediaPermissionsModal } from './MediaPermissionsModal';
const i18n = setupI18n('en', enMessages);
type TemplateProps = Omit<PropsType, 'i18n' | 'children'>;
function Template(props: TemplateProps) {
return (
<StrictMode>
<MediaPermissionsModal i18n={i18n} {...props} />
</StrictMode>
);
}
export default {
title: 'Components/MediaPermissionsModal',
component: Template,
args: {
mediaType: 'camera',
requestor: 'call',
openSystemMediaPermissions: action('onOpenSystemMediaPermissions'),
onClose: action('onClose'),
},
} satisfies ComponentMeta<TemplateProps>;
export function Camera(props: TemplateProps): JSX.Element {
return <Template {...props} mediaType="camera" />;
}
export function Microphone(props: TemplateProps): JSX.Element {
return <Template {...props} mediaType="microphone" />;
}
export function VoiceNote(props: TemplateProps): JSX.Element {
return <Template {...props} requestor="voiceNote" mediaType="microphone" />;
}