lbry-desktop/ui/component/channelBlockButton/view.jsx

94 lines
2.4 KiB
React
Raw Normal View History

// @flow
import React from 'react';
import Button from 'component/button';
2021-06-16 10:27:58 +08:00
import { BLOCK_LEVEL } from 'constants/comment';
type Props = {
uri: string,
2021-06-16 10:27:58 +08:00
blockLevel?: string,
creatorUri?: string,
isBlocked: boolean,
isBlockingOrUnBlocking: boolean,
2021-06-16 10:27:58 +08:00
isToggling: boolean,
2021-06-11 17:49:18 -03:00
doCommentModUnBlock: (string, boolean) => void,
doCommentModBlock: (string, ?Number, boolean) => void,
2021-06-16 10:27:58 +08:00
doCommentModUnBlockAsAdmin: (string, string) => void,
doCommentModBlockAsAdmin: (string, string) => void,
doCommentModUnBlockAsModerator: (string, string, string) => void,
doCommentModBlockAsModerator: (string, string, string) => void,
};
function ChannelBlockButton(props: Props) {
2021-06-16 10:27:58 +08:00
const {
uri,
blockLevel,
creatorUri,
doCommentModUnBlock,
doCommentModBlock,
doCommentModUnBlockAsAdmin,
doCommentModBlockAsAdmin,
doCommentModUnBlockAsModerator,
doCommentModBlockAsModerator,
isBlocked,
isBlockingOrUnBlocking,
isToggling,
} = props;
function handleClick() {
2021-06-16 10:27:58 +08:00
switch (blockLevel) {
default:
case BLOCK_LEVEL.SELF:
if (isBlocked) {
doCommentModUnBlock(uri, false);
} else {
doCommentModBlock(uri, undefined, false);
2021-06-16 10:27:58 +08:00
}
break;
case BLOCK_LEVEL.MODERATOR:
if (creatorUri) {
if (isBlocked) {
doCommentModUnBlockAsModerator(uri, creatorUri, '');
2021-06-16 10:27:58 +08:00
} else {
doCommentModBlockAsModerator(uri, creatorUri, '');
2021-06-16 10:27:58 +08:00
}
}
break;
case BLOCK_LEVEL.ADMIN:
if (isBlocked) {
doCommentModUnBlockAsAdmin(uri, '');
} else {
doCommentModBlockAsAdmin(uri, '');
}
break;
}
}
2021-06-16 10:27:58 +08:00
function getButtonText(blockLevel) {
switch (blockLevel) {
default:
case BLOCK_LEVEL.SELF:
case BLOCK_LEVEL.ADMIN:
return isBlocked
? isBlockingOrUnBlocking
? __('Unblocking...')
: __('Unblock')
: isBlockingOrUnBlocking
2021-06-16 10:27:58 +08:00
? __('Blocking...')
: __('Block');
case BLOCK_LEVEL.MODERATOR:
if (isToggling) {
return isBlocked ? __('Unblocking...') : __('Blocking...');
} else {
return isBlocked ? __('Unblock') : __('Block');
}
}
}
return <Button button={isBlocked ? 'alt' : 'secondary'} label={getButtonText(blockLevel)} onClick={handleClick} />;
}
export default ChannelBlockButton;