src/applications/_mock-form-ae-design-patterns/patterns/pattern1/TaskPurple/EditContactInfo.jsx
import React, { useRef, useEffect } from 'react';
import PropTypes from 'prop-types';
import { useSelector } from 'react-redux';
// import {
// ProfileInformationFieldController,
// InitializeVAPServiceID,
// FIELD_NAMES,
// } from '@department-of-veterans-affairs/platform-user/exports';
// import InitializeVAPServiceID from '@@vap-svc/containers/InitializeVAPServiceID';
// import ProfileInformationFieldController from '@@vap-svc/components/ProfileInformationFieldController';
// import { FIELD_NAMES } from '@@vap-svc/constants';
import InitializeVAPServiceID from 'platform/user/profile/vap-svc/containers/InitializeVAPServiceID';
// import ProfileInformationFieldController from 'platform/user/profile/vap-svc/components/ProfileInformationFieldController';
import { FIELD_NAMES } from 'platform/user/profile/vap-svc/constants';
import { focusElement } from '@department-of-veterans-affairs/platform-utilities/ui';
import { usePrevious } from 'platform/utilities/react-hooks';
import { setReturnState } from 'platform/forms-system/src/js/utilities/data/profile';
import ProfileInformationFieldController from './ProfileInformationFieldController';
export const BuildPage = props => {
const { title, field, id, goToPath, subTitle } = props;
const headerRef = useRef(null);
const modalState = useSelector(state => state?.vapService?.modal);
const prevModalState = usePrevious(modalState);
useEffect(
() => {
if (headerRef?.current) {
focusElement(headerRef?.current);
}
},
[headerRef],
);
useEffect(
() => {
const shouldFocusOnHeaderRef =
prevModalState === 'addressValidation' &&
modalState === 'mailingAddress';
// we do this to make sure focus is set when cancelling out of address validation UI
if (shouldFocusOnHeaderRef) {
setTimeout(() => {
focusElement(headerRef?.current);
}, 250);
}
},
[modalState, prevModalState],
);
// const onReviewPage = window.sessionStorage.getItem(REVIEW_CONTACT) === 'true';
// const returnPath = onReviewPage ? '/review-and-submit' : `${contactPath}`;
const returnPath = '/1/task-purple/veteran-information';
const handlers = {
onSubmit: event => {
// This prevents this nested form submit event from passing to the
// outer form and causing a page advance
event.stopPropagation();
},
cancel: () => {
setReturnState(id, 'canceled');
goToPath(returnPath);
},
success: () => {
setReturnState(id, 'updated');
goToPath(returnPath);
},
};
return (
<>
<h2
ref={headerRef}
className="vads-u-margin-top--1 vads-u-margin-bottom--3"
>
{title}
</h2>
<va-card background>
<p className="vads-u-margin-top--0 vads-u-margin-bottom--0 vads-u-font-weight--bold">
Current home phone number
</p>
<p className="vads-u-margin-bottom--0">
{props.data.veteran.homePhone.areaCode}-
{props.data.veteran.homePhone.phoneNumber.slice(0, 3)}-
{props.data.veteran.homePhone.phoneNumber.slice(3, 7)}
</p>
</va-card>
<div className="va-profile-wrapper" onSubmit={handlers.onSubmit}>
<InitializeVAPServiceID>
{subTitle && <p className="vads-u-color--gray-medium">{subTitle}</p>}
<ProfileInformationFieldController
forceEditView
fieldName={FIELD_NAMES[field]}
isDeleteDisabled
cancelCallback={handlers.cancel}
successCallback={handlers.success}
/>
</InitializeVAPServiceID>
</div>
</>
);
};
BuildPage.propTypes = {
contactPath: PropTypes.string,
data: PropTypes.object,
field: PropTypes.string,
goToPath: PropTypes.func,
id: PropTypes.string,
saveButtonText: PropTypes.string,
subTitle: PropTypes.string,
title: PropTypes.string,
};
export const EditHomePhone = props => (
<BuildPage {...props} field="HOME_PHONE" id="home-phone" />
);
export const EditMobilePhone = props => (
<BuildPage {...props} field="MOBILE_PHONE" id="mobile-phone" />
);
export const EditEmail = props => (
<BuildPage {...props} field="EMAIL" id="email" />
);
export const EditAddress = props => {
return <BuildPage {...props} field="MAILING_ADDRESS" id="address" />;
};