// Copyright 2020 Signal Messenger, LLC // SPDX-License-Identifier: AGPL-3.0-only import * as React from 'react'; import { noop } from 'lodash'; import { storiesOf } from '@storybook/react'; import { boolean } from '@storybook/addon-knobs'; import { action } from '@storybook/addon-actions'; import { ColorType } from '../types/Colors'; import { ConversationTypeType } from '../state/ducks/conversations'; import { CallingPip, PropsType } from './CallingPip'; import { ActiveCallType, CallMode, CallState, GroupCallConnectionState, GroupCallJoinState, } from '../types/Calling'; import { setup as setupI18n } from '../../js/modules/i18n'; import enMessages from '../../_locales/en/messages.json'; const i18n = setupI18n('en', enMessages); const conversation = { id: '3051234567', avatarPath: undefined, color: 'ultramarine' as ColorType, title: 'Rick Sanchez', name: 'Rick Sanchez', phoneNumber: '3051234567', profileName: 'Rick Sanchez', markedUnread: false, type: 'direct' as ConversationTypeType, lastUpdated: Date.now(), }; const getCommonActiveCallData = () => ({ conversation, hasLocalAudio: boolean('hasLocalAudio', true), hasLocalVideo: boolean('hasLocalVideo', false), joinedAt: Date.now(), pip: true, settingsDialogOpen: false, showParticipantsList: false, }); const defaultCall: ActiveCallType = { ...getCommonActiveCallData(), callMode: CallMode.Direct as CallMode.Direct, callState: CallState.Accepted, peekedParticipants: [], remoteParticipants: [{ hasRemoteVideo: true }], }; const createProps = (overrideProps: Partial = {}): PropsType => ({ activeCall: overrideProps.activeCall || defaultCall, // eslint-disable-next-line @typescript-eslint/no-explicit-any getGroupCallVideoFrameSource: noop as any, hangUp: action('hang-up'), hasLocalVideo: boolean('hasLocalVideo', overrideProps.hasLocalVideo || false), i18n, setGroupCallVideoRequest: action('set-group-call-video-request'), setLocalPreview: action('set-local-preview'), setRendererCanvas: action('set-renderer-canvas'), togglePip: action('toggle-pip'), }); const story = storiesOf('Components/CallingPip', module); story.add('Default', () => { const props = createProps({}); return ; }); story.add('Contact (with avatar)', () => { const props = createProps({ activeCall: { ...defaultCall, conversation: { ...conversation, avatarPath: 'https://www.fillmurray.com/64/64', }, }, }); return ; }); story.add('Contact (no color)', () => { const props = createProps({ activeCall: { ...defaultCall, conversation: { ...conversation, color: undefined, }, }, }); return ; }); story.add('Group Call', () => { const props = createProps({ activeCall: { ...getCommonActiveCallData(), callMode: CallMode.Group as CallMode.Group, connectionState: GroupCallConnectionState.Connected, conversationsWithSafetyNumberChanges: [], joinState: GroupCallJoinState.Joined, maxDevices: 5, deviceCount: 0, peekedParticipants: [], remoteParticipants: [], }, }); return ; });