// 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: [ UsernameEditState.Editing, UsernameEditState.ConfirmingDelete, UsernameEditState.Deleting, ], }, usernameCorrupted: { control: 'boolean', }, usernameLinkState: { control: { type: 'select' }, options: [UsernameLinkState.Ready, UsernameLinkState.Updating], }, usernameLinkCorrupted: { control: 'boolean', }, }, args: { aboutEmoji: '', aboutText: casual.sentence, profileAvatarUrl: 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; function renderEditUsernameModalBody(props: { isRootModal: boolean; onClose: () => void; }): JSX.Element { return ( ); } // eslint-disable-next-line react/function-component-definition const Template: StoryFn = args => { const [skinTone, setSkinTone] = useState(0); return ( ); }; export const FullSet = Template.bind({}); FullSet.args = { aboutEmoji: '🙏', aboutText: 'Live. Laugh. Love', familyName: casual.last_name, firstName: casual.first_name, profileAvatarUrl: '/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, };