signal-desktop/ts/components/ProfileEditor.stories.tsx

165 lines
4.7 KiB
TypeScript
Raw Normal View History

2021-07-19 19:26:06 +00:00
// Copyright 2021 Signal Messenger, LLC
// SPDX-License-Identifier: AGPL-3.0-only
import type { Meta, StoryFn } from '@storybook/react';
2022-10-18 17:12:02 +00:00
import { action } from '@storybook/addon-actions';
2021-07-19 19:26:06 +00:00
import React, { useState } from 'react';
2022-07-20 21:29:09 +00:00
import casual from 'casual';
import { v4 as generateUuid } from 'uuid';
2021-07-19 19:26:06 +00:00
import type { PropsType } from './ProfileEditor';
2021-07-19 19:26:06 +00:00
import enMessages from '../../_locales/en/messages.json';
2022-07-20 21:29:09 +00:00
import { ProfileEditor } from './ProfileEditor';
2022-10-18 17:12:02 +00:00
import { EditUsernameModalBody } from './EditUsernameModalBody';
import {
UsernameEditState,
2023-07-20 03:14:08 +00:00
UsernameLinkState,
2022-10-18 17:12:02 +00:00
UsernameReservationState,
} from '../state/ducks/usernameEnums';
2022-07-20 21:29:09 +00:00
import { getRandomColor } from '../test-both/helpers/getRandomColor';
import { setupI18n } from '../util/setupI18n';
import { SignalService as Proto } from '../protobuf';
2021-07-19 19:26:06 +00:00
const i18n = setupI18n('en', enMessages);
2022-06-07 00:48:02 +00:00
export default {
2022-07-20 21:29:09 +00:00
component: ProfileEditor,
2022-06-07 00:48:02 +00:00
title: 'Components/ProfileEditor',
2022-07-20 21:29:09 +00:00
argTypes: {
2022-10-18 17:12:02 +00:00
usernameEditState: {
control: { type: 'radio' },
2024-07-08 18:23:27 +00:00
options: [
UsernameEditState.Editing,
UsernameEditState.ConfirmingDelete,
UsernameEditState.Deleting,
],
2022-10-18 17:12:02 +00:00
},
usernameCorrupted: {
control: 'boolean',
},
2023-07-20 03:14:08 +00:00
usernameLinkState: {
control: { type: 'select' },
options: [UsernameLinkState.Ready, UsernameLinkState.Updating],
},
usernameLinkCorrupted: {
control: 'boolean',
},
2022-07-20 21:29:09 +00:00
},
args: {
aboutEmoji: '',
aboutText: casual.sentence,
profileAvatarPath: undefined,
conversationId: generateUuid(),
color: getRandomColor(),
deleteAvatarFromDisk: action('deleteAvatarFromDisk'),
familyName: casual.last_name,
firstName: casual.first_name,
i18n,
usernameLink: 'https://signal.me/#eu/testtest',
usernameLinkColor: Proto.AccountRecord.UsernameLink.Color.PURPLE,
usernameEditState: UsernameEditState.Editing,
usernameLinkState: UsernameLinkState.Ready,
recentEmojis: [],
skinTone: 0,
userAvatarData: [],
username: undefined,
onEditStateChanged: action('onEditStateChanged'),
onProfileChanged: action('onProfileChanged'),
onSetSkinTone: action('onSetSkinTone'),
saveAttachment: action('saveAttachment'),
setUsernameLinkColor: action('setUsernameLinkColor'),
showToast: action('showToast'),
replaceAvatar: action('replaceAvatar'),
resetUsernameLink: action('resetUsernameLink'),
saveAvatarToDisk: action('saveAvatarToDisk'),
markCompletedUsernameLinkOnboarding: action(
'markCompletedUsernameLinkOnboarding'
),
openUsernameReservationModal: action('openUsernameReservationModal'),
setUsernameEditState: action('setUsernameEditState'),
deleteUsername: action('deleteUsername'),
},
} satisfies Meta<PropsType>;
2022-07-20 21:29:09 +00:00
2022-10-18 17:12:02 +00:00
function renderEditUsernameModalBody(props: {
2024-02-06 18:35:59 +00:00
isRootModal: boolean;
2022-10-18 17:12:02 +00:00
onClose: () => void;
}): JSX.Element {
return (
<EditUsernameModalBody
i18n={i18n}
minNickname={3}
maxNickname={20}
2022-10-18 17:12:02 +00:00
state={UsernameReservationState.Open}
error={undefined}
2024-02-06 18:35:59 +00:00
recoveredUsername={undefined}
usernameCorrupted={false}
2022-10-18 17:12:02 +00:00
setUsernameReservationError={action('setUsernameReservationError')}
clearUsernameReservation={action('clearUsernameReservation')}
2022-10-18 17:12:02 +00:00
reserveUsername={action('reserveUsername')}
confirmUsername={action('confirmUsername')}
2024-02-06 18:35:59 +00:00
showToast={action('showToast')}
2022-10-18 17:12:02 +00:00
{...props}
/>
);
}
2022-11-18 00:45:19 +00:00
// eslint-disable-next-line react/function-component-definition
const Template: StoryFn<PropsType> = args => {
2021-07-19 19:26:06 +00:00
const [skinTone, setSkinTone] = useState(0);
return (
2022-10-18 17:12:02 +00:00
<ProfileEditor
{...args}
skinTone={skinTone}
onSetSkinTone={setSkinTone}
renderEditUsernameModalBody={renderEditUsernameModalBody}
/>
2021-07-19 19:26:06 +00:00
);
2022-06-07 00:48:02 +00:00
};
2021-07-19 19:26:06 +00:00
2022-07-20 21:29:09 +00:00
export const FullSet = Template.bind({});
FullSet.args = {
aboutEmoji: '🙏',
aboutText: 'Live. Laugh. Love',
familyName: casual.last_name,
firstName: casual.first_name,
profileAvatarPath: '/fixtures/kitten-3-64-64.jpg',
};
2022-06-07 00:48:02 +00:00
2022-07-20 21:29:09 +00:00
export const WithFullName = Template.bind({});
WithFullName.args = {
familyName: casual.last_name,
};
export const WithCustomAbout = Template.bind({});
WithCustomAbout.args = {
aboutEmoji: '🙏',
aboutText: 'Live. Laugh. Love',
};
2024-02-08 00:34:31 +00:00
export const WithUsername = Template.bind({});
WithUsername.args = {
2022-10-18 17:12:02 +00:00
username: 'signaluser.123',
2022-07-20 21:29:09 +00:00
};
2022-10-18 17:12:02 +00:00
export const DeletingUsername = Template.bind({});
DeletingUsername.args = {
username: 'signaluser.123',
usernameEditState: UsernameEditState.Deleting,
2022-06-07 00:48:02 +00:00
};
2022-10-18 17:12:02 +00:00
export const ConfirmingDelete = Template.bind({});
ConfirmingDelete.args = {
username: 'signaluser.123',
usernameEditState: UsernameEditState.ConfirmingDelete,
2022-06-07 00:48:02 +00:00
};
2024-02-06 18:35:59 +00:00
export const Corrupted = Template.bind({});
Corrupted.args = {
username: 'signaluser.123',
usernameCorrupted: true,
};