58 lines
1.3 KiB
TypeScript
58 lines
1.3 KiB
TypeScript
|
// Copyright 2023 Signal Messenger, LLC
|
||
|
// SPDX-License-Identifier: AGPL-3.0-only
|
||
|
|
||
|
import React, { useState } from 'react';
|
||
|
import { action } from '@storybook/addon-actions';
|
||
|
import { CompositionRecording } from './CompositionRecording';
|
||
|
|
||
|
import { setupI18n } from '../util/setupI18n';
|
||
|
import enMessages from '../../_locales/en/messages.json';
|
||
|
|
||
|
const i18n = setupI18n('en', enMessages);
|
||
|
|
||
|
export default {
|
||
|
title: 'components/CompositionRecording',
|
||
|
component: CompositionRecording,
|
||
|
};
|
||
|
|
||
|
export function Default(): JSX.Element {
|
||
|
const [active, setActive] = useState(false);
|
||
|
|
||
|
const cancel = action('cancel');
|
||
|
const send = action('send');
|
||
|
|
||
|
const handleActivate = () => {
|
||
|
setActive(true);
|
||
|
};
|
||
|
|
||
|
const handleCancel = () => {
|
||
|
cancel();
|
||
|
setActive(false);
|
||
|
};
|
||
|
const handleSend = () => {
|
||
|
send();
|
||
|
setActive(false);
|
||
|
};
|
||
|
|
||
|
return (
|
||
|
<>
|
||
|
{!active && (
|
||
|
<button type="button" onClick={handleActivate}>
|
||
|
Activate
|
||
|
</button>
|
||
|
)}
|
||
|
{active && (
|
||
|
<CompositionRecording
|
||
|
i18n={i18n}
|
||
|
conversationId="convo-id"
|
||
|
onCancel={handleCancel}
|
||
|
onSend={handleSend}
|
||
|
errorRecording={_ => action('error')()}
|
||
|
addAttachment={action('addAttachment')}
|
||
|
completeRecording={action('completeRecording')}
|
||
|
/>
|
||
|
)}
|
||
|
</>
|
||
|
);
|
||
|
}
|