RocketChat/Rocket.Chat

View on GitHub
packages/ui-video-conf/src/VideoConfMessage/VideoConfMessage.stories.tsx

Summary

Maintainability
D
1 day
Test Coverage
import { MessageDivider, Message, Avatar, Box } from '@rocket.chat/fuselage';
import type { ComponentMeta, ComponentStory } from '@storybook/react';
import type { ReactElement } from 'react';

import '@rocket.chat/icons/dist/rocketchat.css';
import { VideoConfMessage, VideoConfMessageIcon, VideoConfMessageRow, VideoConfMessageText } from '.';
import VideoConfMessageAction from './VideoConfMessageAction';
import VideoConfMessageActions from './VideoConfMessageActions';
import VideoConfMessageButton from './VideoConfMessageButton';
import VideoConfMessageContent from './VideoConfMessageContent';
import VideoConfMessageFooter from './VideoConfMessageFooter';
import VideoConfMessageFooterText from './VideoConfMessageFooterText';
import VideoConfMessageSkeleton from './VideoConfMessageSkeleton';
import VideoConfMessageUserStack from './VideoConfMessageUserStack';

export default {
    title: 'Components/VideoConfMessage',
    component: VideoConfMessage,
    decorators: [
        (Story): ReactElement => (
            <Box>
                <MessageDivider>May, 24, 2020</MessageDivider>
                <Message className='customclass'>
                    <Message.LeftContainer>
                        <Avatar url={avatarUrl} size='x36' />
                    </Message.LeftContainer>
                    <Message.Container>
                        <Message.Header>
                            <Message.Name>Haylie George</Message.Name>
                            <Message.Username>@haylie.george</Message.Username>
                            <Message.Role>Admin</Message.Role>
                            <Message.Role>User</Message.Role>
                            <Message.Role>Owner</Message.Role>
                            <Message.Timestamp>12:00 PM</Message.Timestamp>
                        </Message.Header>
                        <Message.Body>
                            <Story />
                        </Message.Body>
                    </Message.Container>
                </Message>
            </Box>
        ),
    ],
} as ComponentMeta<typeof VideoConfMessage>;

const avatarUrl =
    '';

export const CallingDM: ComponentStory<typeof VideoConfMessage> = () => (
    <VideoConfMessage>
        <VideoConfMessageRow>
            <VideoConfMessageContent>
                <VideoConfMessageIcon variant='incoming' />
                <VideoConfMessageText>Calling...</VideoConfMessageText>
            </VideoConfMessageContent>
            <VideoConfMessageActions>
                <VideoConfMessageAction icon='info' />
            </VideoConfMessageActions>
        </VideoConfMessageRow>
        <VideoConfMessageFooter>
            <VideoConfMessageButton primary>Join</VideoConfMessageButton>
            <VideoConfMessageFooterText>Waiting for answer</VideoConfMessageFooterText>
        </VideoConfMessageFooter>
    </VideoConfMessage>
);

export const CallEndedDM: ComponentStory<typeof VideoConfMessage> = () => (
    <VideoConfMessage>
        <VideoConfMessageRow>
            <VideoConfMessageContent>
                <VideoConfMessageIcon />
                <VideoConfMessageText>Call ended</VideoConfMessageText>
            </VideoConfMessageContent>
            <VideoConfMessageActions>
                <VideoConfMessageAction icon='info' />
            </VideoConfMessageActions>
        </VideoConfMessageRow>
        <VideoConfMessageFooter>
            <VideoConfMessageButton>Call Back</VideoConfMessageButton>
            <VideoConfMessageFooterText>Call was not answered</VideoConfMessageFooterText>
        </VideoConfMessageFooter>
    </VideoConfMessage>
);

export const CallOngoing: ComponentStory<typeof VideoConfMessage> = () => (
    <VideoConfMessage>
        <VideoConfMessageRow>
            <VideoConfMessageContent>
                <VideoConfMessageIcon variant='outgoing' />
                <VideoConfMessageText>Call ongoing</VideoConfMessageText>
            </VideoConfMessageContent>
            <VideoConfMessageActions>
                <VideoConfMessageAction icon='info' />
            </VideoConfMessageActions>
        </VideoConfMessageRow>
        <VideoConfMessageFooter>
            <VideoConfMessageButton primary>Join</VideoConfMessageButton>
            <VideoConfMessageUserStack users={Array(3).fill('')} />
            <VideoConfMessageFooterText>Joined</VideoConfMessageFooterText>
        </VideoConfMessageFooter>
    </VideoConfMessage>
);

export const CallEnded: ComponentStory<typeof VideoConfMessage> = () => (
    <VideoConfMessage>
        <VideoConfMessageRow>
            <VideoConfMessageContent>
                <VideoConfMessageIcon />
                <VideoConfMessageText>Call ended</VideoConfMessageText>
            </VideoConfMessageContent>
            <VideoConfMessageActions>
                <VideoConfMessageAction icon='info' />
            </VideoConfMessageActions>
        </VideoConfMessageRow>
        <VideoConfMessageFooter>
            <VideoConfMessageUserStack users={Array(3).fill('')} />
            <VideoConfMessageFooterText>Joined</VideoConfMessageFooterText>
        </VideoConfMessageFooter>
    </VideoConfMessage>
);

export const Loading: ComponentStory<typeof VideoConfMessage> = () => <VideoConfMessageSkeleton />;