* feat: no atomic * feat: update front not atomic operations * feat: optional fields for person model & use proper gql type * Fix bug display name * Fix bug update user * Fixed bug avatar URL * Fixed display name on people cell * Fix lint * Fixed storybook display name * Fix storybook requests --------- Co-authored-by: Lucas Bordeau <bordeau.lucas@gmail.com>
82 lines
2.1 KiB
TypeScript
82 lines
2.1 KiB
TypeScript
import { useEffect, useState } from 'react';
|
|
|
|
import { EditableField } from '@/ui/editable-field/components/EditableField';
|
|
import { FieldContext } from '@/ui/editable-field/states/FieldContext';
|
|
import { IconUsers } from '@/ui/icon';
|
|
import { InplaceInputText } from '@/ui/inplace-input/components/InplaceInputText';
|
|
import { RecoilScope } from '@/ui/recoil-scope/components/RecoilScope';
|
|
import { Company, useUpdateOneCompanyMutation } from '~/generated/graphql';
|
|
|
|
type OwnProps = {
|
|
company: Pick<Company, 'id' | 'employees'>;
|
|
};
|
|
|
|
export function CompanyEmployeesEditableField({ company }: OwnProps) {
|
|
const [internalValue, setInternalValue] = useState(
|
|
company.employees?.toString(),
|
|
);
|
|
|
|
const [updateCompany] = useUpdateOneCompanyMutation();
|
|
|
|
useEffect(() => {
|
|
setInternalValue(company.employees?.toString());
|
|
}, [company.employees]);
|
|
|
|
async function handleChange(newValue: string) {
|
|
setInternalValue(newValue);
|
|
}
|
|
|
|
async function handleSubmit() {
|
|
if (!internalValue) return;
|
|
|
|
try {
|
|
const numberValue = parseInt(internalValue);
|
|
|
|
if (isNaN(numberValue)) {
|
|
throw new Error('Not a number');
|
|
}
|
|
|
|
await updateCompany({
|
|
variables: {
|
|
where: {
|
|
id: company.id,
|
|
},
|
|
data: {
|
|
employees: numberValue,
|
|
},
|
|
},
|
|
});
|
|
|
|
setInternalValue(numberValue.toString());
|
|
} catch {
|
|
handleCancel();
|
|
}
|
|
}
|
|
|
|
async function handleCancel() {
|
|
setInternalValue(company.employees?.toString());
|
|
}
|
|
|
|
return (
|
|
<RecoilScope SpecificContext={FieldContext}>
|
|
<EditableField
|
|
onSubmit={handleSubmit}
|
|
onCancel={handleCancel}
|
|
iconLabel={<IconUsers />}
|
|
editModeContent={
|
|
<InplaceInputText
|
|
placeholder={'Employees'}
|
|
autoFocus
|
|
value={internalValue ?? ''}
|
|
onChange={(newValue: string) => {
|
|
handleChange(newValue);
|
|
}}
|
|
/>
|
|
}
|
|
displayModeContent={internalValue}
|
|
isDisplayModeContentEmpty={!(internalValue && internalValue !== '0')}
|
|
/>
|
|
</RecoilScope>
|
|
);
|
|
}
|