mirror of
https://github.com/glitch-soc/mastodon.git
synced 2025-12-14 00:08:46 +00:00
[Glitch] Add secondary Wrapstodon share button
Port 6821b70796 to glitch-soc
Signed-off-by: Claire <claire.github-309c@sitedethib.com>
This commit is contained in:
@@ -174,7 +174,7 @@ $mobile-breakpoint: 540px;
|
|||||||
|
|
||||||
.title {
|
.title {
|
||||||
text-transform: uppercase;
|
text-transform: uppercase;
|
||||||
color: #c2c8ff;
|
color: var(--color-text-brand-soft);
|
||||||
font-weight: 500;
|
font-weight: 500;
|
||||||
|
|
||||||
&:last-child {
|
&:last-child {
|
||||||
@@ -333,6 +333,19 @@ $mobile-breakpoint: 540px;
|
|||||||
mix-blend-mode: screen;
|
mix-blend-mode: screen;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.shareButtonWrapper {
|
||||||
|
display: flex;
|
||||||
|
flex-direction: column;
|
||||||
|
gap: 10px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.secondaryShareButton {
|
||||||
|
// Extra selector is needed to override color
|
||||||
|
&:global(.button) {
|
||||||
|
color: var(--color-text-primary);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.navItemBadge {
|
.navItemBadge {
|
||||||
background: var(--color-bg-brand-soft);
|
background: var(--color-bg-brand-soft);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -3,6 +3,7 @@ import type { FC } from 'react';
|
|||||||
|
|
||||||
import { defineMessages, useIntl } from 'react-intl';
|
import { defineMessages, useIntl } from 'react-intl';
|
||||||
|
|
||||||
|
import { showAlert } from '@/flavours/glitch/actions/alerts';
|
||||||
import { resetCompose, focusCompose } from '@/flavours/glitch/actions/compose';
|
import { resetCompose, focusCompose } from '@/flavours/glitch/actions/compose';
|
||||||
import { closeModal } from '@/flavours/glitch/actions/modal';
|
import { closeModal } from '@/flavours/glitch/actions/modal';
|
||||||
import { Button } from '@/flavours/glitch/components/button';
|
import { Button } from '@/flavours/glitch/components/button';
|
||||||
@@ -10,6 +11,7 @@ import type { AnnualReport as AnnualReportData } from '@/flavours/glitch/models/
|
|||||||
import { useAppDispatch } from '@/flavours/glitch/store';
|
import { useAppDispatch } from '@/flavours/glitch/store';
|
||||||
|
|
||||||
import { archetypeNames } from './archetype';
|
import { archetypeNames } from './archetype';
|
||||||
|
import styles from './index.module.scss';
|
||||||
|
|
||||||
const messages = defineMessages({
|
const messages = defineMessages({
|
||||||
share_message: {
|
share_message: {
|
||||||
@@ -20,11 +22,24 @@ const messages = defineMessages({
|
|||||||
id: 'annual_report.summary.share_on_mastodon',
|
id: 'annual_report.summary.share_on_mastodon',
|
||||||
defaultMessage: 'Share on Mastodon',
|
defaultMessage: 'Share on Mastodon',
|
||||||
},
|
},
|
||||||
|
share_elsewhere: {
|
||||||
|
id: 'annual_report.summary.share_elsewhere',
|
||||||
|
defaultMessage: 'Share elsewhere',
|
||||||
|
},
|
||||||
|
copy_link: {
|
||||||
|
id: 'annual_report.summary.copy_link',
|
||||||
|
defaultMessage: 'Copy link',
|
||||||
|
},
|
||||||
|
copied: {
|
||||||
|
id: 'copy_icon_button.copied',
|
||||||
|
defaultMessage: 'Copied to clipboard',
|
||||||
|
},
|
||||||
});
|
});
|
||||||
|
|
||||||
export const ShareButton: FC<{ report: AnnualReportData }> = ({ report }) => {
|
export const ShareButton: FC<{ report: AnnualReportData }> = ({ report }) => {
|
||||||
const intl = useIntl();
|
const intl = useIntl();
|
||||||
const dispatch = useAppDispatch();
|
const dispatch = useAppDispatch();
|
||||||
|
|
||||||
const handleShareClick = useCallback(() => {
|
const handleShareClick = useCallback(() => {
|
||||||
// Generate the share message.
|
// Generate the share message.
|
||||||
const archetypeName = intl.formatMessage(
|
const archetypeName = intl.formatMessage(
|
||||||
@@ -47,10 +62,35 @@ export const ShareButton: FC<{ report: AnnualReportData }> = ({ report }) => {
|
|||||||
dispatch(closeModal({ modalType: 'ANNUAL_REPORT', ignoreFocus: false }));
|
dispatch(closeModal({ modalType: 'ANNUAL_REPORT', ignoreFocus: false }));
|
||||||
}, [report, intl, dispatch]);
|
}, [report, intl, dispatch]);
|
||||||
|
|
||||||
|
const supportsNativeShare = 'share' in navigator;
|
||||||
|
|
||||||
|
const handleSecondaryShare = useCallback(() => {
|
||||||
|
if (report.schema_version === 2 && report.share_url) {
|
||||||
|
if (supportsNativeShare) {
|
||||||
|
void navigator.share({
|
||||||
|
url: report.share_url,
|
||||||
|
});
|
||||||
|
} else {
|
||||||
|
void navigator.clipboard.writeText(report.share_url);
|
||||||
|
dispatch(showAlert({ message: messages.copied }));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}, [report, supportsNativeShare, dispatch]);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Button
|
<div className={styles.shareButtonWrapper}>
|
||||||
text={intl.formatMessage(messages.share_on_mastodon)}
|
<Button
|
||||||
onClick={handleShareClick}
|
text={intl.formatMessage(messages.share_on_mastodon)}
|
||||||
/>
|
onClick={handleShareClick}
|
||||||
|
/>
|
||||||
|
<Button
|
||||||
|
plain
|
||||||
|
className={styles.secondaryShareButton}
|
||||||
|
text={intl.formatMessage(
|
||||||
|
supportsNativeShare ? messages.share_elsewhere : messages.copy_link,
|
||||||
|
)}
|
||||||
|
onClick={handleSecondaryShare}
|
||||||
|
/>
|
||||||
|
</div>
|
||||||
);
|
);
|
||||||
};
|
};
|
||||||
|
|||||||
Reference in New Issue
Block a user