RocketChat/Rocket.Chat

View on GitHub
apps/meteor/client/components/UserCard/UserCard.stories.tsx

Summary

Maintainability
A
0 mins
Test Coverage
import type { ComponentMeta, ComponentStory } from '@storybook/react';
import React from 'react';

import { UserCard, UserCardRole, UserCardAction } from '.';

export default {
    title: 'Components/UserCard',
    component: UserCard,
    parameters: {
        layout: 'centered',
    },
    args: {
        name: 'guilherme.gazzo',
        customStatus: '🛴 currently working on User Card',
        roles: (
            <>
                <UserCardRole>Admin</UserCardRole>
                <UserCardRole>Rocket.Chat</UserCardRole>
                <UserCardRole>Team</UserCardRole>
            </>
        ),
        bio: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Nulla tempus, eros convallis vulputate cursus, nisi neque eleifend libero, eget lacinia justo purus nec est. In at sodales ipsum. Sed lacinia quis purus eget pulvinar. Aenean eu pretium nunc, at aliquam magna. Praesent dignissim, tortor sed volutpat mattis, mauris diam pulvinar leo, porta commodo risus est non purus. Mauris in justo vel lorem ullamcorper hendrerit. Nam est metus, viverra a pellentesque vitae, ornare eget odio. Morbi tempor feugiat mattis. Morbi non felis tempor, aliquam justo sed, sagittis nibh. Mauris consequat ex metus. Praesent sodales sit amet nibh a vulputate. Integer commodo, mi vel bibendum sollicitudin, urna lectus accumsan ante, eget faucibus augue ex id neque. Aenean consectetur, orci a pellentesque mattis, tortor tellus fringilla elit, non ullamcorper risus nunc feugiat risus. Fusce sit amet nisi dapibus turpis commodo placerat. In tortor ante, vehicula sit amet augue et, imperdiet porta sem.',
        actions: (
            <>
                <UserCardAction icon='message' />
                <UserCardAction icon='phone' />
            </>
        ),
        localTime: 'Local Time: 7:44 AM',
    },
} as ComponentMeta<typeof UserCard>;

const Template: ComponentStory<typeof UserCard> = (args) => <UserCard {...args} />;

export const Example = Template.bind({});

export const Nickname = Template.bind({});
Nickname.args = {
    nickname: 'nicknamenickname',
} as any;

export const LargeName = Template.bind({});
LargeName.args = {
    customStatus: '🛴 currently working on User Card  on User Card  on User Card  on User Card  on User Card ',
    name: 'guilherme.gazzo.guilherme.gazzo.guilherme.gazzo.guilherme.gazzo.guilherme.gazzo.guilherme.gazzo.guilherme.gazzo.guilherme.gazzo.',
} as any;

export const NoRoles = Template.bind({});
NoRoles.args = {
    roles: undefined,
} as any;

export const NoActions = Template.bind({});
NoActions.args = {
    actions: undefined,
} as any;

export const NoLocalTime = Template.bind({});
NoLocalTime.args = {
    localTime: undefined,
} as any;

export const NoBio = Template.bind({});
NoBio.args = {
    bio: undefined,
} as any;

export const NoBioAndNoLocalTime = Template.bind({});
NoBioAndNoLocalTime.args = {
    bio: undefined,
    localTime: undefined,
} as any;

export const NoBioNoLocalTimeNoRoles = Template.bind({});
NoBioNoLocalTimeNoRoles.args = {
    bio: undefined,
    localTime: undefined,
    roles: undefined,
} as any;

export const Loading = () => <UserCard />;