interface: get edit closer

This commit is contained in:
Logan Allen 2021-01-26 15:41:50 -06:00
parent 683df1b9a4
commit f5e623b04a
2 changed files with 19 additions and 41 deletions

View File

@ -2,7 +2,10 @@ import React from "react";
import * as Yup from "yup";
import {
ManagedForm as Form,
ManagedTextInputField as Input,
Center,
Col,
Box,
Text,
Row,
@ -21,7 +24,8 @@ import { ImageInput } from "~/views/components/ImageInput";
const formSchema = Yup.object({
nickname: Yup.string(),
bio: Yup.string(),
color: Yup.string()
color: Yup.string(),
avatar: Yup.string().nullable()
});
const emptyContact = {
@ -58,19 +62,10 @@ export function EditProfile(props: any) {
await Object.keys(values).reduce((acc, key) => {
const newValue = key !== "color" ? values[key] : uxToHex(values[key]);
if (newValue !== contact[key]) {
if (key === "avatar") {
return acc.then(() =>
props.api.contacts.edit(props.path, us, {
avatar: { url: newValue },
} as any)
);
}
if (newValue !== contact[key]) {
return acc.then(() =>
props.api.contacts.edit(props.path, us, {
[key]: newValue,
} as any)
props.api.contacts.edit(ship, { [key]: newValue })
);
}
return acc;
@ -90,36 +85,19 @@ export function EditProfile(props: any) {
initialValues={contact || emptyContact}
onSubmit={onSubmit}
>
<Form
display="grid"
gridAutoRows="auto"
gridTemplateColumns="100%"
gridRowGap="5"
maxWidth="400px"
width="100%"
>
<Row
borderBottom={1}
borderBottomColor="washedGray"
pb={3}
alignItems="center"
>
<Box height='32px' width='32px'>
{image}
</Box>
<Box ml={2}>
<Text mono={!Boolean(nickname)}>{nickname}</Text>
</Box>
</Row>
<ImageInput id="avatar" label="Avatar" s3={props.s3} />
<Form width="100%" p={2}>
<Input id="nickname" label="Name" mb={3} />
<Input id="bio" label="Description" mb={3} />
<Row mb={3} width="100%">
<Col pr={2} width="40%">
<ColorInput id="color" label="Sigil Color" />
<Input id="nickname" label="Nickname" />
<Input id="bio" label="Email" />
<Input id="phone" label="Phone" />
<Input id="website" label="Website" />
<Input id="notes" label="Notes" />
</Col>
<Col pl={2} width="60%">
<ImageInput id="avatar" label="Profile Picture" s3={props.s3} />
</Col>
</Row>
<AsyncButton primary loadingText="Updating..." border>
{(contact) ? "Save" : "Share Contact"}
Submit
</AsyncButton>
</Form>
</Formik>

View File

@ -55,7 +55,7 @@ export function Profile(props: any) {
</Center>
</Row>
{ isEdit ? (
<EditProfile ship={ship} contact={contact} />
<EditProfile ship={ship} contact={contact} s3={props.s3} />
) : (
<ViewProfile ship={ship} contact={contact} />
) }