pl-fe: Fix attachment thumbs visibility
Signed-off-by: marcin mikołajczak <git@mkljczk.pl>
This commit is contained in:
parent
62cb2b5882
commit
0867afefbd
8 changed files with 19 additions and 20 deletions
|
@ -2,31 +2,36 @@ import React, { Suspense } from 'react';
|
||||||
|
|
||||||
import { openModal } from 'pl-fe/actions/modals';
|
import { openModal } from 'pl-fe/actions/modals';
|
||||||
import { MediaGallery } from 'pl-fe/features/ui/util/async-components';
|
import { MediaGallery } from 'pl-fe/features/ui/util/async-components';
|
||||||
import { useAppDispatch } from 'pl-fe/hooks';
|
import { useAppDispatch, useSettings } from 'pl-fe/hooks';
|
||||||
|
|
||||||
|
import { isMediaVisible } from './statuses/sensitive-content-overlay';
|
||||||
|
|
||||||
import type { MediaAttachment } from 'pl-api';
|
import type { MediaAttachment } from 'pl-api';
|
||||||
|
import type { Status } from 'pl-fe/normalizers';
|
||||||
|
|
||||||
interface IAttachmentThumbs {
|
interface IAttachmentThumbs {
|
||||||
media: Array<MediaAttachment>;
|
status: Pick<Status, 'media_attachments' | 'sensitive' | 'spoiler_text'>;
|
||||||
onClick?(): void;
|
onClick?(): void;
|
||||||
sensitive?: boolean;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const AttachmentThumbs = (props: IAttachmentThumbs) => {
|
const AttachmentThumbs = ({ status, onClick }: IAttachmentThumbs) => {
|
||||||
const { media, onClick } = props;
|
|
||||||
const dispatch = useAppDispatch();
|
const dispatch = useAppDispatch();
|
||||||
|
const { displayMedia } = useSettings();
|
||||||
|
|
||||||
const fallback = <div className='media-gallery--compact' />;
|
const fallback = <div className='media-gallery--compact' />;
|
||||||
const onOpenMedia = (media: Array<MediaAttachment>, index: number) => dispatch(openModal('MEDIA', { media, index }));
|
const onOpenMedia = (media: Array<MediaAttachment>, index: number) => dispatch(openModal('MEDIA', { media, index }));
|
||||||
|
|
||||||
|
const visible = isMediaVisible(status, displayMedia);
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className='relative'>
|
<div className='relative'>
|
||||||
<Suspense fallback={fallback}>
|
<Suspense fallback={fallback}>
|
||||||
<MediaGallery
|
<MediaGallery
|
||||||
media={media}
|
media={status.media_attachments}
|
||||||
onOpenMedia={onOpenMedia}
|
onOpenMedia={onOpenMedia}
|
||||||
height={50}
|
height={50}
|
||||||
compact
|
compact
|
||||||
|
visible={visible}
|
||||||
/>
|
/>
|
||||||
</Suspense>
|
</Suspense>
|
||||||
|
|
||||||
|
|
|
@ -55,7 +55,7 @@ const StatusMedia: React.FC<IStatusMedia> = ({
|
||||||
if (muted) {
|
if (muted) {
|
||||||
media = (
|
media = (
|
||||||
<AttachmentThumbs
|
<AttachmentThumbs
|
||||||
media={status.media_attachments}
|
status={status}
|
||||||
onClick={onClick}
|
onClick={onClick}
|
||||||
/>
|
/>
|
||||||
);
|
);
|
||||||
|
|
|
@ -9,7 +9,7 @@ import { Button, HStack, Text } from '../ui';
|
||||||
|
|
||||||
import type { Status } from 'pl-fe/normalizers';
|
import type { Status } from 'pl-fe/normalizers';
|
||||||
|
|
||||||
const isMediaVisible = (status: Pick<Status, 'hidden' | 'media_attachments' | 'sensitive' | 'spoiler_text'>, displayMedia: 'default' | 'show_all' | 'hide_all') => {
|
const isMediaVisible = (status: Pick<Status, 'media_attachments' | 'sensitive' | 'spoiler_text'> & { hidden?: boolean | null }, displayMedia: 'default' | 'show_all' | 'hide_all') => {
|
||||||
let visible = !(status.sensitive || status.spoiler_text);
|
let visible = !(status.sensitive || status.spoiler_text);
|
||||||
|
|
||||||
if (status.hidden !== null) visible = !status.hidden;
|
if (status.hidden !== null) visible = !status.hidden;
|
||||||
|
|
|
@ -11,7 +11,7 @@ import type { Account, Status } from 'pl-fe/normalizers';
|
||||||
|
|
||||||
interface IReplyIndicator {
|
interface IReplyIndicator {
|
||||||
className?: string;
|
className?: string;
|
||||||
status?: Pick<Status, | 'contentHtml' | 'created_at' | 'media_attachments' | 'search_index' | 'sensitive'> & { account: Pick<Account, 'id'> };
|
status?: Pick<Status, | 'contentHtml' | 'created_at' | 'hidden' | 'media_attachments' | 'search_index' | 'sensitive' | 'spoiler_text'> & { account: Pick<Account, 'id'> };
|
||||||
onCancel?: () => void;
|
onCancel?: () => void;
|
||||||
hideActions: boolean;
|
hideActions: boolean;
|
||||||
}
|
}
|
||||||
|
@ -55,8 +55,7 @@ const ReplyIndicator: React.FC<IReplyIndicator> = ({ className, status, hideActi
|
||||||
|
|
||||||
{status.media_attachments.length > 0 && (
|
{status.media_attachments.length > 0 && (
|
||||||
<AttachmentThumbs
|
<AttachmentThumbs
|
||||||
media={status.media_attachments}
|
status={status}
|
||||||
sensitive={status.sensitive}
|
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
</Stack>
|
</Stack>
|
||||||
|
|
|
@ -71,8 +71,7 @@ const DraftStatus: React.FC<IDraftStatus> = ({ draftStatus, ...other }) => {
|
||||||
|
|
||||||
{status.media_attachments.length > 0 && (
|
{status.media_attachments.length > 0 && (
|
||||||
<AttachmentThumbs
|
<AttachmentThumbs
|
||||||
media={status.media_attachments}
|
status={status}
|
||||||
sensitive={status.sensitive}
|
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
|
|
|
@ -53,8 +53,7 @@ const ScheduledStatus: React.FC<IScheduledStatus> = ({ statusId, ...other }) =>
|
||||||
|
|
||||||
{status.media_attachments.length > 0 && (
|
{status.media_attachments.length > 0 && (
|
||||||
<AttachmentThumbs
|
<AttachmentThumbs
|
||||||
media={status.media_attachments}
|
status={status}
|
||||||
sensitive={status.sensitive}
|
|
||||||
/>
|
/>
|
||||||
)}
|
)}
|
||||||
|
|
||||||
|
|
|
@ -69,7 +69,7 @@ const CompareHistoryModal: React.FC<BaseModalProps & CompareHistoryModalProps> =
|
||||||
)}
|
)}
|
||||||
|
|
||||||
{version.media_attachments.length > 0 && (
|
{version.media_attachments.length > 0 && (
|
||||||
<AttachmentThumbs media={version.media_attachments} />
|
<AttachmentThumbs status={version} />
|
||||||
)}
|
)}
|
||||||
|
|
||||||
<Text align='right' tag='span' theme='muted' size='sm'>
|
<Text align='right' tag='span' theme='muted' size='sm'>
|
||||||
|
|
|
@ -58,10 +58,7 @@ const SelectedStatus = ({ statusId }: { statusId: string }) => {
|
||||||
<StatusContent status={status} />
|
<StatusContent status={status} />
|
||||||
|
|
||||||
{status.media_attachments.length > 0 && (
|
{status.media_attachments.length > 0 && (
|
||||||
<AttachmentThumbs
|
<AttachmentThumbs status={status} />
|
||||||
media={status.media_attachments}
|
|
||||||
sensitive={status.sensitive}
|
|
||||||
/>
|
|
||||||
)}
|
)}
|
||||||
</Stack>
|
</Stack>
|
||||||
);
|
);
|
||||||
|
|
Loading…
Reference in a new issue