chart.js 1.38 KB
Newer Older
1 2 3 4 5 6 7
import { fakeChartData } from '../services/api';

export default {
  namespace: 'chart',

  state: {
    visitData: [],
afc163's avatar
afc163 committed
8
    visitData2: [],
9 10 11 12 13 14 15 16
    salesData: [],
    searchData: [],
    offlineData: [],
    offlineChartData: [],
    salesTypeData: [],
    salesTypeDataOnline: [],
    salesTypeDataOffline: [],
    radarData: [],
17
    loading: false,
18 19 20
  },

  effects: {
afc163's avatar
afc163 committed
21
    *fetch(_, { call, put }) {
22 23 24 25
      yield put({
        type: 'changeLoading',
        payload: true,
      });
26 27 28 29 30 31
      const response = yield call(fakeChartData);
      yield put({
        type: 'save',
        payload: response,
      });
    },
afc163's avatar
afc163 committed
32
    *fetchSalesData(_, { call, put }) {
33 34 35 36 37 38 39 40 41 42 43 44 45 46 47
      const response = yield call(fakeChartData);
      yield put({
        type: 'save',
        payload: {
          salesData: response.salesData,
        },
      });
    },
  },

  reducers: {
    save(state, { payload }) {
      return {
        ...state,
        ...payload,
48
        loading: false,
49 50 51 52 53
      };
    },
    clear() {
      return {
        visitData: [],
afc163's avatar
afc163 committed
54
        visitData2: [],
55 56 57 58 59 60 61 62 63 64
        salesData: [],
        searchData: [],
        offlineData: [],
        offlineChartData: [],
        salesTypeData: [],
        salesTypeDataOnline: [],
        salesTypeDataOffline: [],
        radarData: [],
      };
    },
65 66 67 68 69 70
    changeLoading(state, { payload }) {
      return {
        ...state,
        loading: payload,
      };
    },
71 72
  },
};