orderList.js 3.4 KB
import { message } from 'antd';
import {
  orderPage,
  updateOrderItem,
  updateOrderItemPayAmount,
  updateRemark,
  cancelOrder,
} from '../../services/order';

export default {
  namespace: 'orderList',

  state: {
    list: {
      pagination: {
        current: 0,
        pageSize: 10,
        total: 0,
      },
      dataSource: [],
    },
    payAmountVisible: false,
    payAmount: 0,
    orderId: 0,
    orderItemId: 0,
    searchParams: {},

    remarkVisible: false,
    remark: '',

    orderCancelVisible: false,
    orderCancelShowOther: false,
  },

  effects: {
    *queryPage({ payload }, { call, put }) {
      const response = yield call(orderPage, payload);

      yield put({
        type: 'changeSearchParams',
        payload: {
          searchParams: {
            ...payload,
          },
        },
      });

      message.info('查询成功!', response);
      const { total, orders } = response.data;
      yield put({
        type: 'queryPageSuccess',
        payload: {
          list: {
            dataSource: orders,
            pagination: {
              total,
              current: payload.pageNo,
              pageSize: payload.pageSize,
            },
          },
        },
      });
    },
    *updateOrderItem({ payload }, { call, put }) {
      const { params } = payload;
      const response = yield call(updateOrderItem, params);
      message.info('查询成功!');
      yield put({
        type: 'queryPageSuccess',
        payload: {
          list: response.data,
        },
      });
    },
    *updatePayAmount({ payload }, { call, put }) {
      const { searchParams, params } = payload;
      yield call(updateOrderItemPayAmount, params);
      yield put({
        type: 'changePayAmountVisible',
        payload: {
          payAmountVisible: false,
        },
      });

      yield put({
        type: 'queryPage',
        payload: {
          ...searchParams,
        },
      });
    },
    *updateRemake({ payload }, { call, put }) {
      const { searchParams, params } = payload;
      yield call(updateRemark, params);
      yield put({
        type: 'changeRemakeVisible',
        payload: {
          remarkVisible: false,
        },
      });

      yield put({
        type: 'queryPage',
        payload: {
          ...searchParams,
        },
      });
    },
    *cancelOrder({ payload }, { call, put }) {
      const { searchParams, params } = payload;
      yield call(cancelOrder, params);
      yield put({
        type: 'changeOrderCancelVisible',
        payload: {
          orderCancelVisible: false,
        },
      });

      yield put({
        type: 'queryPage',
        payload: {
          ...searchParams,
        },
      });
    },
  },

  reducers: {
    queryPageSuccess(state, { payload }) {
      const { list } = payload;
      return {
        ...state,
        list,
      };
    },
    changePayAmountVisible(state, { payload }) {
      return {
        ...state,
        ...payload,
      };
    },
    changeSearchParams(state, { payload }) {
      return {
        ...state,
        ...payload,
      };
    },
    changeRemakeVisible(state, { payload }) {
      return {
        ...state,
        ...payload,
      };
    },
    changeOrderCancelVisible(state, { payload }) {
      return {
        ...state,
        ...payload,
      };
    },
    changeOrderCancelShowOther(state, { payload }) {
      return {
        ...state,
        ...payload,
      };
    },
  },
};