Merge branch 'events' into 'develop'

Show Unauthorized modal for 'X people going'

See merge request soapbox-pub/soapbox!1979
This commit is contained in:
marcin mikołajczak 2022-12-08 14:28:13 +00:00
commit 41746b84d9
3 changed files with 49 additions and 30 deletions

View file

@ -20,6 +20,7 @@ import { HStack } from 'soapbox/components/ui';
import DropdownMenuContainer from 'soapbox/containers/dropdown-menu-container';
import { useAppDispatch, useAppSelector, useFeatures, useOwnAccount, useSettings, useSoapboxConfig } from 'soapbox/hooks';
import { isLocal, isRemote } from 'soapbox/utils/accounts';
import copy from 'soapbox/utils/copy';
import { getReactForStatus, reduceEmoji } from 'soapbox/utils/emoji-reacts';
import type { Menu } from 'soapbox/components/dropdown-menu';
@ -267,21 +268,8 @@ const StatusActionBar: React.FC<IStatusActionBar> = ({
const handleCopy: React.EventHandler<React.MouseEvent> = (e) => {
const { uri } = status;
const textarea = document.createElement('textarea');
textarea.textContent = uri;
textarea.style.position = 'fixed';
document.body.appendChild(textarea);
try {
textarea.select();
document.execCommand('copy');
} catch {
// Do nothing
} finally {
document.body.removeChild(textarea);
}
copy(uri);
};
const onModerate: React.MouseEventHandler = (e) => {

View file

@ -19,6 +19,8 @@ import { Button, HStack, IconButton, Menu, MenuButton, MenuDivider, MenuItem, Me
import SvgIcon from 'soapbox/components/ui/icon/svg-icon';
import VerificationBadge from 'soapbox/components/verification-badge';
import { useAppDispatch, useFeatures, useOwnAccount } from 'soapbox/hooks';
import { isRemote } from 'soapbox/utils/accounts';
import copy from 'soapbox/utils/copy';
import { download } from 'soapbox/utils/download';
import { shortNumberFormat } from 'soapbox/utils/numbers';
@ -33,6 +35,7 @@ const messages = defineMessages({
bannerHeader: { id: 'event.banner', defaultMessage: 'Event banner' },
exportIcs: { id: 'event.export_ics', defaultMessage: 'Export to your calendar' },
copy: { id: 'event.copy', defaultMessage: 'Copy link to event' },
external: { id: 'event.external', defaultMessage: 'View event on {domain}' },
bookmark: { id: 'status.bookmark', defaultMessage: 'Bookmark' },
unbookmark: { id: 'status.unbookmark', defaultMessage: 'Remove bookmark' },
quotePost: { id: 'status.quote', defaultMessage: 'Quote post' },
@ -105,21 +108,12 @@ const EventHeader: React.FC<IEventHeader> = ({ status }) => {
const handleCopy = () => {
const { uri } = status;
const textarea = document.createElement('textarea');
textarea.textContent = uri;
textarea.style.position = 'fixed';
copy(uri);
};
document.body.appendChild(textarea);
try {
textarea.select();
document.execCommand('copy');
} catch {
// Do nothing
} finally {
document.body.removeChild(textarea);
}
const handleExternalClick = () => {
window.open(status.uri, '_blank');
};
const handleBookmarkClick = () => {
@ -196,6 +190,8 @@ const EventHeader: React.FC<IEventHeader> = ({ status }) => {
};
const makeMenu = (): MenuType => {
const domain = account.fqn.split('@')[1];
const menu: MenuType = [
{
text: intl.formatMessage(messages.exportIcs),
@ -209,6 +205,14 @@ const EventHeader: React.FC<IEventHeader> = ({ status }) => {
},
];
if (features.federating && isRemote(account)) {
menu.push({
text: intl.formatMessage(messages.external, { domain }),
action: handleExternalClick,
icon: require('@tabler/icons/external-link.svg'),
});
}
if (!ownAccount) return menu;
if (features.bookmarks) {
@ -329,9 +333,13 @@ const EventHeader: React.FC<IEventHeader> = ({ status }) => {
e.preventDefault();
e.stopPropagation();
dispatch(openModal('EVENT_PARTICIPANTS', {
statusId: status.id,
}));
if (!ownAccount) {
dispatch(openModal('UNAUTHORIZED'));
} else {
dispatch(openModal('EVENT_PARTICIPANTS', {
statusId: status.id,
}));
}
};
return (

23
app/soapbox/utils/copy.ts Normal file
View file

@ -0,0 +1,23 @@
const copy = (text: string) => {
if (navigator.clipboard) {
navigator.clipboard.writeText(text);
} else {
const textarea = document.createElement('textarea');
textarea.textContent = text;
textarea.style.position = 'fixed';
document.body.appendChild(textarea);
try {
textarea.select();
document.execCommand('copy');
} catch {
// Do nothing
} finally {
document.body.removeChild(textarea);
}
}
};
export default copy;