import { queryFakeList } from './service'; import { ListItemDataType } from './data'; import { Reducer } from 'redux'; import { EffectsCommandMap } from 'dva'; import { AnyAction } from 'redux'; export interface IStateType { list: ListItemDataType[]; } export type Effect = ( action: AnyAction, effects: EffectsCommandMap & { select: (func: (state: IStateType) => T) => T } ) => void; export interface ModelType { namespace: string; state: IStateType; effects: { fetch: Effect; }; reducers: { queryList: Reducer; }; } const Model: ModelType = { namespace: 'BLOCK_NAME_CAMEL_CASE', state: { list: [], }, effects: { *fetch({ payload }, { call, put }) { const response = yield call(queryFakeList, payload); yield put({ type: 'queryList', payload: Array.isArray(response) ? response : [], }); }, }, reducers: { queryList(state, action) { return { ...state, list: action.payload, }; }, }, }; export default Model;