2022-07-08 14:54:23 -07:00
|
|
|
import React from 'react';
|
2022-06-13 08:35:54 -07:00
|
|
|
import { defineMessages, useIntl } from 'react-intl';
|
|
|
|
|
|
|
|
import {
|
|
|
|
subscribeAccount,
|
|
|
|
unsubscribeAccount,
|
|
|
|
} from 'soapbox/actions/accounts';
|
2023-06-22 21:38:50 -07:00
|
|
|
import { useFollow } from 'soapbox/api/hooks';
|
2022-06-13 08:35:54 -07:00
|
|
|
import { IconButton } from 'soapbox/components/ui';
|
|
|
|
import { useAppDispatch, useFeatures } from 'soapbox/hooks';
|
2022-12-20 07:47:46 -08:00
|
|
|
import toast from 'soapbox/toast';
|
2022-06-13 08:35:54 -07:00
|
|
|
|
|
|
|
import type { Account as AccountEntity } from 'soapbox/types/entities';
|
|
|
|
|
|
|
|
const messages = defineMessages({
|
|
|
|
subscribe: { id: 'account.subscribe', defaultMessage: 'Subscribe to notifications from @{name}' },
|
|
|
|
unsubscribe: { id: 'account.unsubscribe', defaultMessage: 'Unsubscribe to notifications from @{name}' },
|
|
|
|
subscribeSuccess: { id: 'account.subscribe.success', defaultMessage: 'You have subscribed to this account.' },
|
|
|
|
unsubscribeSuccess: { id: 'account.unsubscribe.success', defaultMessage: 'You have unsubscribed from this account.' },
|
2022-07-21 12:37:14 -07:00
|
|
|
subscribeFailure: { id: 'account.subscribe.failure', defaultMessage: 'An error occurred trying to subscribe to this account.' },
|
|
|
|
unsubscribeFailure: { id: 'account.unsubscribe.failure', defaultMessage: 'An error occurred trying to unsubscribe to this account.' },
|
2022-06-13 08:35:54 -07:00
|
|
|
});
|
|
|
|
|
|
|
|
interface ISubscriptionButton {
|
2023-06-20 12:24:39 -07:00
|
|
|
account: Pick<AccountEntity, 'id' | 'username' | 'relationship'>
|
2022-06-13 08:35:54 -07:00
|
|
|
}
|
|
|
|
|
|
|
|
const SubscriptionButton = ({ account }: ISubscriptionButton) => {
|
|
|
|
const dispatch = useAppDispatch();
|
|
|
|
const features = useFeatures();
|
|
|
|
const intl = useIntl();
|
2023-06-22 21:38:50 -07:00
|
|
|
const { follow } = useFollow();
|
2022-06-13 08:35:54 -07:00
|
|
|
|
2022-06-14 08:58:42 -07:00
|
|
|
const isFollowing = account.relationship?.following;
|
|
|
|
const isRequested = account.relationship?.requested;
|
2022-11-10 15:11:19 -08:00
|
|
|
const isSubscribed = features.accountNotifies
|
|
|
|
? account.relationship?.notifying
|
|
|
|
: account.relationship?.subscribing;
|
|
|
|
const title = isSubscribed
|
2023-06-20 12:24:39 -07:00
|
|
|
? intl.formatMessage(messages.unsubscribe, { name: account.username })
|
|
|
|
: intl.formatMessage(messages.subscribe, { name: account.username });
|
2022-06-13 08:35:54 -07:00
|
|
|
|
2022-07-08 14:54:23 -07:00
|
|
|
const onSubscribeSuccess = () =>
|
2022-12-20 07:47:46 -08:00
|
|
|
toast.success(intl.formatMessage(messages.subscribeSuccess));
|
2022-06-13 08:35:54 -07:00
|
|
|
|
|
|
|
const onSubscribeFailure = () =>
|
2022-12-20 08:34:53 -08:00
|
|
|
toast.error(intl.formatMessage(messages.subscribeFailure));
|
2022-06-13 08:35:54 -07:00
|
|
|
|
|
|
|
const onUnsubscribeSuccess = () =>
|
2022-12-20 07:47:46 -08:00
|
|
|
toast.success(intl.formatMessage(messages.unsubscribeSuccess));
|
2022-06-13 08:35:54 -07:00
|
|
|
|
|
|
|
const onUnsubscribeFailure = () =>
|
2022-12-20 08:34:53 -08:00
|
|
|
toast.error(intl.formatMessage(messages.unsubscribeFailure));
|
2022-06-13 08:35:54 -07:00
|
|
|
|
|
|
|
const onNotifyToggle = () => {
|
|
|
|
if (account.relationship?.notifying) {
|
2023-06-22 21:38:50 -07:00
|
|
|
follow(account.id, { notify: false })
|
2022-06-13 08:35:54 -07:00
|
|
|
?.then(() => onUnsubscribeSuccess())
|
|
|
|
.catch(() => onUnsubscribeFailure());
|
|
|
|
} else {
|
2023-06-22 21:38:50 -07:00
|
|
|
follow(account.id, { notify: true })
|
2022-06-13 08:35:54 -07:00
|
|
|
?.then(() => onSubscribeSuccess())
|
|
|
|
.catch(() => onSubscribeFailure());
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const onSubscriptionToggle = () => {
|
|
|
|
if (account.relationship?.subscribing) {
|
2023-06-20 12:24:39 -07:00
|
|
|
dispatch(unsubscribeAccount(account.id))
|
2022-06-13 08:35:54 -07:00
|
|
|
?.then(() => onUnsubscribeSuccess())
|
|
|
|
.catch(() => onUnsubscribeFailure());
|
|
|
|
} else {
|
2023-06-20 12:24:39 -07:00
|
|
|
dispatch(subscribeAccount(account.id))
|
2022-06-13 08:35:54 -07:00
|
|
|
?.then(() => onSubscribeSuccess())
|
|
|
|
.catch(() => onSubscribeFailure());
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
|
|
|
const handleToggle = () => {
|
|
|
|
if (features.accountNotifies) {
|
|
|
|
onNotifyToggle();
|
|
|
|
} else {
|
|
|
|
onSubscriptionToggle();
|
|
|
|
}
|
|
|
|
};
|
|
|
|
|
2022-06-14 08:58:42 -07:00
|
|
|
if (!features.accountSubscriptions && !features.accountNotifies) {
|
2022-06-13 08:35:54 -07:00
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
2022-06-14 08:58:42 -07:00
|
|
|
if (isRequested || isFollowing) {
|
2022-06-13 08:35:54 -07:00
|
|
|
return (
|
|
|
|
<IconButton
|
2022-07-09 09:20:02 -07:00
|
|
|
src={isSubscribed ? require('@tabler/icons/bell-ringing.svg') : require('@tabler/icons/bell.svg')}
|
2022-06-13 08:35:54 -07:00
|
|
|
onClick={handleToggle}
|
|
|
|
title={title}
|
2022-08-12 08:42:26 -07:00
|
|
|
theme='outlined'
|
|
|
|
className='px-2'
|
2023-02-15 13:26:27 -08:00
|
|
|
iconClassName='h-4 w-4'
|
2022-06-13 08:35:54 -07:00
|
|
|
/>
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return null;
|
|
|
|
};
|
|
|
|
|
|
|
|
export default SubscriptionButton;
|