// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import React, { useContext } from 'react'; import { action } from '@storybook/addon-actions'; import type { Meta } from '@storybook/react'; import { IMAGE_JPEG } from '../types/MIME'; import type { Props } from './CompositionArea'; import { CompositionArea } from './CompositionArea'; import { setupI18n } from '../util/setupI18n'; import enMessages from '../../_locales/en/messages.json'; import { StorybookThemeContext } from '../../.storybook/StorybookThemeContext'; import { fakeDraftAttachment } from '../test-both/helpers/fakeAttachment'; import { landscapeGreenUrl } from '../storybook/Fixtures'; import { RecordingState } from '../types/AudioRecorder'; import { ConversationColors } from '../types/Colors'; import { getDefaultConversation } from '../test-both/helpers/getDefaultConversation'; import { PaymentEventKind } from '../types/Payment'; const i18n = setupI18n('en', enMessages); export default { title: 'Components/CompositionArea', decorators: [ // necessary for the add attachment button to render properly storyFn =>
{storyFn()}
, ], argTypes: { recordingState: { control: { type: 'select' }, options: Object.keys(RecordingState), mappings: RecordingState, }, announcementsOnly: { control: { type: 'boolean' } }, areWePendingApproval: { control: { type: 'boolean' } }, }, args: { addAttachment: action('addAttachment'), conversationId: '123', convertDraftBodyRangesIntoHydrated: () => undefined, discardEditMessage: action('discardEditMessage'), focusCounter: 0, sendCounter: 0, i18n, isDisabled: false, isFormattingEnabled: true, messageCompositionId: '456', sendEditedMessage: action('sendEditedMessage'), sendMultiMediaMessage: action('sendMultiMediaMessage'), platform: 'darwin', processAttachments: action('processAttachments'), removeAttachment: action('removeAttachment'), setComposerFocus: action('setComposerFocus'), setMessageToEdit: action('setMessageToEdit'), setQuoteByMessageId: action('setQuoteByMessageId'), showToast: action('showToast'), // AttachmentList draftAttachments: [], onClearAttachments: action('onClearAttachments'), // AudioCapture cancelRecording: action('cancelRecording'), completeRecording: action('completeRecording'), errorRecording: action('errorRecording'), recordingState: RecordingState.Idle, startRecording: action('startRecording'), // StagedLinkPreview linkPreviewLoading: false, linkPreviewResult: undefined, onCloseLinkPreview: action('onCloseLinkPreview'), // Quote quotedMessageProps: undefined, scrollToMessage: action('scrollToMessage'), // MediaEditor imageToBlurHash: async () => 'LDA,FDBnm+I=p{tkIUI;~UkpELV]', // MediaQualitySelector setMediaQualitySetting: action('setMediaQualitySetting'), shouldSendHighQualityAttachments: false, // CompositionInput onEditorStateChange: action('onEditorStateChange'), onTextTooLong: action('onTextTooLong'), draftText: undefined, clearQuotedMessage: action('clearQuotedMessage'), getPreferredBadge: () => undefined, getQuotedMessage: action('getQuotedMessage'), sortedGroupMembers: [], // EmojiButton onPickEmoji: action('onPickEmoji'), onSetSkinTone: action('onSetSkinTone'), recentEmojis: [], skinTone: 1, // StickerButton knownPacks: [], receivedPacks: [], installedPacks: [], blessedPacks: [], recentStickers: [], clearInstalledStickerPack: action('clearInstalledStickerPack'), pushPanelForConversation: action('pushPanelForConversation'), sendStickerMessage: action('sendStickerMessage'), clearShowIntroduction: action('clearShowIntroduction'), showPickerHint: false, clearShowPickerHint: action('clearShowPickerHint'), // Message Requests conversationType: 'direct', acceptConversation: action('acceptConversation'), blockConversation: action('blockConversation'), blockAndReportSpam: action('blockAndReportSpam'), deleteConversation: action('deleteConversation'), conversationName: getDefaultConversation(), // GroupV1 Disabled Actions showGV2MigrationDialog: action('showGV2MigrationDialog'), // GroupV2 announcementsOnly: false, areWeAdmin: false, areWePendingApproval: false, groupAdmins: [], cancelJoinRequest: action('cancelJoinRequest'), showConversation: action('showConversation'), // SMS-only isSMSOnly: false, isFetchingUUID: false, renderSmartCompositionRecording: _ =>
RECORDING
, renderSmartCompositionRecordingDraft: _ =>
RECORDING DRAFT
, // Select mode selectedMessageIds: undefined, toggleSelectMode: action('toggleSelectMode'), toggleForwardMessagesModal: action('toggleForwardMessagesModal'), }, } satisfies Meta; export function Default(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ; } export function StartingText(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ( ); } export function StickerButton(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ( ); } export function MessageRequest(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ; } export function SmsOnlyFetchingUuid(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ; } export function SmsOnly(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ; } export function Attachments(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ( ); } export function PendingApproval(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ; } export function AnnouncementsOnlyGroup(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ( ); } export function Quote(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ( ); } export function QuoteWithPayment(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ( ); } export function NoFormattingMenu(args: Props): JSX.Element { const theme = useContext(StorybookThemeContext); return ( ); }