| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624 |
- import {
- getProject,
- getFaultAnalysis,
- getIssueList,
- getProjectActive,
- getNotificationList,
- getMediaList,
- getMonitorList,
- getUserGuide,
- getDailyList,
- getProjectProgress,
- deleteFile,
- getProjectTotalProgress,
- getLayoutOptions,
- saveLayoutOptions,
- getProjectAlarm,
- getBreakdownRecord,
- getProjectList,
- getAutoPatrol,
- getBreakdownList,
- getPatrolRecord,
- } from '@/services/DataMeter';
- import { queryProjectFileList } from '@/services/FileAdmin';
- import { getprojectPlanProgress, getProjectRealProgress } from '@/services/projectPlanProgress';
- import { getRepairRecord } from '@/services/EquipmentMaintenance';
- import { queryConfigList, queryTemplateList } from '@/services/CharUtils';
- import { queryPatrolRecord } from '@/services/patrol';
- import { message } from 'antd';
- import { DEFAULT_LAYOUT, DEFAULT_MAP_LAYOUT } from '@/components/DataMeter/config';
- import { getDefaultConfList } from '@/services/ProjectAdmin';
- const PLAN_TYPE = {
- 15: 1,
- 3: 3,
- 12: 4,
- };
- export default {
- namespace: 'dataMeterNew',
- state: {
- projectDetail: {},
- faultAnalysis: [],
- issueList: [],
- projectActive: [],
- news: [],
- memorabilia: [],
- awards: [],
- notificationList: [],
- projectAlarmList: [],
- repairList: [],
- breakdownList: [],
- mediaImgList: [],
- mediaVideo: null,
- monitorList: [],
- userGuideList: [],
- dailyList: [],
- projectProgress: null,
- projectTotalProgress: {
- AllProgress: 0,
- },
- layout: {
- 0: {
- config_json: [],
- },
- 1: {
- config_json: [],
- },
- 2: {
- config_json: [],
- },
- },
- chartConfigList: [],
- realProgress: {},
- progress: {},
- // currentChart: {}
- projectList: [],
- autoReport: {},
- patrolRecordDetail: {},
- patrolList: [],
- fileList: [],
- defaultConf: {},
- layoutAdmin: {
- 0: {
- config_json: [],
- },
- 1: {
- config_json: [],
- },
- 2: {
- config_json: [],
- },
- },
- },
- effects: {
- *getAutoPatrol({ payload, callback }, { call, put }) {
- const response = yield call(getAutoPatrol, payload);
- if (response) {
- // 查询数据报表详情
- const { data } = yield call(queryPatrolRecord, { recordId: response.data[0].Id });
- if (data) {
- const creatorName = data.CreatorUser && data.CreatorUser.CName;
- var status = {};
- let Items = [];
- const getItems = (item, patrolType) => {
- let key;
- if (patrolType == 1) {
- key = item.PatrolName;
- } else {
- key = item.DeviceCode + '-' + item.DeviceName;
- }
- item.patrolType = patrolType;
- item.ThresholdEnum = item.TemplateItem.ThresholdEnum;
- item.Type = item.TemplateItem.Type;
- if (!status[key]) status[key] = { normal: 0, error: 0 };
- if (item.Status == 1) {
- status[key].error++;
- } else {
- status[key].normal++;
- }
- return item;
- };
- data.ItemsExtend.forEach(item => {
- console.log(Items);
- if (item.PatrolCardRecordItemAssocThreshold) {
- var arr = item.PatrolCardRecordItemAssocThreshold.map(i => getItems(i, 1));
- Items = Items.concat(arr);
- } else {
- Items.push(getItems(item, 0));
- }
- });
- data.Items = Items;
- data.Points.forEach(item => {
- let key;
- if (item.PatrolType == 1) {
- key = item.DeviceName;
- } else {
- key = item.DeviceCode + '-' + item.DeviceName;
- }
- item.creatorName = creatorName;
- item.level = `${item.ExceptionLevel || '-'}/${item.DeviceLevel || '-'}`;
- item.status = status[key] || { normal: 0, error: 0 };
- });
- console.log(data);
- callback && callback(data);
- yield put({
- type: 'save',
- payload: { autoReport: data },
- });
- }
- }
- },
- *getProject({ payload }, { call, put }) {
- const response = yield call(getProject, payload);
- if (response) {
- yield put({
- type: 'save',
- payload: { projectDetail: response.data },
- });
- }
- },
- *getFaultAnalysis({ payload }, { call, put }) {
- const response = yield call(getFaultAnalysis, payload);
- if (response) {
- var list = [];
- response.data.forEach(item => {
- item.Details.forEach(err => {
- list.push({
- ...item,
- ...err,
- });
- });
- });
- yield put({
- type: 'save',
- payload: { faultAnalysis: list },
- });
- }
- },
- *getIssueList({ payload }, { call, put }) {
- const response = yield call(getIssueList, payload);
- if (response) {
- yield put({
- type: 'save',
- payload: { issueList: response.data.list },
- });
- }
- },
- *getRepairRecord({ payload }, { call, put }) {
- const response = yield call(getRepairRecord, payload);
- if (response) {
- yield put({
- type: 'save',
- payload: { repairList: response.data.list },
- });
- }
- },
- *getBreakdownRecord({ payload }, { call, put }) {
- const response = yield call(getBreakdownList, payload);
- if (response) {
- yield put({
- type: 'save',
- payload: { breakdownList: response.data.list },
- });
- }
- },
- *getPatrolRecord({ payload }, { call, put }) {
- const response = yield call(getPatrolRecord, payload);
- if (response) {
- yield put({
- type: 'save',
- payload: { patrolList: response.data.list },
- });
- }
- },
- *getProjectAlarm({ payload }, { call, put }) {
- const response = yield call(getProjectAlarm, payload);
- if (response) {
- yield put({
- type: 'save',
- payload: { projectAlarmList: response.data.list },
- });
- }
- },
- *getProjectActive({ payload }, { call, put }) {
- const response = yield call(getProjectActive, payload);
- if (response) {
- let stateName;
- // 0-项目动态 1-新闻动态 2-大事记 3-所获奖项
- switch (payload.type) {
- case 0:
- stateName = 'projectActive';
- break;
- case 1:
- stateName = 'news';
- break;
- case 2:
- stateName = 'memorabilia';
- break;
- case 3:
- stateName = 'awards';
- break;
- }
- if (!stateName) return;
- yield put({
- type: 'save',
- payload: { [stateName]: response.data.list },
- });
- }
- },
- *getNotificationList({ payload }, { call, put }) {
- const response = yield call(getNotificationList, payload);
- if (response) {
- yield put({
- type: 'save',
- payload: { notificationList: response.data.list },
- });
- }
- },
- *getMediaList({ payload }, { call, put }) {
- const response = yield call(getMediaList, payload);
- if (response) {
- var mediaVideo = null,
- mediaImgList = [];
- response.data.forEach(item => {
- if (/\.mp4$/.test(item.Name)) {
- if (!mediaVideo) {
- mediaVideo = item;
- }
- } else {
- mediaImgList.push(item);
- }
- });
- yield put({
- type: 'save',
- payload: {
- mediaVideo,
- mediaImgList,
- },
- });
- }
- },
- *getMonitorList({ payload }, { call, put }) {
- const response = yield call(getMonitorList, payload);
- if (response) {
- var obj = JSON.parse(response.data.config_json) || {};
- yield put({
- type: 'save',
- // payload: { monitorList: response.data.list },
- payload: { monitorList: Object.keys(obj).map(key => obj[key]) || [] },
- });
- }
- },
- *getUserGuide({ payload }, { call, put }) {
- const response = yield call(getUserGuide, payload);
- if (response) {
- var list = [];
- response.data.list.forEach(item => {
- item.UserGuideFiles.forEach(file => {
- list.push({
- ...item,
- ...file,
- });
- });
- });
- yield put({
- type: 'save',
- payload: { userGuideList: list },
- });
- }
- },
- *getDailyList({ payload }, { call, put }) {
- const response = yield call(getDailyList, payload);
- if (response) {
- yield put({
- type: 'save',
- payload: { dailyList: response.data.list },
- });
- }
- },
- *getProjectPlanProgress({ payload, callback }, { call, put }) {
- const response = yield call(getprojectPlanProgress, payload);
- if (response) {
- var progress = response.data;
- Object.keys(progress).forEach(k => {
- if (
- progress[k] == '0001-01-01T00:00:00Z' ||
- progress[k] == '0001-01-01 00:00:00' ||
- progress[k] == '0001-01-01 00:00:00 +0000 UTC'
- ) {
- progress[k] = '';
- }
- });
- yield put({
- type: 'save',
- payload: { progress },
- });
- }
- },
- *getProjectRealProgress({ payload }, { call, put, select }) {
- const calcProgress = data => {
- let count = 0,
- total = 0;
- data.forEach(item => {
- total += item.TotalCount;
- count += item.RealCount;
- });
- return ((count / total) * 100).toFixed(2);
- };
- let { realProgress } = yield select(s => s.dataMeterNew);
- console.log(realProgress);
- var keys = Object.keys(PLAN_TYPE);
- for (let i = 0; i < keys.length; i++) {
- let k = keys[i];
- var response = yield call(getProjectRealProgress, {
- ...payload,
- type: PLAN_TYPE[k],
- });
- if (response) {
- let tempRealProgress = response.data.Task.map(item => ({
- ...item,
- RealCount: item.FinishList.length || 0,
- TotalCount: item.DeviceCodes ? item.DeviceCodes.length : 0,
- children: null,
- }));
- console.log(tempRealProgress);
- realProgress[k] = calcProgress(tempRealProgress);
- }
- }
- yield put({
- type: 'save',
- payload: { realProgress: { ...realProgress } },
- });
- },
- *getProjectProgress({ payload }, { call, put }) {
- const response = yield call(getProjectProgress, payload);
- if (response) {
- yield put({
- type: 'save',
- payload: { projectProgress: response.data },
- });
- }
- },
- *deleteFile({ payload }, { call, put }) {
- const response = yield call(deleteFile, payload);
- if (response) {
- yield put({
- type: 'getMediaList',
- payload: payload,
- });
- }
- },
- *getProjectTotalProgress({ payload }, { call, put }) {
- const response = yield call(getProjectTotalProgress, payload);
- if (response) {
- yield put({
- type: 'save',
- payload: { projectTotalProgress: response.data },
- });
- }
- },
- *getLayoutOptions({ payload }, { call, put, select }) {
- // if (payload.is_default == 1) {
- // // 默认配置的projectId为0
- // payload.projectId = 0;
- // }
- const response = yield call(getLayoutOptions, payload);
- if (response) {
- var layout = yield select(state => state.dataMeterNew.layout);
- if (payload.is_default == 1) {
- layout = yield select(state => state.dataMeterNew.layoutAdmin);
- }
- var defaultLayout = payload.sub_module === 0 ? DEFAULT_MAP_LAYOUT : DEFAULT_LAYOUT;
- var data = response.data;
- try {
- data.config_json = JSON.parse(data.config_json);
- // response.data.config_json = defaultLayout;
- } catch (error) {
- // 解析失败则使用默认布局
- data.config_json = defaultLayout;
- console.log(error);
- }
- layout[payload.sub_module] = data;
- if (payload.is_default == 0)
- yield put({
- type: 'save',
- payload: { layout: { ...layout } },
- });
- else
- yield put({
- type: 'save',
- payload: { layoutAdmin: { ...layout } },
- });
- }
- },
- *saveLayoutOptions({ payload }, { call, put, select }) {
- // if (payload.is_default == 1) {
- // // 默认配置的projectId为0
- // payload.projectId = 0;
- // }
- if (payload.config_json == '[]') {
- message.error('保存的配置不能为空');
- return;
- }
- var response = yield call(saveLayoutOptions, payload);
- if (response) {
- var layout = yield select(state => state.dataMeterNew.layout);
- if (payload.is_default == 1) {
- layout = yield select(state => state.dataMeterNew.layoutAdmin);
- }
- console.log(payload.config_json);
- layout[payload.sub_module].config_json = JSON.parse(payload.config_json);
- if (payload.is_default == 0)
- yield put({
- type: 'save',
- payload: { layout: { ...layout } },
- });
- else
- yield put({
- type: 'save',
- payload: { layoutAdmin: { ...layout } },
- });
- }
- },
- *resizeLayout({ payload }, { call, select, put }) {
- // 默认配置的projectId为0
- const response = yield call(getLayoutOptions, {
- ...payload,
- // projectId: 0,
- });
- if (response) {
- var layout = yield select(state => state.dataMeterNew.layout);
- var defaultLayout = payload.sub_module === 0 ? DEFAULT_MAP_LAYOUT : DEFAULT_LAYOUT;
- var config_json = response.data.config_json
- ? JSON.parse(response.data.config_json)
- : defaultLayout;
- // response.data.config_json = defaultLayout;
- // 将默认配置保存到本地
- layout[payload.sub_module].config_json = config_json;
- yield put({
- type: 'save',
- payload: { layout: { ...layout } },
- });
- yield call(saveLayoutOptions, {
- ...payload,
- config_json: JSON.stringify(config_json),
- is_default: 0,
- });
- }
- },
- *resizeDefaultLayout({ payload }, { call, select, put }) {
- var layout = yield select(state => state.dataMeterNew.layout);
- var config_json = payload.sub_module === 0 ? DEFAULT_MAP_LAYOUT : DEFAULT_LAYOUT;
- // 将默认配置保存到本地
- layout[payload.sub_module].config_json = config_json;
- yield put({
- type: 'save',
- payload: { layout: { ...layout } },
- });
- yield call(saveLayoutOptions, {
- ...payload,
- config_json: JSON.stringify(config_json),
- is_default: 0,
- });
- },
- *queryConfigList({ payload, callback }, { call, put }) {
- const {
- data: { list: tplList },
- } = yield call(queryTemplateList, { pageSize: 999 });
- const {
- data: { list: configList },
- } = yield call(queryConfigList, {
- ...payload,
- isNew: 1,
- pageSize: 9999,
- });
- let list = [];
- configList.map(item => {
- let template = tplList.find(tpl => tpl.ID == item.type);
- item.options = JSON.parse(item.options);
- item.template = template;
- list.push(item);
- });
- callback && callback(list);
- yield put({
- type: 'save',
- payload: {
- chartConfigList: list,
- },
- });
- },
- *queryConfig({ payload, callback }, { call, put }) {
- const response = yield call(queryConfigList, payload);
- if (response) {
- var currentChart = response.data.list[0];
- currentChart.options = JSON.parse(currentChart.options);
- let { options, configs, type } = currentChart;
- // 将接口返回的实时数据更新到图表中
- if (type != 'pfd') {
- if (!options.series) {
- callback && callback(currentChart);
- }
- let series = options.series[0];
- if (type == 'pie') {
- configs.forEach((item, index) => {
- series.data[index].value = item.value;
- });
- } else if (series.type == 'bar') {
- configs.forEach((item, index) => {
- series.data[index] = item.value;
- });
- }
- }
- callback && callback(currentChart);
- // yield put({
- // type: 'save',
- // payload: {
- // currentChart,
- // },
- // });
- }
- },
- *getProjectList({ payload, callback }, { call, put }) {
- const response = yield call(getProjectList, payload);
- if (response) {
- let nowDate = new Date();
- (response.data.list || []).map(item => {
- let type;
- if (!item.EndDate) {
- type = 2;
- } else {
- type = nowDate >= new Date(item.EndDate) ? 2 : 1;
- }
- item.type = type;
- });
- yield put({
- type: 'save',
- payload: { projectList: response.data.list },
- });
- console.log(response.data.list);
- callback && callback(response.data.list);
- }
- },
- *queryProjectFileList({ payload }, { call, put, select }) {
- try {
- const response = yield call(queryProjectFileList, {
- ...payload,
- deviceCode: -1,
- });
- if (response) {
- yield put({
- type: 'save',
- payload: { fileList: response.data },
- });
- }
- } catch (e) {
- console.error(e);
- }
- },
- *getDefaultConfList({ payload }, { call, put }) {
- const response = yield call(getDefaultConfList, payload);
- if (response) {
- yield put({
- type: 'save',
- payload: { defaultConf: response.data },
- });
- }
- },
- },
- reducers: {
- save(state, action) {
- return {
- ...state,
- ...action.payload,
- };
- },
- },
- };
|