feature/IO-3182-Phone-Number-Consent - Checkpoint
This commit is contained in:
@@ -1,65 +1,23 @@
|
||||
import { useMutation } from "@apollo/client";
|
||||
import { Switch, Typography, Tooltip, message } from "antd";
|
||||
import { Typography } from "antd";
|
||||
import { useTranslation } from "react-i18next";
|
||||
import { connect } from "react-redux";
|
||||
import { createStructuredSelector } from "reselect";
|
||||
import { selectBodyshop } from "../../redux/user/user.selectors";
|
||||
import { updateBodyshopEnforceConsent } from "../../redux/user/user.actions";
|
||||
import { UPDATE_BODYSHOP_ENFORCE_CONSENT } from "../../graphql/bodyshop.queries";
|
||||
import PhoneNumberConsentList from "../phone-number-consent/phone-number-consent.component";
|
||||
|
||||
const mapStateToProps = createStructuredSelector({
|
||||
bodyshop: selectBodyshop
|
||||
});
|
||||
|
||||
const mapDispatchToProps = (dispatch) => ({
|
||||
updateBodyshopEnforceConsent: (enforce_sms_consent) => dispatch(updateBodyshopEnforceConsent(enforce_sms_consent))
|
||||
});
|
||||
const mapDispatchToProps = (dispatch) => ({});
|
||||
|
||||
function ShopInfoConsentComponent({ bodyshop, updateBodyshopEnforceConsent }) {
|
||||
function ShopInfoConsentComponent({ bodyshop }) {
|
||||
const { t } = useTranslation();
|
||||
|
||||
const [updateEnforceConsent] = useMutation(UPDATE_BODYSHOP_ENFORCE_CONSENT, {
|
||||
onError: (error) => {
|
||||
message.error(t("settings.enforce_sms_consent_error"));
|
||||
console.error("Error updating enforce_sms_consent:", error);
|
||||
},
|
||||
onCompleted: (data) => {
|
||||
message.success(t("settings.enforce_sms_consent_success"));
|
||||
updateBodyshopEnforceConsent(data.update_bodyshops_by_pk.enforce_sms_consent);
|
||||
}
|
||||
});
|
||||
|
||||
const enforceConsent = bodyshop?.enforce_sms_consent ?? false;
|
||||
|
||||
return (
|
||||
<div>
|
||||
<Typography.Title level={4}>{t("settings.title")}</Typography.Title>
|
||||
<div style={{ marginBottom: 16 }}>
|
||||
<Typography.Text>{t("settings.enforce_sms_consent")}</Typography.Text>
|
||||
<Tooltip
|
||||
title={enforceConsent ? t("settings.enforce_sms_consent_warning") : t("settings.enforce_sms_consent_enable")}
|
||||
>
|
||||
<Switch
|
||||
checked={enforceConsent}
|
||||
onChange={(checked) => {
|
||||
if (!checked && enforceConsent) return; // Prevent disabling
|
||||
updateEnforceConsent({
|
||||
variables: { id: bodyshop.id, enforce_sms_consent: checked },
|
||||
optimisticResponse: {
|
||||
update_bodyshops_by_pk: {
|
||||
__typename: "bodyshops",
|
||||
id: bodyshop.id,
|
||||
enforce_sms_consent: checked
|
||||
}
|
||||
}
|
||||
});
|
||||
}}
|
||||
disabled={enforceConsent}
|
||||
/>
|
||||
</Tooltip>
|
||||
</div>
|
||||
{enforceConsent && <PhoneNumberConsentList bodyshop={bodyshop} />}
|
||||
{<PhoneNumberConsentList bodyshop={bodyshop} />}
|
||||
</div>
|
||||
);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user