pl-fe: add some feedback on deleted post, remove unused feature

Signed-off-by: mkljczk <git@mkljczk.pl>
This commit is contained in:
mkljczk 2024-12-05 14:10:17 +01:00
parent 8de583e1eb
commit 40376e4576
7 changed files with 35 additions and 37 deletions

View file

@ -171,13 +171,7 @@ const unmuteStatus = (statusId: string) =>
}; };
const toggleMuteStatus = (status: Pick<Status, 'id' | 'muted'>) => const toggleMuteStatus = (status: Pick<Status, 'id' | 'muted'>) =>
(dispatch: AppDispatch) => { status.muted ? unmuteStatus(status.id) : muteStatus(status.id);
if (status.muted) {
dispatch(unmuteStatus(status.id));
} else {
dispatch(muteStatus(status.id));
}
};
// let TRANSLATIONS_QUEUE: Set<string> = new Set(); // let TRANSLATIONS_QUEUE: Set<string> = new Set();
// let TRANSLATIONS_TIMEOUT: NodeJS.Timeout | null = null; // let TRANSLATIONS_TIMEOUT: NodeJS.Timeout | null = null;

View file

@ -85,7 +85,6 @@ interface IAccount {
/** Override other actions for specificity like mute/unmute. */ /** Override other actions for specificity like mute/unmute. */
actionType?: 'muting' | 'blocking' | 'follow_request' | 'biting'; actionType?: 'muting' | 'blocking' | 'follow_request' | 'biting';
avatarSize?: number; avatarSize?: number;
hidden?: boolean;
hideActions?: boolean; hideActions?: boolean;
id?: string; id?: string;
onActionClick?: (account: AccountSchema) => void; onActionClick?: (account: AccountSchema) => void;
@ -115,7 +114,6 @@ const Account = ({
actionTitle, actionTitle,
actionAlignment = 'center', actionAlignment = 'center',
avatarSize = 42, avatarSize = 42,
hidden = false,
hideActions = false, hideActions = false,
onActionClick, onActionClick,
showAccountHoverCard = true, showAccountHoverCard = true,
@ -181,15 +179,6 @@ const Account = ({
return null; return null;
} }
if (hidden) {
return (
<>
{account.display_name}
{account.username}
</>
);
}
if (withDate) timestamp = account.created_at; if (withDate) timestamp = account.created_at;
const LinkEl: any = withLinkToProfile ? Link : 'div'; const LinkEl: any = withLinkToProfile ? Link : 'div';

View file

@ -29,6 +29,7 @@ import StatusLanguagePicker from './status-language-picker';
import StatusReactionsBar from './status-reactions-bar'; import StatusReactionsBar from './status-reactions-bar';
import StatusReplyMentions from './status-reply-mentions'; import StatusReplyMentions from './status-reply-mentions';
import StatusInfo from './statuses/status-info'; import StatusInfo from './statuses/status-info';
import Tombstone from './tombstone';
const messages = defineMessages({ const messages = defineMessages({
reblogged_by: { id: 'status.reblogged_by', defaultMessage: '{name} reposted' }, reblogged_by: { id: 'status.reblogged_by', defaultMessage: '{name} reposted' },
@ -40,7 +41,6 @@ interface IStatus {
status: SelectedStatus; status: SelectedStatus;
onClick?: () => void; onClick?: () => void;
muted?: boolean; muted?: boolean;
hidden?: boolean;
unread?: boolean; unread?: boolean;
onMoveUp?: (statusId: string, featured?: boolean) => void; onMoveUp?: (statusId: string, featured?: boolean) => void;
onMoveDown?: (statusId: string, featured?: boolean) => void; onMoveDown?: (statusId: string, featured?: boolean) => void;
@ -65,7 +65,6 @@ const Status: React.FC<IStatus> = (props) => {
onMoveUp, onMoveUp,
onMoveDown, onMoveDown,
muted, muted,
hidden,
featured, featured,
unread, unread,
hideActionBar, hideActionBar,
@ -95,7 +94,7 @@ const Status: React.FC<IStatus> = (props) => {
// Track height changes we know about to compensate scrolling. // Track height changes we know about to compensate scrolling.
useEffect(() => { useEffect(() => {
didShowCard.current = Boolean(!muted && !hidden && status?.card); didShowCard.current = Boolean(!muted && status?.card);
}, []); }, []);
const handleClick = (e?: React.MouseEvent) => { const handleClick = (e?: React.MouseEvent) => {
@ -299,16 +298,13 @@ const Status: React.FC<IStatus> = (props) => {
if (!status) return null; if (!status) return null;
if (hidden) { if (status.deleted) return (
return ( <Tombstone
<div ref={node}> id={status.id}
<> onMoveUp={onMoveUp}
{actualStatus.account.display_name || actualStatus.account.username} onMoveDown={onMoveDown}
{actualStatus.content} />
</>
</div>
); );
}
if (filtered && status.showFiltered !== false) { if (filtered && status.showFiltered !== false) {
const minHandlers = muted ? undefined : { const minHandlers = muted ? undefined : {

View file

@ -181,7 +181,6 @@ const buildMessage = (
const avatarSize = 48; const avatarSize = 48;
interface INotification { interface INotification {
hidden?: boolean;
notification: NotificationGroup; notification: NotificationGroup;
onMoveUp?: (notificationId: string) => void; onMoveUp?: (notificationId: string) => void;
onMoveDown?: (notificationId: string) => void; onMoveDown?: (notificationId: string) => void;
@ -196,7 +195,7 @@ const getNotificationStatus = (n: Pick<NotificationGroup, 'type'> & ({ status: S
}; };
const Notification: React.FC<INotification> = (props) => { const Notification: React.FC<INotification> = (props) => {
const { hidden = false, onMoveUp, onMoveDown } = props; const { onMoveUp, onMoveDown } = props;
const dispatch = useAppDispatch(); const dispatch = useAppDispatch();
@ -330,7 +329,6 @@ const Notification: React.FC<INotification> = (props) => {
return account && typeof account === 'object' ? ( return account && typeof account === 'object' ? (
<AccountContainer <AccountContainer
id={account.id} id={account.id}
hidden={hidden}
avatarSize={avatarSize} avatarSize={avatarSize}
actionType='follow_request' actionType='follow_request'
withRelationship withRelationship
@ -340,7 +338,6 @@ const Notification: React.FC<INotification> = (props) => {
return account && typeof account === 'object' ? ( return account && typeof account === 'object' ? (
<AccountContainer <AccountContainer
id={account.id} id={account.id}
hidden={hidden}
avatarSize={avatarSize} avatarSize={avatarSize}
actionType='biting' actionType='biting'
withRelationship withRelationship
@ -350,7 +347,6 @@ const Notification: React.FC<INotification> = (props) => {
return account && typeof account === 'object' && notification.target && typeof notification.target === 'object' ? ( return account && typeof account === 'object' && notification.target && typeof notification.target === 'object' ? (
<AccountContainer <AccountContainer
id={notification.target_id} id={notification.target_id}
hidden={hidden}
avatarSize={avatarSize} avatarSize={avatarSize}
withRelationship withRelationship
/> />
@ -368,7 +364,6 @@ const Notification: React.FC<INotification> = (props) => {
return status && typeof status === 'object' ? ( return status && typeof status === 'object' ? (
<StatusContainer <StatusContainer
id={status.id} id={status.id}
hidden={hidden}
onMoveDown={handleMoveDown} onMoveDown={handleMoveDown}
onMoveUp={handleMoveUp} onMoveUp={handleMoveUp}
avatarSize={avatarSize} avatarSize={avatarSize}

View file

@ -1,6 +1,7 @@
import clsx from 'clsx'; import clsx from 'clsx';
import React from 'react'; import React from 'react';
import Tombstone from 'pl-fe/components/tombstone';
import StatusContainer from 'pl-fe/containers/status-container'; import StatusContainer from 'pl-fe/containers/status-container';
import PlaceholderStatus from 'pl-fe/features/placeholder/components/placeholder-status'; import PlaceholderStatus from 'pl-fe/features/placeholder/components/placeholder-status';
import { useAppSelector } from 'pl-fe/hooks/use-app-selector'; import { useAppSelector } from 'pl-fe/hooks/use-app-selector';
@ -20,6 +21,20 @@ const ThreadStatus: React.FC<IThreadStatus> = (props): JSX.Element => {
const replyToId = useAppSelector(state => state.contexts.inReplyTos[id]); const replyToId = useAppSelector(state => state.contexts.inReplyTos[id]);
const replyCount = useAppSelector(state => (state.contexts.replies[id] || []).length); const replyCount = useAppSelector(state => (state.contexts.replies[id] || []).length);
const isLoaded = useAppSelector(state => Boolean(state.statuses[id])); const isLoaded = useAppSelector(state => Boolean(state.statuses[id]));
const isDeleted = useAppSelector(state => Boolean(state.statuses[id]?.deleted));
if (isDeleted) {
return (
<div className='py-4 pb-8'>
<Tombstone
key={id}
id={id}
onMoveUp={props.onMoveUp}
onMoveDown={props.onMoveDown}
/>
</div>
);
}
const renderConnector = (): JSX.Element | null => { const renderConnector = (): JSX.Element | null => {
const isConnectedTop = replyToId && replyToId !== focusedStatusId; const isConnectedTop = replyToId && replyToId !== focusedStatusId;

View file

@ -115,6 +115,7 @@ const normalizeStatus = (status: BaseStatus & {
group_id: status.group?.id || null, group_id: status.group?.id || null,
expectsCard: false, expectsCard: false,
showFiltered: null as null | boolean, showFiltered: null as null | boolean,
deleted: false,
...status, ...status,
quote_id: status.quote?.id || status.quote_id || null, quote_id: status.quote?.id || status.quote_id || null,
account: normalizeAccount(status.account), account: normalizeAccount(status.account),

View file

@ -40,6 +40,7 @@ import {
STATUS_UNFILTER, STATUS_UNFILTER,
STATUS_UNMUTE_SUCCESS, STATUS_UNMUTE_SUCCESS,
type StatusesAction, type StatusesAction,
STATUS_DELETE_SUCCESS,
} from '../actions/statuses'; } from '../actions/statuses';
import { TIMELINE_DELETE, type TimelineAction } from '../actions/timelines'; import { TIMELINE_DELETE, type TimelineAction } from '../actions/timelines';
@ -281,6 +282,13 @@ const statuses = (state = initialState, action: EmojiReactsAction | EventsAction
status.event.join_state = action.previousState; status.event.join_state = action.previousState;
} }
}); });
case STATUS_DELETE_SUCCESS:
return create(state, (draft) => {
const status = draft[action.statusId];
if (status) {
status.deleted = true;
}
});
default: default:
return state; return state;
} }