saleor-dashboard/src/giftCards/GiftCardUpdate/GiftCardUpdatePageHeader/GiftCardEnableDisableSection.tsx
Paweł Chyła ce1854b2ca
Introduce datagrid in grift cards list (#3894)
Co-authored-by: wojteknowacki <124166231+wojteknowacki@users.noreply.github.com>
2023-07-19 15:31:33 +02:00

49 lines
1.3 KiB
TypeScript

// @ts-strict-ignore
import { commonMessages } from "@dashboard/intl";
import { ConfirmButton } from "@saleor/macaw-ui";
import React from "react";
import { useIntl } from "react-intl";
import { bulkEnableDisableSectionMessages as buttonMessages } from "../../GiftCardsList/messages";
import useGiftCardDetails from "../providers/GiftCardDetailsProvider/hooks/useGiftCardDetails";
import useGiftCardActivateToggle from "./hooks/useGiftCardActivateToggle";
const GiftCardEnableDisableSection: React.FC = () => {
const intl = useIntl();
const {
giftCard: { id, isActive, isExpired },
} = useGiftCardDetails();
const { giftCardActivate, giftCardDeactivate, currentOpts } =
useGiftCardActivateToggle({
isActive,
});
const handleClick = () =>
isActive
? giftCardDeactivate({ variables: { id } })
: giftCardActivate({ variables: { id } });
const buttonLabel = isActive
? buttonMessages.disableLabel
: buttonMessages.enableLabel;
if (isExpired) {
return null;
}
return (
<ConfirmButton
data-test-id="enable-button"
onClick={handleClick}
transitionState={currentOpts?.status}
labels={{
confirm: intl.formatMessage(buttonLabel),
error: intl.formatMessage(commonMessages.error),
}}
/>
);
};
export default GiftCardEnableDisableSection;