168 lines
4.8 KiB
TypeScript
168 lines
4.8 KiB
TypeScript
// Copyright 2021 Signal Messenger, LLC
|
|
// SPDX-License-Identifier: AGPL-3.0-only
|
|
|
|
import type { Meta, StoryFn } from '@storybook/react';
|
|
import { action } from '@storybook/addon-actions';
|
|
import React, { useState } from 'react';
|
|
import casual from 'casual';
|
|
import { v4 as generateUuid } from 'uuid';
|
|
|
|
import type { PropsType } from './ProfileEditor';
|
|
import enMessages from '../../_locales/en/messages.json';
|
|
import { ProfileEditor } from './ProfileEditor';
|
|
import { EditUsernameModalBody } from './EditUsernameModalBody';
|
|
import {
|
|
UsernameEditState,
|
|
UsernameLinkState,
|
|
UsernameReservationState,
|
|
} from '../state/ducks/usernameEnums';
|
|
import { getRandomColor } from '../test-both/helpers/getRandomColor';
|
|
import { setupI18n } from '../util/setupI18n';
|
|
import { SignalService as Proto } from '../protobuf';
|
|
|
|
const i18n = setupI18n('en', enMessages);
|
|
|
|
export default {
|
|
component: ProfileEditor,
|
|
title: 'Components/ProfileEditor',
|
|
argTypes: {
|
|
usernameEditState: {
|
|
control: { type: 'radio' },
|
|
options: {
|
|
Editing: UsernameEditState.Editing,
|
|
ConfirmingDelete: UsernameEditState.ConfirmingDelete,
|
|
Deleting: UsernameEditState.Deleting,
|
|
},
|
|
},
|
|
usernameCorrupted: {
|
|
control: 'boolean',
|
|
},
|
|
usernameLinkState: {
|
|
control: { type: 'select' },
|
|
options: [UsernameLinkState.Ready, UsernameLinkState.Updating],
|
|
},
|
|
usernameLinkCorrupted: {
|
|
control: 'boolean',
|
|
},
|
|
isUsernameDeletionEnabled: {
|
|
control: 'boolean',
|
|
},
|
|
},
|
|
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,
|
|
isUsernameDeletionEnabled: true,
|
|
|
|
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>;
|
|
|
|
function renderEditUsernameModalBody(props: {
|
|
isRootModal: boolean;
|
|
onClose: () => void;
|
|
}): JSX.Element {
|
|
return (
|
|
<EditUsernameModalBody
|
|
i18n={i18n}
|
|
minNickname={3}
|
|
maxNickname={20}
|
|
state={UsernameReservationState.Open}
|
|
error={undefined}
|
|
recoveredUsername={undefined}
|
|
usernameCorrupted={false}
|
|
setUsernameReservationError={action('setUsernameReservationError')}
|
|
clearUsernameReservation={action('clearUsernameReservation')}
|
|
reserveUsername={action('reserveUsername')}
|
|
confirmUsername={action('confirmUsername')}
|
|
showToast={action('showToast')}
|
|
{...props}
|
|
/>
|
|
);
|
|
}
|
|
|
|
// eslint-disable-next-line react/function-component-definition
|
|
const Template: StoryFn<PropsType> = args => {
|
|
const [skinTone, setSkinTone] = useState(0);
|
|
|
|
return (
|
|
<ProfileEditor
|
|
{...args}
|
|
skinTone={skinTone}
|
|
onSetSkinTone={setSkinTone}
|
|
renderEditUsernameModalBody={renderEditUsernameModalBody}
|
|
/>
|
|
);
|
|
};
|
|
|
|
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',
|
|
};
|
|
|
|
export const WithFullName = Template.bind({});
|
|
WithFullName.args = {
|
|
familyName: casual.last_name,
|
|
};
|
|
export const WithCustomAbout = Template.bind({});
|
|
WithCustomAbout.args = {
|
|
aboutEmoji: '🙏',
|
|
aboutText: 'Live. Laugh. Love',
|
|
};
|
|
|
|
export const WithUsername = Template.bind({});
|
|
WithUsername.args = {
|
|
username: 'signaluser.123',
|
|
};
|
|
|
|
export const DeletingUsername = Template.bind({});
|
|
DeletingUsername.args = {
|
|
username: 'signaluser.123',
|
|
usernameEditState: UsernameEditState.Deleting,
|
|
};
|
|
|
|
export const ConfirmingDelete = Template.bind({});
|
|
ConfirmingDelete.args = {
|
|
username: 'signaluser.123',
|
|
usernameEditState: UsernameEditState.ConfirmingDelete,
|
|
};
|
|
|
|
export const Corrupted = Template.bind({});
|
|
Corrupted.args = {
|
|
username: 'signaluser.123',
|
|
usernameCorrupted: true,
|
|
};
|