nicolium: store type improvements

Signed-off-by: nicole mikołajczyk <git@mkljczk.pl>
This commit is contained in:
nicole mikołajczyk
2026-02-27 16:41:08 +01:00
parent 66701a4888
commit 05fc2c043c
5 changed files with 36 additions and 33 deletions

View File

@ -10,8 +10,11 @@ import type {
Poll as BasePoll,
Relationship as BaseRelationship,
Status as BaseStatus,
StatusWithoutAccount,
} from 'pl-api';
type Status = BaseStatus | (StatusWithoutAccount & { expectsCard?: boolean });
const STATUS_IMPORT = 'STATUS_IMPORT' as const;
const STATUSES_IMPORT = 'STATUSES_IMPORT' as const;
@ -19,13 +22,13 @@ const isEmpty = (object: Record<string, any>) => !Object.values(object).some((va
interface ImportStatusAction {
type: typeof STATUS_IMPORT;
status: BaseStatus;
status: Status;
idempotencyKey?: string;
}
interface ImportStatusesAction {
type: typeof STATUSES_IMPORT;
statuses: Array<BaseStatus>;
statuses: Array<Status>;
}
const importEntities =
@ -34,7 +37,7 @@ const importEntities =
accounts?: Array<BaseAccount | undefined | null>;
groups?: Array<BaseGroup | undefined | null>;
polls?: Array<BasePoll | undefined | null>;
statuses?: Array<(BaseStatus & { expectsCard?: boolean }) | undefined | null>;
statuses?: Array<Status | undefined | null>;
relationships?: Array<BaseRelationship | undefined | null>;
},
options: {
@ -53,7 +56,7 @@ const importEntities =
const groups: Record<string, BaseGroup> = {};
const polls: Record<string, BasePoll> = {};
const relationships: Record<string, BaseRelationship> = {};
const statuses: Record<string, BaseStatus> = {};
const statuses: Record<string, Status> = {};
const processAccount = (account: BaseAccount, withSelf = true) => {
if (!override && selectAccount(account.id)) return;
@ -64,7 +67,7 @@ const importEntities =
if (account.relationship) relationships[account.relationship.id] = account.relationship;
};
const processStatus = (status: BaseStatus, withSelf = true) => {
const processStatus = (status: Status, withSelf = true) => {
// Skip broken statuses
if (status.scheduled_at !== null) return;

View File

@ -14,26 +14,24 @@ import NicoliumLoad from './nicolium-load';
import NicoliumMount from './nicolium-mount';
// Preload happens synchronously
store.dispatch(preload() as any);
store.dispatch(preload());
/** The root React node of the application. */
const Nicolium: React.FC = () => (
<>
<Provider store={store}>
<QueryClientProvider client={queryClient}>
<DefaultCurrentAccountProvider>
<StatProvider>
<HelmetProvider>
<NicoliumHead />
<NicoliumLoad>
<NicoliumMount />
</NicoliumLoad>
</HelmetProvider>
</StatProvider>
</DefaultCurrentAccountProvider>
</QueryClientProvider>
</Provider>
</>
<Provider store={store}>
<QueryClientProvider client={queryClient}>
<DefaultCurrentAccountProvider>
<StatProvider>
<HelmetProvider>
<NicoliumHead />
<NicoliumLoad>
<NicoliumMount />
</NicoliumLoad>
</HelmetProvider>
</StatProvider>
</DefaultCurrentAccountProvider>
</QueryClientProvider>
</Provider>
);
export { Nicolium as default };

View File

@ -33,7 +33,7 @@ const importConversationEntities = (conversations: Conversation[]) => {
importEntities({
accounts: conversations.flatMap((conversation) => conversation.accounts),
statuses: conversations.map((conversation) => conversation.last_status),
}) as any,
}),
);
};

View File

@ -47,9 +47,7 @@ const minifyStatusList = (response: PaginatedResponse<Status>): PaginatedRespons
minifyList(
response,
(status) => status.id,
(statuses) => {
store.dispatch(importEntities({ statuses }) as any);
},
(statuses) => store.dispatch(importEntities({ statuses })),
);
const minifyAccountList = (response: PaginatedResponse<Account>): PaginatedResponse<string> =>
@ -134,7 +132,7 @@ const minifyConversationList = (response: PaginatedResponse<Conversation>) =>
importEntities({
accounts: conversations.flatMap((conversation) => conversation.accounts),
statuses: conversations.map((conversation) => conversation.last_status),
}) as any,
}),
);
});
@ -147,7 +145,7 @@ const minifyGroupedNotifications = (
(results) => {
const { accounts, statuses } = results;
store.dispatch(importEntities({ accounts, statuses }) as any);
store.dispatch(importEntities({ accounts, statuses }));
},
false,
);
@ -198,8 +196,8 @@ const minifyAdminReport = ({
assigned_account?.account,
target_account?.account,
],
statuses: statuses as any,
}) as any,
statuses: statuses,
}),
);
return {
account_id: account.id,

View File

@ -5,17 +5,21 @@ import errorsMiddleware from './middleware/errors';
import soundsMiddleware from './middleware/sounds';
import appReducer from './reducers';
const store = configureStore({
const untypedStore = configureStore({
reducer: appReducer,
middleware: () => new Tuple(thunk, errorsMiddleware(), soundsMiddleware()),
devTools: true,
});
type Store = typeof store;
type Store = typeof untypedStore & {
dispatch: AppDispatch;
};
const store: Store = untypedStore as Store;
// Infer the `RootState` and `AppDispatch` types from the store itself
// https://redux.js.org/usage/usage-with-typescript
type RootState = ReturnType<typeof store.getState>;
type RootState = ReturnType<typeof untypedStore.getState>;
type AppDispatch = ThunkDispatch<RootState, {}, AnyAction>;
export { store, type Store, type RootState, type AppDispatch };