2018-03-26 14:32:43 -07:00
|
|
|
// @flow
|
2018-10-29 13:23:53 -04:00
|
|
|
import * as MODALS from 'constants/modal_types';
|
|
|
|
import * as ICONS from 'constants/icons';
|
2019-07-02 00:39:17 -04:00
|
|
|
import React, { useRef } from 'react';
|
2018-11-21 16:20:55 -05:00
|
|
|
import { parseURI } from 'lbry-redux';
|
2018-03-26 14:32:43 -07:00
|
|
|
import Button from 'component/button';
|
2019-09-27 14:56:15 -04:00
|
|
|
import useHover from 'effects/use-hover';
|
2020-04-02 10:26:32 -04:00
|
|
|
import useIsMobile from 'effects/use-is-mobile';
|
2018-03-26 14:32:43 -07:00
|
|
|
|
2019-07-08 16:54:58 -04:00
|
|
|
type SubscriptionArgs = {
|
2018-03-26 14:32:43 -07:00
|
|
|
channelName: string,
|
|
|
|
uri: string,
|
|
|
|
};
|
|
|
|
|
|
|
|
type Props = {
|
2019-09-04 00:22:31 -04:00
|
|
|
permanentUrl: ?string,
|
2018-10-19 16:38:07 -04:00
|
|
|
isSubscribed: boolean,
|
|
|
|
subscriptions: Array<string>,
|
2018-03-26 14:32:43 -07:00
|
|
|
doChannelSubscribe: ({ channelName: string, uri: string }) => void,
|
2019-07-08 16:54:58 -04:00
|
|
|
doChannelUnsubscribe: SubscriptionArgs => void,
|
2019-01-07 18:29:40 -05:00
|
|
|
doOpenModal: (id: string) => void,
|
2018-11-21 16:20:55 -05:00
|
|
|
showSnackBarOnSubscribe: boolean,
|
|
|
|
doToast: ({ message: string }) => void,
|
2020-04-02 10:26:32 -04:00
|
|
|
shrinkOnMobile: boolean,
|
2018-03-26 14:32:43 -07:00
|
|
|
};
|
|
|
|
|
2019-06-11 14:10:58 -04:00
|
|
|
export default function SubscribeButton(props: Props) {
|
2018-03-26 14:32:43 -07:00
|
|
|
const {
|
2019-09-04 00:22:31 -04:00
|
|
|
permanentUrl,
|
2018-03-26 14:32:43 -07:00
|
|
|
doChannelSubscribe,
|
|
|
|
doChannelUnsubscribe,
|
2018-10-29 13:23:53 -04:00
|
|
|
doOpenModal,
|
2018-10-19 16:38:07 -04:00
|
|
|
subscriptions,
|
|
|
|
isSubscribed,
|
2018-11-21 16:20:55 -05:00
|
|
|
showSnackBarOnSubscribe,
|
|
|
|
doToast,
|
2020-04-02 10:26:32 -04:00
|
|
|
shrinkOnMobile = false,
|
2018-03-26 14:32:43 -07:00
|
|
|
} = props;
|
2020-04-23 22:04:47 +05:30
|
|
|
|
2019-06-28 03:33:07 -04:00
|
|
|
const buttonRef = useRef();
|
2020-04-02 10:26:32 -04:00
|
|
|
const isMobile = useIsMobile();
|
2020-04-23 22:04:47 +05:30
|
|
|
let isHovering = useHover(buttonRef);
|
|
|
|
isHovering = isMobile ? true : isHovering;
|
|
|
|
|
2019-09-04 00:22:31 -04:00
|
|
|
const { channelName } = parseURI(permanentUrl);
|
2019-08-29 19:18:06 -04:00
|
|
|
const claimName = '@' + channelName;
|
2020-04-23 22:04:47 +05:30
|
|
|
|
2017-12-21 18:08:54 -03:00
|
|
|
const subscriptionHandler = isSubscribed ? doChannelUnsubscribe : doChannelSubscribe;
|
2019-06-28 03:27:55 -04:00
|
|
|
const subscriptionLabel = isSubscribed ? __('Following') : __('Follow');
|
2019-06-28 03:33:07 -04:00
|
|
|
const unfollowOverride = isSubscribed && isHovering && __('Unfollow');
|
2020-04-03 19:29:39 -04:00
|
|
|
|
2020-04-23 22:04:47 +05:30
|
|
|
const label = isMobile && shrinkOnMobile ? '' : unfollowOverride || subscriptionLabel;
|
2020-05-26 11:48:12 +08:00
|
|
|
const titlePrefix = isSubscribed ? __('Unfollow this channel') : __('Follow this channel');
|
2020-04-03 19:29:39 -04:00
|
|
|
|
2019-09-04 00:22:31 -04:00
|
|
|
return permanentUrl ? (
|
2018-03-26 14:32:43 -07:00
|
|
|
<Button
|
2019-06-28 03:33:07 -04:00
|
|
|
ref={buttonRef}
|
2018-05-22 23:48:22 -04:00
|
|
|
iconColor="red"
|
2020-04-23 22:04:47 +05:30
|
|
|
largestLabel={isMobile && shrinkOnMobile ? '' : subscriptionLabel}
|
2019-06-28 03:33:07 -04:00
|
|
|
icon={unfollowOverride ? ICONS.UNSUBSCRIBE : ICONS.SUBSCRIBE}
|
2019-06-17 16:32:38 -04:00
|
|
|
button={'alt'}
|
2019-10-15 14:53:55 -04:00
|
|
|
requiresAuth={IS_WEB}
|
2020-04-02 10:26:32 -04:00
|
|
|
label={label}
|
2020-05-26 11:48:12 +08:00
|
|
|
title={titlePrefix}
|
2018-08-27 14:45:50 -04:00
|
|
|
onClick={e => {
|
|
|
|
e.stopPropagation();
|
|
|
|
|
2019-01-14 16:21:37 -05:00
|
|
|
if (!subscriptions.length) {
|
2018-10-29 13:23:53 -04:00
|
|
|
doOpenModal(MODALS.FIRST_SUBSCRIPTION);
|
2018-03-26 14:32:43 -07:00
|
|
|
}
|
2018-11-21 16:20:55 -05:00
|
|
|
|
2018-03-26 14:32:43 -07:00
|
|
|
subscriptionHandler({
|
2018-11-21 16:20:55 -05:00
|
|
|
channelName: claimName,
|
2019-09-04 00:22:31 -04:00
|
|
|
uri: permanentUrl,
|
2018-03-26 14:32:43 -07:00
|
|
|
});
|
2018-11-21 16:20:55 -05:00
|
|
|
|
|
|
|
if (showSnackBarOnSubscribe) {
|
2019-06-28 03:27:55 -04:00
|
|
|
doToast({ message: `${__('Now following ')} ${claimName}!` });
|
2018-11-21 16:20:55 -05:00
|
|
|
}
|
2018-03-26 14:32:43 -07:00
|
|
|
}}
|
|
|
|
/>
|
2019-09-04 00:22:31 -04:00
|
|
|
) : null;
|
2019-06-11 14:10:58 -04:00
|
|
|
}
|