Redux машинописный тип статически Диспетчер - PullRequest
0 голосов
/ 06 октября 2019

Я недавно переключился на 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 и установка его в качестве типа для отправки также не работали.

любой совет был бы действительно признателен!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...