Fix type errors, use () => RootState for getState

Signed-off-by: marcin mikołajczak <git@mkljczk.pl>
This commit is contained in:
marcin mikołajczak 2022-06-18 11:51:02 +02:00
parent 47b67df323
commit ee55241792
18 changed files with 61 additions and 50 deletions

View file

@ -6,7 +6,7 @@ const FETCH_ABOUT_PAGE_REQUEST = 'FETCH_ABOUT_PAGE_REQUEST';
const FETCH_ABOUT_PAGE_SUCCESS = 'FETCH_ABOUT_PAGE_SUCCESS'; const FETCH_ABOUT_PAGE_SUCCESS = 'FETCH_ABOUT_PAGE_SUCCESS';
const FETCH_ABOUT_PAGE_FAIL = 'FETCH_ABOUT_PAGE_FAIL'; const FETCH_ABOUT_PAGE_FAIL = 'FETCH_ABOUT_PAGE_FAIL';
const fetchAboutPage = (slug = 'index', locale?: string) => (dispatch: React.Dispatch<AnyAction>, getState: any) => { const fetchAboutPage = (slug = 'index', locale?: string) => (dispatch: React.Dispatch<AnyAction>) => {
dispatch({ type: FETCH_ABOUT_PAGE_REQUEST, slug, locale }); dispatch({ type: FETCH_ABOUT_PAGE_REQUEST, slug, locale });
const filename = `${slug}${locale ? `.${locale}` : ''}.html`; const filename = `${slug}${locale ? `.${locale}` : ''}.html`;

View file

@ -4,6 +4,7 @@ import { openModal, closeModal } from './modals';
import type { AxiosError } from 'axios'; import type { AxiosError } from 'axios';
import type { AnyAction } from 'redux'; import type { AnyAction } from 'redux';
import type { RootState } from 'soapbox/store';
import type { Account } from 'soapbox/types/entities'; import type { Account } from 'soapbox/types/entities';
const ACCOUNT_NOTE_SUBMIT_REQUEST = 'ACCOUNT_NOTE_SUBMIT_REQUEST'; const ACCOUNT_NOTE_SUBMIT_REQUEST = 'ACCOUNT_NOTE_SUBMIT_REQUEST';
@ -14,14 +15,14 @@ const ACCOUNT_NOTE_INIT_MODAL = 'ACCOUNT_NOTE_INIT_MODAL';
const ACCOUNT_NOTE_CHANGE_COMMENT = 'ACCOUNT_NOTE_CHANGE_COMMENT'; const ACCOUNT_NOTE_CHANGE_COMMENT = 'ACCOUNT_NOTE_CHANGE_COMMENT';
const submitAccountNote = () => (dispatch: React.Dispatch<AnyAction>, getState: any) => { const submitAccountNote = () => (dispatch: React.Dispatch<AnyAction>, getState: () => RootState) => {
dispatch(submitAccountNoteRequest()); dispatch(submitAccountNoteRequest());
const id = getState().getIn(['account_notes', 'edit', 'account_id']); const id = getState().account_notes.edit.account;
return api(getState) return api(getState)
.post(`/api/v1/accounts/${id}/note`, { .post(`/api/v1/accounts/${id}/note`, {
comment: getState().getIn(['account_notes', 'edit', 'comment']), comment: getState().account_notes.edit.comment,
}) })
.then(response => { .then(response => {
dispatch(closeModal()); dispatch(closeModal());
@ -50,8 +51,8 @@ function submitAccountNoteFail(error: AxiosError) {
}; };
} }
const initAccountNoteModal = (account: Account) => (dispatch: React.Dispatch<AnyAction>, getState: any) => { const initAccountNoteModal = (account: Account) => (dispatch: React.Dispatch<AnyAction>, getState: () => RootState) => {
const comment = getState().getIn(['relationships', account.get('id'), 'note']); const comment = getState().relationships.get(account.id)!.note;
dispatch({ dispatch({
type: ACCOUNT_NOTE_INIT_MODAL, type: ACCOUNT_NOTE_INIT_MODAL,

View file

@ -77,7 +77,7 @@ const getAuthApp = () =>
}; };
const createAuthApp = () => const createAuthApp = () =>
(dispatch: AppDispatch, getState: () => any) => { (dispatch: AppDispatch, getState: () => RootState) => {
const params = { const params = {
client_name: sourceCode.displayName, client_name: sourceCode.displayName,
redirect_uris: 'urn:ietf:wg:oauth:2.0:oob', redirect_uris: 'urn:ietf:wg:oauth:2.0:oob',
@ -91,7 +91,7 @@ const createAuthApp = () =>
}; };
const createAppToken = () => const createAppToken = () =>
(dispatch: AppDispatch, getState: () => any) => { (dispatch: AppDispatch, getState: () => RootState) => {
const app = getState().auth.get('app'); const app = getState().auth.get('app');
const params = { const params = {
@ -108,7 +108,7 @@ const createAppToken = () =>
}; };
const createUserToken = (username: string, password: string) => const createUserToken = (username: string, password: string) =>
(dispatch: AppDispatch, getState: () => any) => { (dispatch: AppDispatch, getState: () => RootState) => {
const app = getState().auth.get('app'); const app = getState().auth.get('app');
const params = { const params = {
@ -146,7 +146,7 @@ export const refreshUserToken = () =>
}; };
export const otpVerify = (code: string, mfa_token: string) => export const otpVerify = (code: string, mfa_token: string) =>
(dispatch: AppDispatch, getState: () => any) => { (dispatch: AppDispatch, getState: () => RootState) => {
const app = getState().auth.get('app'); const app = getState().auth.get('app');
return api(getState, 'app').post('/oauth/mfa/challenge', { return api(getState, 'app').post('/oauth/mfa/challenge', {
client_id: app.get('client_id'), client_id: app.get('client_id'),
@ -162,7 +162,7 @@ export const otpVerify = (code: string, mfa_token: string) =>
export const verifyCredentials = (token: string, accountUrl?: string) => { export const verifyCredentials = (token: string, accountUrl?: string) => {
const baseURL = parseBaseURL(accountUrl); const baseURL = parseBaseURL(accountUrl);
return (dispatch: AppDispatch, getState: () => any) => { return (dispatch: AppDispatch, getState: () => RootState) => {
dispatch({ type: VERIFY_CREDENTIALS_REQUEST, token }); dispatch({ type: VERIFY_CREDENTIALS_REQUEST, token });
return baseClient(token, baseURL).get('/api/v1/accounts/verify_credentials').then(({ data: account }) => { return baseClient(token, baseURL).get('/api/v1/accounts/verify_credentials').then(({ data: account }) => {
@ -188,7 +188,7 @@ export const verifyCredentials = (token: string, accountUrl?: string) => {
}; };
export const rememberAuthAccount = (accountUrl: string) => export const rememberAuthAccount = (accountUrl: string) =>
(dispatch: AppDispatch, getState: () => any) => { (dispatch: AppDispatch, getState: () => RootState) => {
dispatch({ type: AUTH_ACCOUNT_REMEMBER_REQUEST, accountUrl }); dispatch({ type: AUTH_ACCOUNT_REMEMBER_REQUEST, accountUrl });
return KVStore.getItemOrError(`authAccount:${accountUrl}`).then(account => { return KVStore.getItemOrError(`authAccount:${accountUrl}`).then(account => {
dispatch(importFetchedAccount(account)); dispatch(importFetchedAccount(account));
@ -230,7 +230,7 @@ export const logIn = (username: string, password: string) =>
}); });
export const deleteSession = () => export const deleteSession = () =>
(dispatch: AppDispatch, getState: () => any) => api(getState).delete('/api/sign_out'); (dispatch: AppDispatch, getState: () => RootState) => api(getState).delete('/api/sign_out');
export const logOut = () => export const logOut = () =>
(dispatch: AppDispatch, getState: () => RootState) => { (dispatch: AppDispatch, getState: () => RootState) => {
@ -256,7 +256,7 @@ export const logOut = () =>
}; };
export const switchAccount = (accountId: string, background = false) => export const switchAccount = (accountId: string, background = false) =>
(dispatch: AppDispatch, getState: () => any) => { (dispatch: AppDispatch, getState: () => RootState) => {
const account = getState().accounts.get(accountId); const account = getState().accounts.get(accountId);
return dispatch({ type: SWITCH_ACCOUNT, account, background }); return dispatch({ type: SWITCH_ACCOUNT, account, background });
}; };
@ -286,7 +286,7 @@ export const register = (params: Record<string, any>) =>
}; };
export const fetchCaptcha = () => export const fetchCaptcha = () =>
(_dispatch: AppDispatch, getState: () => any) => { (_dispatch: AppDispatch, getState: () => RootState) => {
return api(getState).get('/api/pleroma/captcha'); return api(getState).get('/api/pleroma/captcha');
}; };

View file

@ -1,6 +1,6 @@
import api from '../api'; import api from '../api';
import type { AppDispatch } from 'soapbox/store'; import type { AppDispatch, RootState } from 'soapbox/store';
export const BACKUPS_FETCH_REQUEST = 'BACKUPS_FETCH_REQUEST'; export const BACKUPS_FETCH_REQUEST = 'BACKUPS_FETCH_REQUEST';
export const BACKUPS_FETCH_SUCCESS = 'BACKUPS_FETCH_SUCCESS'; export const BACKUPS_FETCH_SUCCESS = 'BACKUPS_FETCH_SUCCESS';
@ -11,7 +11,7 @@ export const BACKUPS_CREATE_SUCCESS = 'BACKUPS_CREATE_SUCCESS';
export const BACKUPS_CREATE_FAIL = 'BACKUPS_CREATE_FAIL'; export const BACKUPS_CREATE_FAIL = 'BACKUPS_CREATE_FAIL';
export const fetchBackups = () => export const fetchBackups = () =>
(dispatch: AppDispatch, getState: () => any) => { (dispatch: AppDispatch, getState: () => RootState) => {
dispatch({ type: BACKUPS_FETCH_REQUEST }); dispatch({ type: BACKUPS_FETCH_REQUEST });
return api(getState).get('/api/v1/pleroma/backups').then(({ data: backups }) => return api(getState).get('/api/v1/pleroma/backups').then(({ data: backups }) =>
dispatch({ type: BACKUPS_FETCH_SUCCESS, backups }), dispatch({ type: BACKUPS_FETCH_SUCCESS, backups }),
@ -21,7 +21,7 @@ export const fetchBackups = () =>
}; };
export const createBackup = () => export const createBackup = () =>
(dispatch: AppDispatch, getState: () => any) => { (dispatch: AppDispatch, getState: () => RootState) => {
dispatch({ type: BACKUPS_CREATE_REQUEST }); dispatch({ type: BACKUPS_CREATE_REQUEST });
return api(getState).post('/api/v1/pleroma/backups').then(({ data: backups }) => return api(getState).post('/api/v1/pleroma/backups').then(({ data: backups }) =>
dispatch({ type: BACKUPS_CREATE_SUCCESS, backups }), dispatch({ type: BACKUPS_CREATE_SUCCESS, backups }),

View file

@ -8,6 +8,7 @@ import { importFetchedAccounts } from './importer';
import type { AnyAction } from '@reduxjs/toolkit'; import type { AnyAction } from '@reduxjs/toolkit';
import type { AxiosError } from 'axios'; import type { AxiosError } from 'axios';
import type { RootState } from 'soapbox/store';
const BLOCKS_FETCH_REQUEST = 'BLOCKS_FETCH_REQUEST'; const BLOCKS_FETCH_REQUEST = 'BLOCKS_FETCH_REQUEST';
const BLOCKS_FETCH_SUCCESS = 'BLOCKS_FETCH_SUCCESS'; const BLOCKS_FETCH_SUCCESS = 'BLOCKS_FETCH_SUCCESS';
@ -17,7 +18,7 @@ const BLOCKS_EXPAND_REQUEST = 'BLOCKS_EXPAND_REQUEST';
const BLOCKS_EXPAND_SUCCESS = 'BLOCKS_EXPAND_SUCCESS'; const BLOCKS_EXPAND_SUCCESS = 'BLOCKS_EXPAND_SUCCESS';
const BLOCKS_EXPAND_FAIL = 'BLOCKS_EXPAND_FAIL'; const BLOCKS_EXPAND_FAIL = 'BLOCKS_EXPAND_FAIL';
const fetchBlocks = () => (dispatch: React.Dispatch<AnyAction>, getState: any) => { const fetchBlocks = () => (dispatch: React.Dispatch<AnyAction>, getState: () => RootState) => {
if (!isLoggedIn(getState)) return null; if (!isLoggedIn(getState)) return null;
const nextLinkName = getNextLinkName(getState); const nextLinkName = getNextLinkName(getState);
@ -53,11 +54,11 @@ function fetchBlocksFail(error: AxiosError) {
}; };
} }
const expandBlocks = () => (dispatch: React.Dispatch<AnyAction>, getState: any) => { const expandBlocks = () => (dispatch: React.Dispatch<AnyAction>, getState: () => RootState) => {
if (!isLoggedIn(getState)) return null; if (!isLoggedIn(getState)) return null;
const nextLinkName = getNextLinkName(getState); const nextLinkName = getNextLinkName(getState);
const url = getState().getIn(['user_lists', 'blocks', 'next']); const url = getState().user_lists.getIn(['blocks', 'next']);
if (url === null) { if (url === null) {
return null; return null;

View file

@ -12,7 +12,7 @@ const fetchBundleSuccess = (skipLoading?: boolean) => ({
skipLoading, skipLoading,
}); });
const fetchBundleFail = (error, skipLoading?: boolean) => ({ const fetchBundleFail = (error: any, skipLoading?: boolean) => ({
type: BUNDLE_FETCH_FAIL, type: BUNDLE_FETCH_FAIL,
error, error,
skipLoading, skipLoading,

View file

@ -3,6 +3,7 @@ import api from '../api';
import { fetchRelationships } from './accounts'; import { fetchRelationships } from './accounts';
import { importFetchedAccounts } from './importer'; import { importFetchedAccounts } from './importer';
import type { AxiosError } from 'axios';
import type { AppDispatch, RootState } from 'soapbox/store'; import type { AppDispatch, RootState } from 'soapbox/store';
import type { APIEntity } from 'soapbox/types/entities'; import type { APIEntity } from 'soapbox/types/entities';
@ -14,14 +15,14 @@ const DIRECTORY_EXPAND_REQUEST = 'DIRECTORY_EXPAND_REQUEST';
const DIRECTORY_EXPAND_SUCCESS = 'DIRECTORY_EXPAND_SUCCESS'; const DIRECTORY_EXPAND_SUCCESS = 'DIRECTORY_EXPAND_SUCCESS';
const DIRECTORY_EXPAND_FAIL = 'DIRECTORY_EXPAND_FAIL'; const DIRECTORY_EXPAND_FAIL = 'DIRECTORY_EXPAND_FAIL';
const fetchDirectory = params => const fetchDirectory = (params: Record<string, any>) =>
(dispatch: AppDispatch, getState: () => RootState) => { (dispatch: AppDispatch, getState: () => RootState) => {
dispatch(fetchDirectoryRequest()); dispatch(fetchDirectoryRequest());
api(getState).get('/api/v1/directory', { params: { ...params, limit: 20 } }).then(({ data }) => { api(getState).get('/api/v1/directory', { params: { ...params, limit: 20 } }).then(({ data }) => {
dispatch(importFetchedAccounts(data)); dispatch(importFetchedAccounts(data));
dispatch(fetchDirectorySuccess(data)); dispatch(fetchDirectorySuccess(data));
dispatch(fetchRelationships(data.map(x => x.id))); dispatch(fetchRelationships(data.map((x: APIEntity) => x.id)));
}).catch(error => dispatch(fetchDirectoryFail(error))); }).catch(error => dispatch(fetchDirectoryFail(error)));
}; };
@ -29,17 +30,17 @@ const fetchDirectoryRequest = () => ({
type: DIRECTORY_FETCH_REQUEST, type: DIRECTORY_FETCH_REQUEST,
}); });
const fetchDirectorySuccess = accounts => ({ const fetchDirectorySuccess = (accounts: APIEntity[]) => ({
type: DIRECTORY_FETCH_SUCCESS, type: DIRECTORY_FETCH_SUCCESS,
accounts, accounts,
}); });
const fetchDirectoryFail = error => ({ const fetchDirectoryFail = (error: AxiosError) => ({
type: DIRECTORY_FETCH_FAIL, type: DIRECTORY_FETCH_FAIL,
error, error,
}); });
const expandDirectory = params => const expandDirectory = (params: Record<string, any>) =>
(dispatch: AppDispatch, getState: () => RootState) => { (dispatch: AppDispatch, getState: () => RootState) => {
dispatch(expandDirectoryRequest()); dispatch(expandDirectoryRequest());
@ -56,12 +57,12 @@ const expandDirectoryRequest = () => ({
type: DIRECTORY_EXPAND_REQUEST, type: DIRECTORY_EXPAND_REQUEST,
}); });
const expandDirectorySuccess = accounts => ({ const expandDirectorySuccess = (accounts: APIEntity[]) => ({
type: DIRECTORY_EXPAND_SUCCESS, type: DIRECTORY_EXPAND_SUCCESS,
accounts, accounts,
}); });
const expandDirectoryFail = error => ({ const expandDirectoryFail = (error: AxiosError) => ({
type: DIRECTORY_EXPAND_FAIL, type: DIRECTORY_EXPAND_FAIL,
error, error,
}); });

View file

@ -3,15 +3,15 @@ import api from '../api';
import type { RootState } from 'soapbox/store'; import type { RootState } from 'soapbox/store';
const getSubscribersCsv = () => const getSubscribersCsv = () =>
(dispatch, getState: () => RootState) => (dispatch: any, getState: () => RootState) =>
api(getState).get('/api/v1/pleroma/admin/email_list/subscribers.csv'); api(getState).get('/api/v1/pleroma/admin/email_list/subscribers.csv');
const getUnsubscribersCsv = () => const getUnsubscribersCsv = () =>
(dispatch, getState: () => RootState) => (dispatch: any, getState: () => RootState) =>
api(getState).get('/api/v1/pleroma/admin/email_list/unsubscribers.csv'); api(getState).get('/api/v1/pleroma/admin/email_list/unsubscribers.csv');
const getCombinedCsv = () => const getCombinedCsv = () =>
(dispatch, getState: () => RootState) => (dispatch: any, getState: () => RootState) =>
api(getState).get('/api/v1/pleroma/admin/email_list/combined.csv'); api(getState).get('/api/v1/pleroma/admin/email_list/combined.csv');
export { export {

View file

@ -66,7 +66,7 @@ const createFilter = (phrase: string, expires_at: string, context: Array<string>
}; };
const deleteFilter = (id) => const deleteFilter = (id: string) =>
(dispatch: AppDispatch, getState: () => RootState) => { (dispatch: AppDispatch, getState: () => RootState) => {
dispatch({ type: FILTERS_DELETE_REQUEST }); dispatch({ type: FILTERS_DELETE_REQUEST });
return api(getState).delete(`/api/v1/filters/${id}`).then(response => { return api(getState).delete(`/api/v1/filters/${id}`).then(response => {

View file

@ -4,6 +4,7 @@ import api from '../api';
import { importFetchedStatuses } from './importer'; import { importFetchedStatuses } from './importer';
import type { AxiosError } from 'axios';
import type { AppDispatch, RootState } from 'soapbox/store'; import type { AppDispatch, RootState } from 'soapbox/store';
import type { APIEntity } from 'soapbox/types/entities'; import type { APIEntity } from 'soapbox/types/entities';
@ -36,7 +37,7 @@ const fetchPinnedStatusesSuccess = (statuses: APIEntity[], next: string | null)
next, next,
}); });
const fetchPinnedStatusesFail = (error) => ({ const fetchPinnedStatusesFail = (error: AxiosError) => ({
type: PINNED_STATUSES_FETCH_FAIL, type: PINNED_STATUSES_FETCH_FAIL,
error, error,
}); });

View file

@ -2,7 +2,9 @@ import api from '../api';
import { importFetchedPoll } from './importer'; import { importFetchedPoll } from './importer';
import type { AxiosError } from 'axios';
import type { AppDispatch, RootState } from 'soapbox/store'; import type { AppDispatch, RootState } from 'soapbox/store';
import type { APIEntity } from 'soapbox/types/entities';
const POLL_VOTE_REQUEST = 'POLL_VOTE_REQUEST'; const POLL_VOTE_REQUEST = 'POLL_VOTE_REQUEST';
const POLL_VOTE_SUCCESS = 'POLL_VOTE_SUCCESS'; const POLL_VOTE_SUCCESS = 'POLL_VOTE_SUCCESS';
@ -40,12 +42,12 @@ const voteRequest = () => ({
type: POLL_VOTE_REQUEST, type: POLL_VOTE_REQUEST,
}); });
const voteSuccess = poll => ({ const voteSuccess = (poll: APIEntity) => ({
type: POLL_VOTE_SUCCESS, type: POLL_VOTE_SUCCESS,
poll, poll,
}); });
const voteFail = error => ({ const voteFail = (error: AxiosError) => ({
type: POLL_VOTE_FAIL, type: POLL_VOTE_FAIL,
error, error,
}); });
@ -54,12 +56,12 @@ const fetchPollRequest = () => ({
type: POLL_FETCH_REQUEST, type: POLL_FETCH_REQUEST,
}); });
const fetchPollSuccess = poll => ({ const fetchPollSuccess = (poll: APIEntity) => ({
type: POLL_FETCH_SUCCESS, type: POLL_FETCH_SUCCESS,
poll, poll,
}); });
const fetchPollFail = error => ({ const fetchPollFail = (error: AxiosError) => ({
type: POLL_FETCH_FAIL, type: POLL_FETCH_FAIL,
error, error,
}); });

View file

@ -39,7 +39,7 @@ const fetchPushSubscription = () =>
}; };
const updatePushSubscription = (params: Record<string, any>) => const updatePushSubscription = (params: Record<string, any>) =>
(dispatch: AppDispatch, getState: () => any) => { (dispatch: AppDispatch, getState: () => RootState) => {
dispatch({ type: PUSH_SUBSCRIPTION_UPDATE_REQUEST, params }); dispatch({ type: PUSH_SUBSCRIPTION_UPDATE_REQUEST, params });
return api(getState).put('/api/v1/push/subscription', params).then(({ data: subscription }) => return api(getState).put('/api/v1/push/subscription', params).then(({ data: subscription }) =>
dispatch({ type: PUSH_SUBSCRIPTION_UPDATE_SUCCESS, params, subscription }), dispatch({ type: PUSH_SUBSCRIPTION_UPDATE_SUCCESS, params, subscription }),

View file

@ -1,10 +1,11 @@
import { getSettings, changeSetting } from 'soapbox/actions/settings'; import { getSettings, changeSetting } from 'soapbox/actions/settings';
import type { OrderedSet as ImmutableOrderedSet } from 'immutable';
import type { AppDispatch, RootState } from 'soapbox/store'; import type { AppDispatch, RootState } from 'soapbox/store';
const getPinnedHosts = (state: RootState) => { const getPinnedHosts = (state: RootState) => {
const settings = getSettings(state); const settings = getSettings(state);
return settings.getIn(['remote_timeline', 'pinnedHosts']); return settings.getIn(['remote_timeline', 'pinnedHosts']) as ImmutableOrderedSet<string>;
}; };
const pinHost = (host: string) => const pinHost = (host: string) =>
@ -12,15 +13,15 @@ const pinHost = (host: string) =>
const state = getState(); const state = getState();
const pinnedHosts = getPinnedHosts(state); const pinnedHosts = getPinnedHosts(state);
return dispatch(changeSetting(['remote_timeline', 'pinnedHosts'], pinnedHosts.push(host))); return dispatch(changeSetting(['remote_timeline', 'pinnedHosts'], pinnedHosts.add(host)));
}; };
const unpinHost = (host) => const unpinHost = (host: string) =>
(dispatch: AppDispatch, getState: () => RootState) => { (dispatch: AppDispatch, getState: () => RootState) => {
const state = getState(); const state = getState();
const pinnedHosts = getPinnedHosts(state); const pinnedHosts = getPinnedHosts(state);
return dispatch(changeSetting(['remote_timeline', 'pinnedHosts'], pinnedHosts.filter((value) => value !== host))); return dispatch(changeSetting(['remote_timeline', 'pinnedHosts'], pinnedHosts.remove(host)));
}; };
export { export {

View file

@ -1,6 +1,7 @@
import api from '../api'; import api from '../api';
import type { Rule } from 'soapbox/reducers/rules'; import type { Rule } from 'soapbox/reducers/rules';
import type { RootState } from 'soapbox/store';
const RULES_FETCH_REQUEST = 'RULES_FETCH_REQUEST'; const RULES_FETCH_REQUEST = 'RULES_FETCH_REQUEST';
const RULES_FETCH_SUCCESS = 'RULES_FETCH_SUCCESS'; const RULES_FETCH_SUCCESS = 'RULES_FETCH_SUCCESS';
@ -16,7 +17,7 @@ type RulesFetchRequestSuccessAction = {
export type RulesActions = RulesFetchRequestAction | RulesFetchRequestSuccessAction export type RulesActions = RulesFetchRequestAction | RulesFetchRequestSuccessAction
const fetchRules = () => (dispatch: React.Dispatch<RulesActions>, getState: any) => { const fetchRules = () => (dispatch: React.Dispatch<RulesActions>, getState: () => RootState) => {
dispatch({ type: RULES_FETCH_REQUEST }); dispatch({ type: RULES_FETCH_REQUEST });
return api(getState) return api(getState)

View file

@ -3,7 +3,7 @@ import { MessageDescriptor, useIntl } from 'react-intl';
import { Button, Form, FormActions, Text } from 'soapbox/components/ui'; import { Button, Form, FormActions, Text } from 'soapbox/components/ui';
import { useAppDispatch } from 'soapbox/hooks'; import { useAppDispatch } from 'soapbox/hooks';
import { AppDispatch } from 'soapbox/store'; import { AppDispatch, RootState } from 'soapbox/store';
interface ICSVExporter { interface ICSVExporter {
messages: { messages: {
@ -11,7 +11,7 @@ interface ICSVExporter {
input_hint: MessageDescriptor, input_hint: MessageDescriptor,
submit: MessageDescriptor, submit: MessageDescriptor,
}, },
action: () => (dispatch: AppDispatch, getState: any) => Promise<void>, action: () => (dispatch: AppDispatch, getState: () => RootState) => Promise<void>,
} }
const CSVExporter: React.FC<ICSVExporter> = ({ messages, action }) => { const CSVExporter: React.FC<ICSVExporter> = ({ messages, action }) => {

View file

@ -86,7 +86,7 @@ const Filters = () => {
}; };
const handleFilterDelete: React.MouseEventHandler<HTMLDivElement> = e => { const handleFilterDelete: React.MouseEventHandler<HTMLDivElement> = e => {
dispatch(deleteFilter(e.currentTarget.dataset.value)).then(() => { dispatch(deleteFilter(e.currentTarget.dataset.value!)).then(() => {
return dispatch(fetchFilters()); return dispatch(fetchFilters());
}).catch(() => { }).catch(() => {
dispatch(snackbar.error(intl.formatMessage(messages.delete_error))); dispatch(snackbar.error(intl.formatMessage(messages.delete_error)));

View file

@ -3,7 +3,8 @@ import { MessageDescriptor, useIntl } from 'react-intl';
import { Button, FileInput, Form, FormActions, FormGroup, Text } from 'soapbox/components/ui'; import { Button, FileInput, Form, FormActions, FormGroup, Text } from 'soapbox/components/ui';
import { useAppDispatch } from 'soapbox/hooks'; import { useAppDispatch } from 'soapbox/hooks';
import { AppDispatch } from 'soapbox/store';
import type { AppDispatch, RootState } from 'soapbox/store';
interface ICSVImporter { interface ICSVImporter {
messages: { messages: {
@ -11,7 +12,7 @@ interface ICSVImporter {
input_hint: MessageDescriptor, input_hint: MessageDescriptor,
submit: MessageDescriptor, submit: MessageDescriptor,
}, },
action: (params: FormData) => (dispatch: AppDispatch, getState: any) => Promise<void>, action: (params: FormData) => (dispatch: AppDispatch, getState: () => RootState) => Promise<void>,
} }
const CSVImporter: React.FC<ICSVImporter> = ({ messages, action }) => { const CSVImporter: React.FC<ICSVImporter> = ({ messages, action }) => {

View file

@ -5,8 +5,10 @@ import api from 'soapbox/api';
import { Modal, Stack, Text, Input } from 'soapbox/components/ui'; import { Modal, Stack, Text, Input } from 'soapbox/components/ui';
import { useAppDispatch } from 'soapbox/hooks'; import { useAppDispatch } from 'soapbox/hooks';
import type { RootState } from 'soapbox/store';
const fetchEmbed = (url: string) => { const fetchEmbed = (url: string) => {
return (dispatch: any, getState: any) => { return (dispatch: any, getState: () => RootState) => {
return api(getState).get('/api/oembed', { params: { url } }); return api(getState).get('/api/oembed', { params: { url } });
}; };
}; };