saleor-dashboard/src/discounts/components/VoucherRequirements/VoucherRequirements.tsx

104 lines
3.1 KiB
TypeScript
Raw Normal View History

2019-08-09 10:17:04 +00:00
import Card from "@material-ui/core/Card";
import CardContent from "@material-ui/core/CardContent";
import TextField from "@material-ui/core/TextField";
import React from "react";
import { useIntl } from "react-intl";
2019-08-09 10:17:04 +00:00
import CardTitle from "@saleor/components/CardTitle";
import { FormSpacer } from "@saleor/components/FormSpacer";
import RadioGroupField from "@saleor/components/RadioGroupField";
import { RequirementsPicker } from "@saleor/discounts/types";
import { FormErrors } from "@saleor/types";
import { FormData } from "../VoucherDetailsPage";
interface VoucherRequirementsProps {
data: FormData;
defaultCurrency: string;
disabled: boolean;
errors: FormErrors<"minAmountSpent" | "minCheckoutItemsQuantity">;
onChange: (event: React.ChangeEvent<any>) => void;
}
const VoucherRequirements = ({
data,
disabled,
errors,
onChange
}: VoucherRequirementsProps) => {
const intl = useIntl();
const minimalOrderValueText = intl.formatMessage({
defaultMessage: "Minimal order value",
description: "voucher requirement"
});
const minimalQuantityText = intl.formatMessage({
defaultMessage: "Minimum quantity of items",
description: "voucher requirement"
});
2019-08-09 10:17:04 +00:00
const requirementsPickerChoices = [
{
label: intl.formatMessage({
defaultMessage: "None",
description: "voucher has no requirements"
}),
2019-08-09 10:17:04 +00:00
value: RequirementsPicker.NONE
},
{
label: minimalOrderValueText,
2019-08-09 10:17:04 +00:00
value: RequirementsPicker.ORDER
},
{
label: minimalQuantityText,
2019-08-09 10:17:04 +00:00
value: RequirementsPicker.ITEM
}
];
return (
<Card>
<CardTitle
title={intl.formatMessage({
defaultMessage: "Minimum Requirements",
description: "voucher requirements, header"
})}
/>
2019-08-09 10:17:04 +00:00
<CardContent>
<RadioGroupField
choices={requirementsPickerChoices}
disabled={disabled}
name={"requirementsPicker" as keyof FormData}
value={data.requirementsPicker}
onChange={onChange}
/>
2019-10-10 12:45:25 +00:00
{[RequirementsPicker.ORDER, RequirementsPicker.ITEM].includes(
data.requirementsPicker
) && <FormSpacer />}
2019-08-09 10:17:04 +00:00
{data.requirementsPicker === RequirementsPicker.ORDER ? (
<TextField
disabled={disabled}
error={!!errors.minAmountSpent}
helperText={errors.minAmountSpent}
label={minimalOrderValueText}
2019-08-09 10:17:04 +00:00
name={"minAmountSpent" as keyof FormData}
value={data.minAmountSpent}
onChange={onChange}
fullWidth
/>
) : data.requirementsPicker === RequirementsPicker.ITEM ? (
<TextField
disabled={disabled}
error={!!errors.minCheckoutItemsQuantity}
helperText={errors.minCheckoutItemsQuantity}
label={minimalQuantityText}
2019-08-09 10:17:04 +00:00
name={"minCheckoutItemsQuantity" as keyof FormData}
value={data.minCheckoutItemsQuantity}
onChange={onChange}
fullWidth
/>
) : null}
</CardContent>
</Card>
);
};
export default VoucherRequirements;