2023-03-15 03:51:03 +00:00
|
|
|
import { ReactElement, ReactNode, useEffect, useMemo, useState } from 'react';
|
2023-03-02 20:56:11 +00:00
|
|
|
|
|
|
|
import { BLACK } from '../../lib/consts/DEFAULT_THEME';
|
2023-03-01 03:21:15 +00:00
|
|
|
|
2023-03-04 02:13:40 +00:00
|
|
|
import CommonUpsInputGroup, {
|
|
|
|
INPUT_ID_UPS_IP,
|
|
|
|
INPUT_ID_UPS_NAME,
|
|
|
|
} from './CommonUpsInputGroup';
|
2023-03-01 03:21:15 +00:00
|
|
|
import FlexBox from '../FlexBox';
|
2023-03-02 20:56:11 +00:00
|
|
|
import Link from '../Link';
|
2023-03-01 03:21:15 +00:00
|
|
|
import SelectWithLabel from '../SelectWithLabel';
|
|
|
|
import Spinner from '../Spinner';
|
|
|
|
import { BodyText } from '../Text';
|
2023-03-04 02:13:40 +00:00
|
|
|
import useIsFirstRender from '../../hooks/useIsFirstRender';
|
2023-03-01 03:21:15 +00:00
|
|
|
|
2023-03-04 02:13:40 +00:00
|
|
|
const INPUT_ID_UPS_TYPE = 'add-ups-select-ups-type-id';
|
2023-03-02 03:31:12 +00:00
|
|
|
|
2023-03-04 02:13:40 +00:00
|
|
|
const INPUT_LABEL_UPS_TYPE = 'UPS type';
|
|
|
|
|
|
|
|
const AddUpsInputGroup = <
|
|
|
|
M extends {
|
|
|
|
[K in
|
|
|
|
| typeof INPUT_ID_UPS_IP
|
|
|
|
| typeof INPUT_ID_UPS_NAME
|
|
|
|
| typeof INPUT_ID_UPS_TYPE]: string;
|
|
|
|
},
|
|
|
|
>({
|
|
|
|
formUtils,
|
2023-03-01 03:21:15 +00:00
|
|
|
loading: isExternalLoading,
|
2023-03-02 03:31:12 +00:00
|
|
|
previous = {},
|
2023-03-01 03:21:15 +00:00
|
|
|
upsTemplate,
|
2023-03-04 02:13:40 +00:00
|
|
|
}: AddUpsInputGroupProps<M>): ReactElement => {
|
|
|
|
const { buildInputFirstRenderFunction, setValidity } = formUtils;
|
|
|
|
|
2023-03-02 03:31:12 +00:00
|
|
|
const { upsTypeId: previousUpsTypeId = '' } = previous;
|
|
|
|
|
2023-03-04 02:13:40 +00:00
|
|
|
const isFirstRender = useIsFirstRender();
|
|
|
|
|
2023-03-02 03:31:12 +00:00
|
|
|
const [inputUpsTypeIdValue, setInputUpsTypeIdValue] =
|
|
|
|
useState<string>(previousUpsTypeId);
|
2023-03-01 03:21:15 +00:00
|
|
|
|
2023-03-02 03:31:12 +00:00
|
|
|
const upsTypeOptions = useMemo<SelectItem[]>(
|
2023-03-01 03:21:15 +00:00
|
|
|
() =>
|
|
|
|
upsTemplate
|
|
|
|
? Object.entries(upsTemplate).map<SelectItem>(
|
2023-03-02 20:56:11 +00:00
|
|
|
([
|
|
|
|
upsTypeId,
|
|
|
|
{
|
|
|
|
brand,
|
|
|
|
description,
|
|
|
|
links: { 0: link },
|
|
|
|
},
|
|
|
|
]) => {
|
|
|
|
let linkElement: ReactNode;
|
|
|
|
|
|
|
|
if (link) {
|
|
|
|
const { linkHref, linkLabel } = link;
|
|
|
|
|
|
|
|
linkElement = (
|
|
|
|
<Link
|
|
|
|
href={linkHref}
|
|
|
|
onClick={(event) => {
|
|
|
|
// Don't trigger the (parent) item selection event.
|
|
|
|
event.stopPropagation();
|
|
|
|
}}
|
|
|
|
sx={{ display: 'inline-flex', color: BLACK }}
|
|
|
|
target="_blank"
|
|
|
|
>
|
|
|
|
{linkLabel}
|
|
|
|
</Link>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return {
|
|
|
|
displayValue: (
|
|
|
|
<FlexBox spacing={0}>
|
|
|
|
<BodyText inverted>{brand}</BodyText>
|
|
|
|
<BodyText inverted>
|
|
|
|
{description} ({linkElement})
|
|
|
|
</BodyText>
|
|
|
|
</FlexBox>
|
|
|
|
),
|
|
|
|
value: upsTypeId,
|
|
|
|
};
|
|
|
|
},
|
2023-03-01 03:21:15 +00:00
|
|
|
)
|
|
|
|
: [],
|
|
|
|
[upsTemplate],
|
|
|
|
);
|
|
|
|
|
2023-03-02 03:31:12 +00:00
|
|
|
const pickUpsTypeElement = useMemo(
|
2023-03-01 03:21:15 +00:00
|
|
|
() =>
|
|
|
|
upsTemplate && (
|
|
|
|
<SelectWithLabel
|
|
|
|
formControlProps={{ sx: { marginTop: '.3em' } }}
|
2023-03-04 02:13:40 +00:00
|
|
|
id={INPUT_ID_UPS_TYPE}
|
|
|
|
label={INPUT_LABEL_UPS_TYPE}
|
2023-03-01 03:21:15 +00:00
|
|
|
onChange={({ target: { value: rawNewValue } }) => {
|
|
|
|
const newValue = String(rawNewValue);
|
|
|
|
|
2023-03-04 02:13:40 +00:00
|
|
|
setValidity(INPUT_ID_UPS_TYPE, true);
|
2023-03-02 03:31:12 +00:00
|
|
|
setInputUpsTypeIdValue(newValue);
|
2023-03-01 03:21:15 +00:00
|
|
|
}}
|
2023-03-02 21:28:22 +00:00
|
|
|
required
|
2023-03-02 03:31:12 +00:00
|
|
|
selectItems={upsTypeOptions}
|
2023-03-01 03:21:15 +00:00
|
|
|
selectProps={{
|
|
|
|
onClearIndicatorClick: () => {
|
2023-03-04 02:13:40 +00:00
|
|
|
setValidity(INPUT_ID_UPS_TYPE, false);
|
2023-03-02 03:31:12 +00:00
|
|
|
setInputUpsTypeIdValue('');
|
2023-03-01 03:21:15 +00:00
|
|
|
},
|
|
|
|
renderValue: (rawValue) => {
|
|
|
|
const upsTypeId = String(rawValue);
|
|
|
|
const { brand } = upsTemplate[upsTypeId];
|
|
|
|
|
|
|
|
return brand;
|
|
|
|
},
|
|
|
|
}}
|
2023-03-02 03:31:12 +00:00
|
|
|
value={inputUpsTypeIdValue}
|
2023-03-01 03:21:15 +00:00
|
|
|
/>
|
|
|
|
),
|
2023-03-04 02:13:40 +00:00
|
|
|
[upsTemplate, upsTypeOptions, inputUpsTypeIdValue, setValidity],
|
2023-03-01 03:21:15 +00:00
|
|
|
);
|
2023-03-04 02:13:40 +00:00
|
|
|
|
2023-03-01 03:21:15 +00:00
|
|
|
const content = useMemo<ReactElement>(
|
|
|
|
() =>
|
|
|
|
isExternalLoading ? (
|
|
|
|
<Spinner />
|
|
|
|
) : (
|
|
|
|
<FlexBox>
|
2023-03-02 03:31:12 +00:00
|
|
|
{pickUpsTypeElement}
|
2023-03-04 02:13:40 +00:00
|
|
|
{inputUpsTypeIdValue && (
|
|
|
|
<CommonUpsInputGroup formUtils={formUtils} previous={previous} />
|
|
|
|
)}
|
2023-03-01 03:21:15 +00:00
|
|
|
</FlexBox>
|
|
|
|
),
|
2023-03-04 02:13:40 +00:00
|
|
|
[
|
|
|
|
formUtils,
|
|
|
|
inputUpsTypeIdValue,
|
|
|
|
isExternalLoading,
|
|
|
|
pickUpsTypeElement,
|
|
|
|
previous,
|
|
|
|
],
|
2023-03-01 03:21:15 +00:00
|
|
|
);
|
|
|
|
|
2023-03-15 03:51:03 +00:00
|
|
|
useEffect(() => {
|
|
|
|
if (isFirstRender) {
|
|
|
|
buildInputFirstRenderFunction(INPUT_ID_UPS_TYPE)({
|
|
|
|
isValid: Boolean(inputUpsTypeIdValue),
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}, [buildInputFirstRenderFunction, inputUpsTypeIdValue, isFirstRender]);
|
2023-03-04 02:13:40 +00:00
|
|
|
|
2023-03-01 03:21:15 +00:00
|
|
|
return content;
|
|
|
|
};
|
|
|
|
|
2023-03-04 02:13:40 +00:00
|
|
|
export { INPUT_ID_UPS_TYPE, INPUT_LABEL_UPS_TYPE };
|
2023-03-02 03:31:12 +00:00
|
|
|
|
2023-03-01 03:21:15 +00:00
|
|
|
export default AddUpsInputGroup;
|