global.js 3.54 KB
Newer Older
愚道's avatar
愚道 committed
1
import { queryNotices } from '@/services/api';
2 3 4 5 6 7 8

export default {
  namespace: 'global',

  state: {
    collapsed: false,
    notices: [],
何乐's avatar
何乐 committed
9
    loadedAllNotices: false,
10 11 12
  },

  effects: {
13
    *fetchNotices(_, { call, put, select }) {
14
      const data = yield call(queryNotices);
何乐's avatar
何乐 committed
15 16 17 18 19
      const loadedAllNotices = data && data.length && data[data.length - 1] === null;
      yield put({
        type: 'setLoadedStatus',
        payload: loadedAllNotices,
      });
20 21
      yield put({
        type: 'saveNotices',
何乐's avatar
何乐 committed
22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44
        payload: data.filter(item => item),
      });
      const unreadCount = yield select(
        state => state.global.notices.filter(item => !item.read).length
      );
      yield put({
        type: 'user/changeNotifyCount',
        payload: {
          totalCount: data.length,
          unreadCount,
        },
      });
    },
    *fetchMoreNotices({ payload }, { call, put, select }) {
      const data = yield call(queryNotices, payload);
      const loadedAllNotices = data && data.length && data[data.length - 1] === null;
      yield put({
        type: 'setLoadedStatus',
        payload: loadedAllNotices,
      });
      yield put({
        type: 'pushNotices',
        payload: data.filter(item => item),
45
      });
46 47 48
      const unreadCount = yield select(
        state => state.global.notices.filter(item => !item.read).length
      );
Xiaoming Liu's avatar
Xiaoming Liu committed
49 50
      yield put({
        type: 'user/changeNotifyCount',
51 52 53 54
        payload: {
          totalCount: data.length,
          unreadCount,
        },
Xiaoming Liu's avatar
Xiaoming Liu committed
55
      });
56
    },
afc163's avatar
afc163 committed
57
    *clearNotices({ payload }, { put, select }) {
58 59 60 61
      yield put({
        type: 'saveClearedNotices',
        payload,
      });
afc163's avatar
afc163 committed
62
      const count = yield select(state => state.global.notices.length);
63 64 65
      const unreadCount = yield select(
        state => state.global.notices.filter(item => !item.read).length
      );
afc163's avatar
afc163 committed
66 67
      yield put({
        type: 'user/changeNotifyCount',
68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93
        payload: {
          totalCount: count,
          unreadCount,
        },
      });
    },
    *changeNoticeReadState({ payload }, { put, select }) {
      const notices = yield select(state =>
        state.global.notices.map(item => {
          const notice = { ...item };
          if (notice.id === payload) {
            notice.read = true;
          }
          return notice;
        })
      );
      yield put({
        type: 'saveNotices',
        payload: notices,
      });
      yield put({
        type: 'user/changeNotifyCount',
        payload: {
          totalCount: notices.length,
          unreadCount: notices.filter(item => !item.read).length,
        },
afc163's avatar
afc163 committed
94 95
      });
    },
96 97 98 99 100 101 102 103 104 105 106 107 108 109 110
  },

  reducers: {
    changeLayoutCollapsed(state, { payload }) {
      return {
        ...state,
        collapsed: payload,
      };
    },
    saveNotices(state, { payload }) {
      return {
        ...state,
        notices: payload,
      };
    },
afc163's avatar
afc163 committed
111
    saveClearedNotices(state, { payload }) {
112 113 114 115 116
      return {
        ...state,
        notices: state.notices.filter(item => item.type !== payload),
      };
    },
何乐's avatar
何乐 committed
117 118 119 120 121 122 123 124 125 126 127 128
    pushNotices(state, { payload }) {
      return {
        ...state,
        notices: [...state.notices, ...payload],
      };
    },
    setLoadedStatus(state, { payload }) {
      return {
        ...state,
        loadedAllNotices: payload,
      };
    },
129
  },
afc163's avatar
afc163 committed
130 131

  subscriptions: {
xiaohu's avatar
xiaohu committed
132
    setup({ history }) {
afc163's avatar
afc163 committed
133 134 135 136 137 138 139 140
      // Subscribe history(url) change, trigger `load` action if pathname is `/`
      return history.listen(({ pathname, search }) => {
        if (typeof window.ga !== 'undefined') {
          window.ga('send', 'pageview', pathname + search);
        }
      });
    },
  },
141
};