nicolium: store type improvements
Signed-off-by: nicole mikołajczyk <git@mkljczk.pl>
This commit is contained in:
@ -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;
|
||||
|
||||
|
||||
@ -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 };
|
||||
|
||||
@ -33,7 +33,7 @@ const importConversationEntities = (conversations: Conversation[]) => {
|
||||
importEntities({
|
||||
accounts: conversations.flatMap((conversation) => conversation.accounts),
|
||||
statuses: conversations.map((conversation) => conversation.last_status),
|
||||
}) as any,
|
||||
}),
|
||||
);
|
||||
};
|
||||
|
||||
|
||||
@ -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,
|
||||
|
||||
@ -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 };
|
||||
|
||||
Reference in New Issue
Block a user