import { ButtonSelector } from '@/portainer/components/form-components/ButtonSelector/ButtonSelector'; import { FormError } from '@/portainer/components/form-components/FormError'; import { InputGroup } from '@/portainer/components/form-components/InputGroup'; import { InputList } from '@/portainer/components/form-components/InputList'; import { InputListError, ItemProps, } from '@/portainer/components/form-components/InputList/InputList'; import styles from './PortsMappingField.module.css'; type Protocol = 'TCP' | 'UDP'; export interface PortMapping { host: string; container: string; protocol: Protocol; } interface Props { value: PortMapping[]; onChange(value: PortMapping[]): void; errors?: InputListError[] | string; } export function PortsMappingField({ value, onChange, errors }: Props) { return ( <> label="Port mapping" value={value} onChange={onChange} addLabel="map additional port" itemBuilder={() => ({ host: '', container: '', protocol: 'TCP' })} item={Item} errors={errors} /> {typeof errors === 'string' && (
{errors}
)} ); } function Item({ onChange, item, error }: ItemProps) { return (
host handleChange('host', e.target.value)} />