model.ts 2.62 KB
Newer Older
1
import { query as queryUsers, queryCurrent, queryProvince, queryCity } from './service';
陈帅's avatar
陈帅 committed
2 3 4 5
import { Reducer } from 'redux';
import { EffectsCommandMap } from 'dva';
import { AnyAction } from 'redux';
import { CurrentUser, City, Province } from './data';
陈帅's avatar
陈帅 committed
6

陈帅's avatar
陈帅 committed
7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
export interface ModalState {
  currentUser?: Partial<CurrentUser>;
  province?: Province[];
  city?: City[];
  isLoading?: boolean;
}

export type Effect = (
  action: AnyAction,
  effects: EffectsCommandMap & { select: <T>(func: (state: ModalState) => T) => T }
) => void;

export interface ModelType {
  namespace: string;
  state: ModalState;
  effects: {
    fetchCurrent: Effect;
    fetch: Effect;
    fetchProvince: Effect;
    fetchCity: Effect;
  };
  reducers: {
    saveCurrentUser: Reducer<ModalState>;
    changeNotifyCount: Reducer<ModalState>;
    setProvince: Reducer<ModalState>;
    setCity: Reducer<ModalState>;
    changeLoading: Reducer<ModalState>;
  };
}

const Model: ModelType = {
38
  namespace: 'BLOCK_NAME_CAMEL_CASE',
陈帅's avatar
陈帅 committed
39 40

  state: {
41
    currentUser: {},
陈帅's avatar
陈帅 committed
42 43
    province: [],
    city: [],
陈帅's avatar
陈帅 committed
44
    isLoading: false,
陈帅's avatar
陈帅 committed
45 46 47
  },

  effects: {
48 49 50 51 52 53 54 55 56 57 58 59 60 61
    *fetch(_, { call, put }) {
      const response = yield call(queryUsers);
      yield put({
        type: 'save',
        payload: response,
      });
    },
    *fetchCurrent(_, { call, put }) {
      const response = yield call(queryCurrent);
      yield put({
        type: 'saveCurrentUser',
        payload: response,
      });
    },
陈帅's avatar
陈帅 committed
62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
    *fetchProvince(_, { call, put }) {
      yield put({
        type: 'changeLoading',
        payload: true,
      });
      const response = yield call(queryProvince);
      yield put({
        type: 'setProvince',
        payload: response,
      });
    },
    *fetchCity({ payload }, { call, put }) {
      const response = yield call(queryCity, payload);
      yield put({
        type: 'setCity',
        payload: response,
      });
    },
  },

  reducers: {
83 84 85 86 87 88
    saveCurrentUser(state, action) {
      return {
        ...state,
        currentUser: action.payload || {},
      };
    },
陈帅's avatar
陈帅 committed
89
    changeNotifyCount(state = {}, action) {
90 91 92 93 94 95 96 97 98
      return {
        ...state,
        currentUser: {
          ...state.currentUser,
          notifyCount: action.payload.totalCount,
          unreadCount: action.payload.unreadCount,
        },
      };
    },
陈帅's avatar
陈帅 committed
99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118
    setProvince(state, action) {
      return {
        ...state,
        province: action.payload,
      };
    },
    setCity(state, action) {
      return {
        ...state,
        city: action.payload,
      };
    },
    changeLoading(state, action) {
      return {
        ...state,
        isLoading: action.payload,
      };
    },
  },
};
陈帅's avatar
陈帅 committed
119 120

export default Model;