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

107 lines
3.2 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";
2020-02-24 14:14:48 +00:00
import { UserError } from "@saleor/types";
import { getFieldError } from "@saleor/utils/errors";
2019-08-09 10:17:04 +00:00
import { FormData } from "../VoucherDetailsPage";
interface VoucherRequirementsProps {
data: FormData;
defaultCurrency: string;
disabled: boolean;
2020-02-24 14:14:48 +00:00
errors: UserError[];
2019-08-09 10:17:04 +00:00
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}
2020-02-24 14:14:48 +00:00
error={!!getFieldError(errors, "minSpent")}
helperText={getFieldError(errors, "minSpent")?.message}
label={minimalOrderValueText}
2020-01-09 11:13:24 +00:00
name={"minSpent" as keyof FormData}
value={data.minSpent}
2019-08-09 10:17:04 +00:00
onChange={onChange}
fullWidth
/>
) : data.requirementsPicker === RequirementsPicker.ITEM ? (
<TextField
disabled={disabled}
2020-02-24 14:14:48 +00:00
error={!!getFieldError(errors, "minCheckoutItemsQuantity")}
helperText={
getFieldError(errors, "minCheckoutItemsQuantity")?.message
}
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;