[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:
diondiondion
2025-12-12 14:39:56 +01:00
committed by Claire
parent acf583d374
commit cb1d1e289e
2 changed files with 58 additions and 5 deletions

View File

@@ -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);
} }

View File

@@ -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>
); );
}; };