|
@@ -20,6 +20,7 @@ export default {
|
|
|
tabs: [],
|
|
tabs: [],
|
|
|
selectedTab: null,
|
|
selectedTab: null,
|
|
|
collectionDashboards: [], // 已收藏报表
|
|
collectionDashboards: [], // 已收藏报表
|
|
|
|
|
+ fixedDashboard: null, // 固定到首页的报表
|
|
|
}
|
|
}
|
|
|
},
|
|
},
|
|
|
reducers: {
|
|
reducers: {
|
|
@@ -115,8 +116,20 @@ export default {
|
|
|
yield put({ type: 'removeTabs', tabs });
|
|
yield put({ type: 'removeTabs', tabs });
|
|
|
},
|
|
},
|
|
|
*closeAllTabs(action, { select, call, put }) {
|
|
*closeAllTabs(action, { select, call, put }) {
|
|
|
- yield put({ type: 'removeAllTabs' });
|
|
|
|
|
- yield put({ type: 'dashboardDesigner/reset' });
|
|
|
|
|
|
|
+ const { home } = yield select(state => ({ home: state.present.home }));
|
|
|
|
|
+ const { tabs, fixedDashboard } = home;
|
|
|
|
|
+ let rmTabs = [];
|
|
|
|
|
+
|
|
|
|
|
+ for(let i = tabs.length - 1; i >= 0; i--) {
|
|
|
|
|
+ if(!fixedDashboard || (tabs[i].code !== fixedDashboard.code)) {
|
|
|
|
|
+ rmTabs.push(tabs[i]);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
|
|
+ yield put({ type: 'removeTabs', tabs: rmTabs });
|
|
|
|
|
+ if(fixedDashboard && rmTabs.length > 0) {
|
|
|
|
|
+ let sTab = tabs.find(t => t.code === fixedDashboard.code);
|
|
|
|
|
+ yield put({ type: 'changeTab', tab: sTab });
|
|
|
|
|
+ }
|
|
|
},
|
|
},
|
|
|
*saveCurrentTabDashboardConfig(action, { select, call, put }) {
|
|
*saveCurrentTabDashboardConfig(action, { select, call, put }) {
|
|
|
const { home, dashboardDesigner } = yield select(state => ({ home: state.present.home, dashboardDesigner: state.present.dashboardDesigner }));
|
|
const { home, dashboardDesigner } = yield select(state => ({ home: state.present.home, dashboardDesigner: state.present.dashboardDesigner }));
|
|
@@ -146,8 +159,8 @@ export default {
|
|
|
});
|
|
});
|
|
|
if(!res.err && res.data.code > 0) {
|
|
if(!res.err && res.data.code > 0) {
|
|
|
const list = res.data.data.map(d => ({
|
|
const list = res.data.data.map(d => ({
|
|
|
- code: d.ID + '',
|
|
|
|
|
- name: d.NAME
|
|
|
|
|
|
|
+ code: d.id + '',
|
|
|
|
|
+ name: d.name
|
|
|
}));
|
|
}));
|
|
|
yield put({ type: 'setField', name: 'collectionDashboards', value: list });
|
|
yield put({ type: 'setField', name: 'collectionDashboards', value: list });
|
|
|
return list;
|
|
return list;
|
|
@@ -198,6 +211,69 @@ export default {
|
|
|
message.error('添加收藏失败: ' + e.message);
|
|
message.error('添加收藏失败: ' + e.message);
|
|
|
}
|
|
}
|
|
|
},
|
|
},
|
|
|
|
|
+ *getFixedDashboard(action, { select, put, call }) {
|
|
|
|
|
+ const main = yield select (state => state.present.main);
|
|
|
|
|
+ const { currentUser } = main;
|
|
|
|
|
+ try{
|
|
|
|
|
+ const res = yield call(service.fetch, {
|
|
|
|
|
+ url: URLS.HOMEPAGE_FIXED_GET + '/' + currentUser.code,
|
|
|
|
|
+ method: 'GET'
|
|
|
|
|
+ });
|
|
|
|
|
+ if(!res.err && res.data.code > 0) {
|
|
|
|
|
+ // let fixedDashboard = {
|
|
|
|
|
+ // code: res.data.data ? (res.data.data.code + '') : null,
|
|
|
|
|
+ // name: res.data.data ? (res.data.data.name + '') : null
|
|
|
|
|
+ // }
|
|
|
|
|
+ let fixedDashboard = res.data.data ? {
|
|
|
|
|
+ code: res.data.data['id'] + '',
|
|
|
|
|
+ name: res.data.data['name'],
|
|
|
|
|
+ } : null;
|
|
|
|
|
+ yield put({ type: 'setField', name: 'fixedDashboard', value: fixedDashboard });
|
|
|
|
|
+ return fixedDashboard;
|
|
|
|
|
+ }else {
|
|
|
|
|
+ message.error('请求默认报表失败: ' + (res.err || res.data.msg));
|
|
|
|
|
+ return null;
|
|
|
|
|
+ }
|
|
|
|
|
+ }catch(e) {
|
|
|
|
|
+ message.error('请求默认报表失败: ' + e.message);
|
|
|
|
|
+ }
|
|
|
|
|
+ },
|
|
|
|
|
+ *onFixedDashboard(action, { select, put, call }) {
|
|
|
|
|
+ const main = yield select (state => state.present.main);
|
|
|
|
|
+ const { currentUser } = main;
|
|
|
|
|
+ const { tab } = action;
|
|
|
|
|
+ try{
|
|
|
|
|
+ const res = yield call(service.fetch, {
|
|
|
|
|
+ url: URLS.HOMEPAGE_FIXED + '/' + currentUser.code + '/' + tab.code
|
|
|
|
|
+ });
|
|
|
|
|
+ if(!res.err && res.data.code > 0) {
|
|
|
|
|
+ yield put({ type: 'setField', name: 'fixedDashboard', value: tab });
|
|
|
|
|
+ message.success('已设为默认报表');
|
|
|
|
|
+ }else {
|
|
|
|
|
+ message.error('设为默认报表失败: ' + (res.err || res.data.msg));
|
|
|
|
|
+ }
|
|
|
|
|
+ }catch(e) {
|
|
|
|
|
+ message.error('设为默认报表失败: ' + e.message);
|
|
|
|
|
+ }
|
|
|
|
|
+ },
|
|
|
|
|
+ *onCancelFixedDashboard(action, { select, put, call }) {
|
|
|
|
|
+ const main = yield select (state => state.present.main);
|
|
|
|
|
+ const { currentUser } = main;
|
|
|
|
|
+ const { tab } = action;
|
|
|
|
|
+ try{
|
|
|
|
|
+ const res = yield call(service.fetch, {
|
|
|
|
|
+ url: URLS.HOMEPAGE_CANCELFIXED + '/' + currentUser.code + '/' + tab.code
|
|
|
|
|
+ });
|
|
|
|
|
+ if(!res.err && res.data.code > 0) {
|
|
|
|
|
+ yield put({ type: 'setField', name: 'fixedDashboard', value: null });
|
|
|
|
|
+ message.success('已取消默认报表');
|
|
|
|
|
+ }else {
|
|
|
|
|
+ message.error('取消默认报表失败: ' + (res.err || res.data.msg));
|
|
|
|
|
+ }
|
|
|
|
|
+ }catch(e) {
|
|
|
|
|
+ message.error('取消默认报表失败: ' + e.message);
|
|
|
|
|
+ }
|
|
|
|
|
+ }
|
|
|
},
|
|
},
|
|
|
subscriptions: {
|
|
subscriptions: {
|
|
|
setup({ dispatch, history }) {
|
|
setup({ dispatch, history }) {
|