model.ts 1.85 KB
Newer Older
1
import { query as queryUsers, queryCurrent, queryProvince, queryCity } from './service';
陈帅's avatar
陈帅 committed
2 3

export default {
4
  namespace: 'BLOCK_NAME_CAMEL_CASE',
陈帅's avatar
陈帅 committed
5 6

  state: {
7 8
    list: [],
    currentUser: {},
陈帅's avatar
陈帅 committed
9 10 11 12 13
    province: [],
    city: [],
  },

  effects: {
14 15 16 17 18 19 20 21 22 23 24 25 26 27
    *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
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
    *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: {
49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70
    save(state, action) {
      return {
        ...state,
        list: action.payload,
      };
    },
    saveCurrentUser(state, action) {
      return {
        ...state,
        currentUser: action.payload || {},
      };
    },
    changeNotifyCount(state, action) {
      return {
        ...state,
        currentUser: {
          ...state.currentUser,
          notifyCount: action.payload.totalCount,
          unreadCount: action.payload.unreadCount,
        },
      };
    },
陈帅's avatar
陈帅 committed
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90
    setProvince(state, action) {
      return {
        ...state,
        province: action.payload,
      };
    },
    setCity(state, action) {
      return {
        ...state,
        city: action.payload,
      };
    },
    changeLoading(state, action) {
      return {
        ...state,
        isLoading: action.payload,
      };
    },
  },
};