Я недавно переключился на Typescript для своего реактивного проекта, и я получил машинописный текст с работающей избыточностью (thunk). Мне все еще интересно, возможно ли «привязать» интерфейс к диспетчерскому действию, чтобы я мог проверить его форму.
Код моего actionCreator:
import { Message, SEND_MESSAGE, DELETE_MESSAGE, GET_MESSAGES_SUCCESS, GET_MESSAGES_FAILED, GET_MESSAGES, ChatActionTypes, ChatState } from './types';
import { ActionCreator, Dispatch } from 'redux';
import { ThunkAction } from 'redux-thunk';
import axios from "axios";
export const getMessages: ActionCreator<ThunkAction<Promise<any>, ChatState, null, ChatActionTypes>> = () => {
console.log('i get called')
return async (dispatch: Dispatch) => {
try {
const response = await axios.get('https://jsonplaceholder.typicode.com/todosdffd');
console.log(response)
dispatch({
type: GET_MESSAGES_SUCCESS,
payload: {
loading: false,
data: response.data,
}
})
} catch (error) {
console.log('error triggered')
dispatch({
type: typeof GET_MESSAGES_FAILED,
payload: {
loading: false,
error: {error }
}
})
}
}
}
export function sendMessage(newMessage: Message): ChatActionTypes {
return {
type: SEND_MESSAGE,
payload: newMessage
}
}
export function deleteMessage(timestamp: number): ChatActionTypes {
return {
type: DELETE_MESSAGE,
meta: {
timestamp
}
}
}
мой файл типов
export const SEND_MESSAGE = 'SEND_MESSAGE';
export const DELETE_MESSAGE = 'DELETE_MESSSAGE' ;
export const GET_MESSAGES = 'GET_MESSSAGES' ;
export const GET_MESSAGES_SUCCESS = 'GET_MESSAGES_SUCCESS' ;
export const GET_MESSAGES_FAILED = 'GET_MESSAGES_FAILED' ;
export interface Message {
user: string,
message: string,
timeStamp: number
}
export interface ChatState {
messages: Message[]
}
interface SendMessageAction {
type: typeof SEND_MESSAGE,
payload: Message
}
interface DeleteMessageAction {
type: typeof DELETE_MESSAGE,
meta: {
timestamp: number
}
}
interface GetMessagesAction {
type: typeof GET_MESSAGES,
payload: {
loading: boolean
}
}
interface GetMessagesFailedAction {
type: typeof GET_MESSAGES_FAILED,
payload: {
loading: boolean,
error: object
}
}
interface GetMessagesSuccessAction {
type: typeof GET_MESSAGES_SUCCESS,
payload: {
loading: boolean,
data: any[]
}
}
export type ChatActionTypes = SendMessageAction | DeleteMessageAction | GetMessagesAction | GetMessagesFailedAction | GetMessagesSuccessAction;
Что я пытался сделать:
dispatch<ChatActionTypes>({ ... })
, но это не работает. Получение интерфейса непосредственно в коде actionCreator и установка его в качестве типа для отправки также не работали.
любой совет был бы действительно признателен!