* Change to using arrow functions Co-authored-by: v1b3m <vibenjamin6@gmail.com> Co-authored-by: Matheus <matheus_benini@hotmail.com> * Add lint rule --------- Co-authored-by: v1b3m <vibenjamin6@gmail.com> Co-authored-by: Matheus <matheus_benini@hotmail.com> Co-authored-by: Charles Bochet <charles@twenty.com>
63 lines
2.2 KiB
TypeScript
63 lines
2.2 KiB
TypeScript
import { useContext } from 'react';
|
|
import { isPossiblePhoneNumber } from 'react-phone-number-input';
|
|
import { useRecoilState } from 'recoil';
|
|
|
|
import { PhoneInput } from '@/ui/input/components/PhoneInput';
|
|
|
|
import { EditableFieldDefinitionContext } from '../contexts/EditableFieldDefinitionContext';
|
|
import { EditableFieldEntityIdContext } from '../contexts/EditableFieldEntityIdContext';
|
|
import { useFieldInputEventHandlers } from '../hooks/useFieldInputEventHandlers';
|
|
import { useUpdateGenericEntityField } from '../hooks/useUpdateGenericEntityField';
|
|
import { genericEntityFieldFamilySelector } from '../states/selectors/genericEntityFieldFamilySelector';
|
|
import { EditableFieldHotkeyScope } from '../types/EditableFieldHotkeyScope';
|
|
import { FieldDefinition } from '../types/FieldDefinition';
|
|
import { FieldPhoneMetadata } from '../types/FieldMetadata';
|
|
|
|
export const GenericEditablePhoneFieldEditMode = () => {
|
|
const currentEditableFieldEntityId = useContext(EditableFieldEntityIdContext);
|
|
const currentEditableFieldDefinition = useContext(
|
|
EditableFieldDefinitionContext,
|
|
) as FieldDefinition<FieldPhoneMetadata>;
|
|
|
|
// TODO: we could use a hook that would return the field value with the right type
|
|
const [fieldValue, setFieldValue] = useRecoilState<string>(
|
|
genericEntityFieldFamilySelector({
|
|
entityId: currentEditableFieldEntityId ?? '',
|
|
fieldName: currentEditableFieldDefinition
|
|
? currentEditableFieldDefinition.metadata.fieldName
|
|
: '',
|
|
}),
|
|
);
|
|
|
|
const updateField = useUpdateGenericEntityField();
|
|
|
|
const handleSubmit = (newValue: string) => {
|
|
if (!isPossiblePhoneNumber(newValue)) return;
|
|
|
|
setFieldValue(newValue);
|
|
|
|
if (currentEditableFieldEntityId && updateField) {
|
|
updateField(
|
|
currentEditableFieldEntityId,
|
|
currentEditableFieldDefinition,
|
|
newValue,
|
|
);
|
|
}
|
|
};
|
|
|
|
const { handleEnter, handleEscape, handleClickOutside } =
|
|
useFieldInputEventHandlers({
|
|
onSubmit: handleSubmit,
|
|
});
|
|
|
|
return (
|
|
<PhoneInput
|
|
value={fieldValue ?? ''}
|
|
onClickOutside={handleClickOutside}
|
|
onEnter={handleEnter}
|
|
onEscape={handleEscape}
|
|
hotkeyScope={EditableFieldHotkeyScope.EditableField}
|
|
/>
|
|
);
|
|
};
|