2023-11-30 19:08:16 +08:00
|
|
|
import React from 'react';
|
2020-02-04 04:41:12 +08:00
|
|
|
import { withTracker } from 'meteor/react-meteor-data';
|
2024-01-10 20:07:38 +08:00
|
|
|
import { useMutation } from '@apollo/client';
|
2020-02-04 04:41:12 +08:00
|
|
|
import GuestPolicyComponent from './component';
|
|
|
|
import Service from '../service';
|
2023-11-30 19:08:16 +08:00
|
|
|
import useCurrentUser from '/imports/ui/core/hooks/useCurrentUser';
|
2024-01-10 20:07:38 +08:00
|
|
|
import { SET_POLICY } from '../mutations';
|
2020-02-04 04:41:12 +08:00
|
|
|
|
2022-11-23 00:16:46 +08:00
|
|
|
const GuestPolicyContainer = (props) => {
|
2023-11-30 19:08:16 +08:00
|
|
|
const { data: currentUserData } = useCurrentUser((user) => ({
|
2023-11-30 21:24:25 +08:00
|
|
|
isModerator: user.isModerator,
|
2023-11-30 19:08:16 +08:00
|
|
|
}));
|
2023-11-30 21:24:25 +08:00
|
|
|
const amIModerator = currentUserData?.isModerator;
|
2021-09-02 03:46:14 +08:00
|
|
|
|
2024-01-10 20:07:38 +08:00
|
|
|
const [setPolicy] = useMutation(SET_POLICY);
|
|
|
|
|
|
|
|
const changeGuestPolicy = (guestPolicy) => {
|
|
|
|
setPolicy({
|
|
|
|
variables: {
|
|
|
|
guestPolicy,
|
|
|
|
},
|
|
|
|
});
|
|
|
|
};
|
|
|
|
|
|
|
|
return amIModerator && <GuestPolicyComponent changeGuestPolicy={changeGuestPolicy} {...props} />;
|
2021-09-02 03:46:14 +08:00
|
|
|
};
|
2020-02-04 04:41:12 +08:00
|
|
|
|
2023-11-30 19:08:16 +08:00
|
|
|
export default withTracker(() => ({
|
2020-02-04 04:41:12 +08:00
|
|
|
guestPolicy: Service.getGuestPolicy(),
|
2023-03-22 04:45:20 +08:00
|
|
|
}))(GuestPolicyContainer);
|