* chore(ui-toolkit): add aria label to icon for a11y (#621) * chore(ui-toolkit): add labels for form-groups for a11y (#621) * fix(ui-toolkit): fix form inputs storybook for a11y (#621) * feat(ui-toolkit): add strict eslint a11y and components config (#621) * chore(ui-toolkit): add translate t to form labels
45 lines
1.2 KiB
TypeScript
45 lines
1.2 KiB
TypeScript
import { FormGroup, Select } from '@vegaprotocol/ui-toolkit';
|
|
import { OrderTimeInForce, OrderType } from '@vegaprotocol/wallet';
|
|
import { t } from '@vegaprotocol/react-helpers';
|
|
|
|
interface TimeInForceSelectorProps {
|
|
value: OrderTimeInForce;
|
|
orderType: OrderType;
|
|
onSelect: (tif: OrderTimeInForce) => void;
|
|
}
|
|
|
|
export const TimeInForceSelector = ({
|
|
value,
|
|
orderType,
|
|
onSelect,
|
|
}: TimeInForceSelectorProps) => {
|
|
const options =
|
|
orderType === OrderType.Limit
|
|
? Object.entries(OrderTimeInForce)
|
|
: Object.entries(OrderTimeInForce).filter(
|
|
([_, timeInForce]) =>
|
|
timeInForce === OrderTimeInForce.FOK ||
|
|
timeInForce === OrderTimeInForce.IOC
|
|
);
|
|
|
|
return (
|
|
<FormGroup label={t('Time in force')} labelFor="select-time-in-force">
|
|
<Select
|
|
id="select-time-in-force"
|
|
value={value}
|
|
onChange={(e) => onSelect(e.target.value as OrderTimeInForce)}
|
|
className="w-full"
|
|
data-testid="order-tif"
|
|
>
|
|
{options.map(([key, value]) => {
|
|
return (
|
|
<option key={key} value={value}>
|
|
{key}
|
|
</option>
|
|
);
|
|
})}
|
|
</Select>
|
|
</FormGroup>
|
|
);
|
|
};
|