pl-fe: Remove unused code
Signed-off-by: mkljczk <git@mkljczk.pl>
This commit is contained in:
parent
65772abf87
commit
2053998732
9 changed files with 2 additions and 270 deletions
|
@ -30,8 +30,6 @@ const TIMELINE_EXPAND_REQUEST = 'TIMELINE_EXPAND_REQUEST' as const;
|
||||||
const TIMELINE_EXPAND_SUCCESS = 'TIMELINE_EXPAND_SUCCESS' as const;
|
const TIMELINE_EXPAND_SUCCESS = 'TIMELINE_EXPAND_SUCCESS' as const;
|
||||||
const TIMELINE_EXPAND_FAIL = 'TIMELINE_EXPAND_FAIL' as const;
|
const TIMELINE_EXPAND_FAIL = 'TIMELINE_EXPAND_FAIL' as const;
|
||||||
|
|
||||||
const TIMELINE_INSERT = 'TIMELINE_INSERT' as const;
|
|
||||||
|
|
||||||
const MAX_QUEUED_ITEMS = 40;
|
const MAX_QUEUED_ITEMS = 40;
|
||||||
|
|
||||||
const processTimelineUpdate = (timeline: string, status: BaseStatus) =>
|
const processTimelineUpdate = (timeline: string, status: BaseStatus) =>
|
||||||
|
@ -329,8 +327,6 @@ const scrollTopTimeline = (timeline: string, top: boolean) => ({
|
||||||
top,
|
top,
|
||||||
});
|
});
|
||||||
|
|
||||||
const insertSuggestionsIntoTimeline = () => ({ type: TIMELINE_INSERT, timeline: 'home' });
|
|
||||||
|
|
||||||
// TODO: other actions
|
// TODO: other actions
|
||||||
type TimelineAction =
|
type TimelineAction =
|
||||||
| ReturnType<typeof updateTimeline>
|
| ReturnType<typeof updateTimeline>
|
||||||
|
@ -341,8 +337,7 @@ type TimelineAction =
|
||||||
| ReturnType<typeof scrollTopTimeline>
|
| ReturnType<typeof scrollTopTimeline>
|
||||||
| ReturnType<typeof expandTimelineRequest>
|
| ReturnType<typeof expandTimelineRequest>
|
||||||
| ReturnType<typeof expandTimelineSuccess>
|
| ReturnType<typeof expandTimelineSuccess>
|
||||||
| ReturnType<typeof expandTimelineFail>
|
| ReturnType<typeof expandTimelineFail>;
|
||||||
| ReturnType<typeof insertSuggestionsIntoTimeline>;
|
|
||||||
|
|
||||||
export {
|
export {
|
||||||
TIMELINE_UPDATE,
|
TIMELINE_UPDATE,
|
||||||
|
@ -354,11 +349,8 @@ export {
|
||||||
TIMELINE_EXPAND_REQUEST,
|
TIMELINE_EXPAND_REQUEST,
|
||||||
TIMELINE_EXPAND_SUCCESS,
|
TIMELINE_EXPAND_SUCCESS,
|
||||||
TIMELINE_EXPAND_FAIL,
|
TIMELINE_EXPAND_FAIL,
|
||||||
TIMELINE_INSERT,
|
|
||||||
MAX_QUEUED_ITEMS,
|
MAX_QUEUED_ITEMS,
|
||||||
processTimelineUpdate,
|
processTimelineUpdate,
|
||||||
updateTimeline,
|
|
||||||
updateTimelineQueue,
|
|
||||||
dequeueTimeline,
|
dequeueTimeline,
|
||||||
deleteFromTimelines,
|
deleteFromTimelines,
|
||||||
clearTimeline,
|
clearTimeline,
|
||||||
|
@ -371,6 +363,5 @@ export {
|
||||||
fetchHashtagTimeline,
|
fetchHashtagTimeline,
|
||||||
expandTimelineSuccess,
|
expandTimelineSuccess,
|
||||||
scrollTopTimeline,
|
scrollTopTimeline,
|
||||||
insertSuggestionsIntoTimeline,
|
|
||||||
type TimelineAction,
|
type TimelineAction,
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,55 +0,0 @@
|
||||||
import { getClient } from '../api';
|
|
||||||
|
|
||||||
import { importEntities } from './importer';
|
|
||||||
|
|
||||||
import type { Status } from 'pl-api';
|
|
||||||
import type { AppDispatch, RootState } from 'pl-fe/store';
|
|
||||||
|
|
||||||
const TRENDING_STATUSES_FETCH_REQUEST = 'TRENDING_STATUSES_FETCH_REQUEST' as const;
|
|
||||||
const TRENDING_STATUSES_FETCH_SUCCESS = 'TRENDING_STATUSES_FETCH_SUCCESS' as const;
|
|
||||||
const TRENDING_STATUSES_FETCH_FAIL = 'TRENDING_STATUSES_FETCH_FAIL' as const;
|
|
||||||
|
|
||||||
interface TrendingStatusesFetchRequestAction {
|
|
||||||
type: typeof TRENDING_STATUSES_FETCH_REQUEST;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface TrendingStatusesFetchSuccessAction {
|
|
||||||
type: typeof TRENDING_STATUSES_FETCH_SUCCESS;
|
|
||||||
statuses: Array<Status>;
|
|
||||||
}
|
|
||||||
|
|
||||||
interface TrendingStatusesFetchFailAction {
|
|
||||||
type: typeof TRENDING_STATUSES_FETCH_FAIL;
|
|
||||||
error: any;
|
|
||||||
}
|
|
||||||
|
|
||||||
const fetchTrendingStatuses = () =>
|
|
||||||
(dispatch: AppDispatch, getState: () => RootState) => {
|
|
||||||
const state = getState();
|
|
||||||
const client = getClient(state);
|
|
||||||
|
|
||||||
if (!client.features.trendingStatuses) return;
|
|
||||||
|
|
||||||
dispatch<TrendingStatusesFetchRequestAction>({ type: TRENDING_STATUSES_FETCH_REQUEST });
|
|
||||||
|
|
||||||
return client.trends.getTrendingStatuses().then((statuses) => {
|
|
||||||
dispatch(importEntities({ statuses }));
|
|
||||||
dispatch<TrendingStatusesFetchSuccessAction>({ type: TRENDING_STATUSES_FETCH_SUCCESS, statuses });
|
|
||||||
return statuses;
|
|
||||||
}).catch(error => {
|
|
||||||
dispatch<TrendingStatusesFetchFailAction>({ type: TRENDING_STATUSES_FETCH_FAIL, error });
|
|
||||||
});
|
|
||||||
};
|
|
||||||
|
|
||||||
type TrendingStatusesAction =
|
|
||||||
| TrendingStatusesFetchRequestAction
|
|
||||||
| TrendingStatusesFetchSuccessAction
|
|
||||||
| TrendingStatusesFetchFailAction;
|
|
||||||
|
|
||||||
export {
|
|
||||||
TRENDING_STATUSES_FETCH_REQUEST,
|
|
||||||
TRENDING_STATUSES_FETCH_SUCCESS,
|
|
||||||
TRENDING_STATUSES_FETCH_FAIL,
|
|
||||||
fetchTrendingStatuses,
|
|
||||||
type TrendingStatusesAction,
|
|
||||||
};
|
|
|
@ -8,10 +8,8 @@ import ScrollableList, { type IScrollableListWithContainer } from 'pl-fe/compone
|
||||||
import Stack from 'pl-fe/components/ui/stack';
|
import Stack from 'pl-fe/components/ui/stack';
|
||||||
import Text from 'pl-fe/components/ui/text';
|
import Text from 'pl-fe/components/ui/text';
|
||||||
import StatusContainer from 'pl-fe/containers/status-container';
|
import StatusContainer from 'pl-fe/containers/status-container';
|
||||||
import FeedSuggestions from 'pl-fe/features/feed-suggestions/feed-suggestions';
|
|
||||||
import PlaceholderStatus from 'pl-fe/features/placeholder/components/placeholder-status';
|
import PlaceholderStatus from 'pl-fe/features/placeholder/components/placeholder-status';
|
||||||
import PendingStatus from 'pl-fe/features/ui/components/pending-status';
|
import PendingStatus from 'pl-fe/features/ui/components/pending-status';
|
||||||
import { usePlFeConfig } from 'pl-fe/hooks/use-pl-fe-config';
|
|
||||||
|
|
||||||
interface IStatusList extends Omit<IScrollableListWithContainer, 'onLoadMore' | 'children'> {
|
interface IStatusList extends Omit<IScrollableListWithContainer, 'onLoadMore' | 'children'> {
|
||||||
/** Unique key to preserve the scroll position when navigating back. */
|
/** Unique key to preserve the scroll position when navigating back. */
|
||||||
|
@ -54,8 +52,6 @@ const StatusList: React.FC<IStatusList> = ({
|
||||||
className,
|
className,
|
||||||
...other
|
...other
|
||||||
}) => {
|
}) => {
|
||||||
const plFeConfig = usePlFeConfig();
|
|
||||||
|
|
||||||
const getFeaturedStatusCount = () => featuredStatusIds?.length || 0;
|
const getFeaturedStatusCount = () => featuredStatusIds?.length || 0;
|
||||||
|
|
||||||
const getCurrentStatusIndex = (id: string, featured: boolean): number => {
|
const getCurrentStatusIndex = (id: string, featured: boolean): number => {
|
||||||
|
@ -79,7 +75,7 @@ const StatusList: React.FC<IStatusList> = ({
|
||||||
const handleLoadOlder = useCallback(debounce(() => {
|
const handleLoadOlder = useCallback(debounce(() => {
|
||||||
const maxId = lastStatusId || statusIds.at(-1);
|
const maxId = lastStatusId || statusIds.at(-1);
|
||||||
if (onLoadMore && maxId) {
|
if (onLoadMore && maxId) {
|
||||||
onLoadMore(maxId.replace('末suggestions-', ''));
|
onLoadMore(maxId);
|
||||||
}
|
}
|
||||||
}, 300, { leading: true }), [onLoadMore, lastStatusId, statusIds.at(-1)]);
|
}, 300, { leading: true }), [onLoadMore, lastStatusId, statusIds.at(-1)]);
|
||||||
|
|
||||||
|
@ -149,15 +145,6 @@ const StatusList: React.FC<IStatusList> = ({
|
||||||
));
|
));
|
||||||
};
|
};
|
||||||
|
|
||||||
const renderFeedSuggestions = (statusId: string): React.ReactNode => (
|
|
||||||
<FeedSuggestions
|
|
||||||
key='suggestions'
|
|
||||||
statusId={statusId}
|
|
||||||
onMoveUp={handleMoveUp}
|
|
||||||
onMoveDown={handleMoveDown}
|
|
||||||
/>
|
|
||||||
);
|
|
||||||
|
|
||||||
const renderStatuses = (): React.ReactNode[] => {
|
const renderStatuses = (): React.ReactNode[] => {
|
||||||
if (isLoading || statusIds.length > 0) {
|
if (isLoading || statusIds.length > 0) {
|
||||||
return statusIds.reduce((acc, statusId, index) => {
|
return statusIds.reduce((acc, statusId, index) => {
|
||||||
|
@ -166,10 +153,6 @@ const StatusList: React.FC<IStatusList> = ({
|
||||||
if (gap) {
|
if (gap) {
|
||||||
acc.push(gap);
|
acc.push(gap);
|
||||||
}
|
}
|
||||||
} else if (statusId.startsWith('末suggestions-')) {
|
|
||||||
if (plFeConfig.feedInjection) {
|
|
||||||
acc.push(renderFeedSuggestions(statusId));
|
|
||||||
}
|
|
||||||
} else if (statusId.startsWith('末pending-')) {
|
} else if (statusId.startsWith('末pending-')) {
|
||||||
acc.push(renderPendingStatus(statusId));
|
acc.push(renderPendingStatus(statusId));
|
||||||
} else {
|
} else {
|
||||||
|
|
|
@ -1,119 +0,0 @@
|
||||||
import React from 'react';
|
|
||||||
import { defineMessages, useIntl } from 'react-intl';
|
|
||||||
import { Link } from 'react-router-dom';
|
|
||||||
|
|
||||||
import { useAccount } from 'pl-fe/api/hooks/accounts/use-account';
|
|
||||||
import { useSuggestedAccounts } from 'pl-fe/api/hooks/trends/use-suggested-accounts';
|
|
||||||
import Card, { CardBody, CardTitle } from 'pl-fe/components/ui/card';
|
|
||||||
import HStack from 'pl-fe/components/ui/hstack';
|
|
||||||
import Stack from 'pl-fe/components/ui/stack';
|
|
||||||
import Text from 'pl-fe/components/ui/text';
|
|
||||||
import VerificationBadge from 'pl-fe/components/verification-badge';
|
|
||||||
|
|
||||||
import Emojify from '../emoji/emojify';
|
|
||||||
import ActionButton from '../ui/components/action-button';
|
|
||||||
import { HotKeys } from '../ui/components/hotkeys';
|
|
||||||
|
|
||||||
const messages = defineMessages({
|
|
||||||
heading: { id: 'feed_suggestions.heading', defaultMessage: 'Suggested profiles' },
|
|
||||||
viewAll: { id: 'feed_suggestions.view_all', defaultMessage: 'View all' },
|
|
||||||
});
|
|
||||||
|
|
||||||
interface ISuggestionItem {
|
|
||||||
accountId: string;
|
|
||||||
}
|
|
||||||
|
|
||||||
const SuggestionItem: React.FC<ISuggestionItem> = ({ accountId }) => {
|
|
||||||
const { account } = useAccount(accountId);
|
|
||||||
if (!account) return null;
|
|
||||||
|
|
||||||
return (
|
|
||||||
<Stack space={3} className='w-52 shrink-0 rounded-md border border-solid border-gray-300 p-4 dark:border-gray-800 md:w-full md:shrink md:border-transparent md:p-0 dark:md:border-transparent'>
|
|
||||||
<Link
|
|
||||||
to={`/@${account.acct}`}
|
|
||||||
title={account.acct}
|
|
||||||
>
|
|
||||||
<Stack space={3} className='mx-auto w-40 md:w-24'>
|
|
||||||
<img
|
|
||||||
src={account.avatar}
|
|
||||||
className='mx-auto block size-16 min-w-[56px] rounded-full object-cover'
|
|
||||||
alt={account.acct}
|
|
||||||
/>
|
|
||||||
|
|
||||||
<Stack>
|
|
||||||
<HStack alignItems='center' justifyContent='center' space={1}>
|
|
||||||
<Text weight='semibold' truncate align='center' size='sm' className='max-w-[95%]'>
|
|
||||||
<Emojify text={account.display_name} emojis={account.emojis} />
|
|
||||||
</Text>
|
|
||||||
|
|
||||||
{account.verified && <VerificationBadge />}
|
|
||||||
</HStack>
|
|
||||||
|
|
||||||
<Text theme='muted' align='center' size='sm' truncate>@{account.acct}</Text>
|
|
||||||
</Stack>
|
|
||||||
</Stack>
|
|
||||||
</Link>
|
|
||||||
|
|
||||||
<div className='text-center'>
|
|
||||||
<ActionButton account={account} />
|
|
||||||
</div>
|
|
||||||
</Stack>
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
interface IFeedSuggesetions {
|
|
||||||
statusId: string;
|
|
||||||
onMoveUp?: (statusId: string, featured?: boolean) => void;
|
|
||||||
onMoveDown?: (statusId: string, featured?: boolean) => void;
|
|
||||||
}
|
|
||||||
|
|
||||||
const FeedSuggestions: React.FC<IFeedSuggesetions> = ({ statusId, onMoveUp, onMoveDown }) => {
|
|
||||||
const intl = useIntl();
|
|
||||||
const { data: suggestedProfiles, isLoading } = useSuggestedAccounts();
|
|
||||||
|
|
||||||
if (!isLoading && suggestedProfiles?.length === 0) return null;
|
|
||||||
|
|
||||||
const handleHotkeyMoveUp = (e?: KeyboardEvent): void => {
|
|
||||||
if (onMoveUp) {
|
|
||||||
onMoveUp(statusId);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const handleHotkeyMoveDown = (e?: KeyboardEvent): void => {
|
|
||||||
if (onMoveDown) {
|
|
||||||
onMoveDown(statusId);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const handlers = {
|
|
||||||
moveUp: handleHotkeyMoveUp,
|
|
||||||
moveDown: handleHotkeyMoveDown,
|
|
||||||
};
|
|
||||||
|
|
||||||
return (
|
|
||||||
<HotKeys handlers={handlers}>
|
|
||||||
<Card size='lg' variant='rounded' className='focusable space-y-6' tabIndex={0}>
|
|
||||||
<HStack justifyContent='between' alignItems='center'>
|
|
||||||
<CardTitle title={intl.formatMessage(messages.heading)} />
|
|
||||||
|
|
||||||
<Link
|
|
||||||
to='/suggestions'
|
|
||||||
className='text-primary-600 hover:underline dark:text-accent-blue'
|
|
||||||
>
|
|
||||||
{intl.formatMessage(messages.viewAll)}
|
|
||||||
</Link>
|
|
||||||
</HStack>
|
|
||||||
|
|
||||||
<CardBody>
|
|
||||||
<HStack space={4} alignItems='center' className='overflow-x-auto md:space-x-0 lg:overflow-x-hidden'>
|
|
||||||
{suggestedProfiles?.slice(0, 4).map((suggestedProfile) => (
|
|
||||||
<SuggestionItem key={suggestedProfile.account_id} accountId={suggestedProfile.account_id} />
|
|
||||||
))}
|
|
||||||
</HStack>
|
|
||||||
</CardBody>
|
|
||||||
</Card>
|
|
||||||
</HotKeys>
|
|
||||||
);
|
|
||||||
};
|
|
||||||
|
|
||||||
export { FeedSuggestions as default };
|
|
|
@ -45,8 +45,6 @@ const messages = defineMessages({
|
||||||
displayCtaLabel: { id: 'plfe_config.cta_label', defaultMessage: 'Display call to action panels if not authenticated' },
|
displayCtaLabel: { id: 'plfe_config.cta_label', defaultMessage: 'Display call to action panels if not authenticated' },
|
||||||
mediaPreviewLabel: { id: 'plfe_config.media_preview_label', defaultMessage: 'Prefer preview media for thumbnails' },
|
mediaPreviewLabel: { id: 'plfe_config.media_preview_label', defaultMessage: 'Prefer preview media for thumbnails' },
|
||||||
mediaPreviewHint: { id: 'plfe_config.media_preview_hint', defaultMessage: 'Some backends provide an optimized version of media for display in timelines. However, these preview images may be too small without additional configuration.' },
|
mediaPreviewHint: { id: 'plfe_config.media_preview_hint', defaultMessage: 'Some backends provide an optimized version of media for display in timelines. However, these preview images may be too small without additional configuration.' },
|
||||||
feedInjectionLabel: { id: 'plfe_config.feed_injection_label', defaultMessage: 'Feed injection' },
|
|
||||||
feedInjectionHint: { id: 'plfe_config.feed_injection_hint', defaultMessage: 'Inject the feed with additional content, such as suggested profiles.' },
|
|
||||||
tileServerLabel: { id: 'plfe_config.tile_server_label', defaultMessage: 'Map tile server' },
|
tileServerLabel: { id: 'plfe_config.tile_server_label', defaultMessage: 'Map tile server' },
|
||||||
tileServerAttributionLabel: { id: 'plfe_config.tile_server_attribution_label', defaultMessage: 'Map tiles attribution' },
|
tileServerAttributionLabel: { id: 'plfe_config.tile_server_attribution_label', defaultMessage: 'Map tiles attribution' },
|
||||||
redirectRootNoLoginLabel: { id: 'plfe_config.redirect_root_no_login_label', defaultMessage: 'Redirect homepage' },
|
redirectRootNoLoginLabel: { id: 'plfe_config.redirect_root_no_login_label', defaultMessage: 'Redirect homepage' },
|
||||||
|
@ -231,16 +229,6 @@ const PlFeConfigEditor: React.FC = () => {
|
||||||
/>
|
/>
|
||||||
</ListItem>
|
</ListItem>
|
||||||
|
|
||||||
<ListItem
|
|
||||||
label={intl.formatMessage(messages.feedInjectionLabel)}
|
|
||||||
hint={intl.formatMessage(messages.feedInjectionHint)}
|
|
||||||
>
|
|
||||||
<Toggle
|
|
||||||
checked={plFe.feedInjection === true}
|
|
||||||
onChange={handleChange('feedInjection', (e) => e.target.checked)}
|
|
||||||
/>
|
|
||||||
</ListItem>
|
|
||||||
|
|
||||||
<ListItem
|
<ListItem
|
||||||
label={intl.formatMessage(messages.mediaPreviewLabel)}
|
label={intl.formatMessage(messages.mediaPreviewLabel)}
|
||||||
hint={intl.formatMessage(messages.mediaPreviewHint)}
|
hint={intl.formatMessage(messages.mediaPreviewHint)}
|
||||||
|
|
|
@ -95,8 +95,6 @@ const plFeConfigSchema = v.pipe(coerceObject({
|
||||||
linkFooterMessage: v.fallback(v.string(), ''),
|
linkFooterMessage: v.fallback(v.string(), ''),
|
||||||
links: v.fallback(v.record(v.string(), v.string()), {}),
|
links: v.fallback(v.record(v.string(), v.string()), {}),
|
||||||
displayCta: v.fallback(v.boolean(), false),
|
displayCta: v.fallback(v.boolean(), false),
|
||||||
/** Whether to inject suggested profiles into the Home feed. */
|
|
||||||
feedInjection: v.fallback(v.boolean(), true),
|
|
||||||
tileServer: v.fallback(v.string(), ''),
|
tileServer: v.fallback(v.string(), ''),
|
||||||
tileServerAttribution: v.fallback(v.string(), ''),
|
tileServerAttribution: v.fallback(v.string(), ''),
|
||||||
redirectRootNoLogin: v.fallback(v.pipe(v.string(), v.transform((url: string) => {
|
redirectRootNoLogin: v.fallback(v.pipe(v.string(), v.transform((url: string) => {
|
||||||
|
|
|
@ -37,7 +37,6 @@ import status_lists from './status-lists';
|
||||||
import statuses from './statuses';
|
import statuses from './statuses';
|
||||||
import tags from './tags';
|
import tags from './tags';
|
||||||
import timelines from './timelines';
|
import timelines from './timelines';
|
||||||
import trending_statuses from './trending-statuses';
|
|
||||||
import user_lists from './user-lists';
|
import user_lists from './user-lists';
|
||||||
|
|
||||||
const reducers = {
|
const reducers = {
|
||||||
|
@ -75,7 +74,6 @@ const reducers = {
|
||||||
statuses,
|
statuses,
|
||||||
tags,
|
tags,
|
||||||
timelines,
|
timelines,
|
||||||
trending_statuses,
|
|
||||||
user_lists,
|
user_lists,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -1,4 +1,3 @@
|
||||||
import sample from 'lodash/sample';
|
|
||||||
import { create } from 'mutative';
|
import { create } from 'mutative';
|
||||||
|
|
||||||
import { ACCOUNT_BLOCK_SUCCESS, ACCOUNT_MUTE_SUCCESS, type AccountsAction } from '../actions/accounts';
|
import { ACCOUNT_BLOCK_SUCCESS, ACCOUNT_MUTE_SUCCESS, type AccountsAction } from '../actions/accounts';
|
||||||
|
@ -15,7 +14,6 @@ import {
|
||||||
TIMELINE_DEQUEUE,
|
TIMELINE_DEQUEUE,
|
||||||
MAX_QUEUED_ITEMS,
|
MAX_QUEUED_ITEMS,
|
||||||
TIMELINE_SCROLL_TOP,
|
TIMELINE_SCROLL_TOP,
|
||||||
TIMELINE_INSERT,
|
|
||||||
type TimelineAction,
|
type TimelineAction,
|
||||||
} from '../actions/timelines';
|
} from '../actions/timelines';
|
||||||
|
|
||||||
|
@ -333,21 +331,6 @@ const timelines = (state: State = initialState, action: AccountsAction | Interac
|
||||||
// return filterTimeline(state, 'home', action.relationship, action.statuses);
|
// return filterTimeline(state, 'home', action.relationship, action.statuses);
|
||||||
case TIMELINE_SCROLL_TOP:
|
case TIMELINE_SCROLL_TOP:
|
||||||
return create(state, (draft) => updateTop(state, action.timeline, action.top));
|
return create(state, (draft) => updateTop(state, action.timeline, action.top));
|
||||||
case TIMELINE_INSERT:
|
|
||||||
return create(state, (draft) => updateTimeline(draft, action.timeline, (timeline) => {
|
|
||||||
let oldIdsArray = timeline.items;
|
|
||||||
const existingSuggestionId = oldIdsArray.find(key => key.includes('末suggestions'));
|
|
||||||
|
|
||||||
if (existingSuggestionId) {
|
|
||||||
oldIdsArray = oldIdsArray.slice(1);
|
|
||||||
}
|
|
||||||
const positionInTimeline = sample([5, 6, 7, 8, 9]) as number;
|
|
||||||
if (timeline.items.at(-1)) {
|
|
||||||
oldIdsArray.splice(positionInTimeline, 0, `末suggestions-${timeline.items.at(-1)}`);
|
|
||||||
}
|
|
||||||
|
|
||||||
timeline.items = oldIdsArray;
|
|
||||||
}));
|
|
||||||
case PIN_SUCCESS:
|
case PIN_SUCCESS:
|
||||||
return create(state, (draft) => updateTimeline(draft, `account:${action.accountId}:with_replies:pinned`, (timeline) => {
|
return create(state, (draft) => updateTimeline(draft, `account:${action.accountId}:with_replies:pinned`, (timeline) => {
|
||||||
timeline.items = [...new Set([action.statusId, ...timeline.items])];
|
timeline.items = [...new Set([action.statusId, ...timeline.items])];
|
||||||
|
|
|
@ -1,35 +0,0 @@
|
||||||
import { create } from 'mutative';
|
|
||||||
|
|
||||||
import { TRENDING_STATUSES_FETCH_REQUEST, TRENDING_STATUSES_FETCH_SUCCESS, type TrendingStatusesAction } from 'pl-fe/actions/trending-statuses';
|
|
||||||
|
|
||||||
import type { Status } from 'pl-api';
|
|
||||||
|
|
||||||
interface State {
|
|
||||||
items: Array<string>;
|
|
||||||
isLoading: boolean;
|
|
||||||
}
|
|
||||||
|
|
||||||
const initialState: State = {
|
|
||||||
items: [],
|
|
||||||
isLoading: false,
|
|
||||||
};
|
|
||||||
|
|
||||||
const toIds = (items: Array<Status>) => items.map(item => item.id);
|
|
||||||
|
|
||||||
const trending_statuses = (state = initialState, action: TrendingStatusesAction) => {
|
|
||||||
switch (action.type) {
|
|
||||||
case TRENDING_STATUSES_FETCH_REQUEST:
|
|
||||||
return create(state, (draft) => {
|
|
||||||
draft.isLoading = true;
|
|
||||||
});
|
|
||||||
case TRENDING_STATUSES_FETCH_SUCCESS:
|
|
||||||
return create(state, (draft) => {
|
|
||||||
draft.items = toIds(action.statuses);
|
|
||||||
draft.isLoading = false;
|
|
||||||
});
|
|
||||||
default:
|
|
||||||
return state;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
export { trending_statuses as default };
|
|
Loading…
Reference in a new issue