| | |
| | | create |
| | | v-model="curSubTaskList" |
| | | :loading="subTaskLoading" |
| | | :create-loading="daytaskLoading" |
| | | height="56vh" |
| | | @add="subTaskDrawer = true" |
| | | @add="handleAddSubtask" |
| | | @submit="handleSubtaskSubmit" |
| | | ></CompSubTaskList> |
| | | </el-col> |
| | |
| | | <CompDayTask |
| | | :day-task="curDayTask" |
| | | :mObjList="curMonitorObjList" |
| | | @submit="handleSubtaskSubmit" |
| | | ></CompDayTask> |
| | | </el-drawer> |
| | | <el-dialog |
| | |
| | | </template> |
| | | |
| | | <script> |
| | | import { unref } from 'vue'; |
| | | import { useCloned } from '@vueuse/core'; |
| | | import dayjs from 'dayjs'; |
| | | import taskApi from '@/api/fysp/taskApi'; |
| | | import CompMonitorObj from './components/CompMonitorObj.vue'; |
| | | import CompMonitorPlan from './components/CompMonitorPlan.vue'; |
| | |
| | | subTaskDrawer: false, |
| | | // 当前选择的日任务 |
| | | curDayTask: {}, |
| | | curDay: undefined, |
| | | daytaskLoading: false, |
| | | // 当前选择的日任务下的子任务 |
| | | curSubTaskList: undefined, |
| | | subTaskLoading: false, |
| | |
| | | topTaskAddVisible: false |
| | | }; |
| | | }, |
| | | provide() { |
| | | return { |
| | | topTask: this.curTask |
| | | }; |
| | | }, |
| | | computed: { |
| | | // 总任务状态统计 |
| | | taskStatus() { |
| | | let total = 0, |
| | | inspected = 0; |
| | | this.curMonitorObjList.forEach((obj) => { |
| | | total += parseInt(obj.monitornum); |
| | | inspected += obj.extension1 ? parseInt(obj.extension1) : 0; |
| | | }); |
| | | return [ |
| | | { name: '场景数', value: 100 }, |
| | | { name: '未巡查', value: 0 }, |
| | | { name: '已巡查', value: 0 } |
| | | { name: '场景数', value: total }, |
| | | { name: '未巡查', value: total - inspected }, |
| | | { name: '已巡查', value: inspected } |
| | | ]; |
| | | } |
| | | }, |
| | |
| | | type = 0; |
| | | break; |
| | | case '正在执行': |
| | | type = 1; |
| | | type = 5; |
| | | break; |
| | | case '已结束': |
| | | type = 2; |
| | | type = 6; |
| | | break; |
| | | default: |
| | | type = 0; |
| | |
| | | } |
| | | }); |
| | | }, |
| | | onDateChange(dayTask) { |
| | | onDateChange(dayTask, day) { |
| | | this.curDay = day; |
| | | if (dayTask) { |
| | | this.subTaskLoading = true; |
| | | // this.subTaskDrawer = true; |
| | |
| | | .finally(() => (this.subTaskLoading = false)); |
| | | } else { |
| | | this.curSubTaskList = []; |
| | | this.curDayTask = {}; |
| | | } |
| | | }, |
| | | navToTaskCreate(value) { |
| | |
| | | this.$refs.planRef |
| | | .fetchDayTasks() |
| | | .finally(() => (this.subTaskLoading = false)); |
| | | }, |
| | | handleAddSubtask() { |
| | | // 判断当日是否有日任务,若没有,先创建在跳转子任务创建界面 |
| | | if (this.curDayTask.guid) { |
| | | this.subTaskDrawer = true; |
| | | } else { |
| | | const _dayTask = useCloned(this.curTask.data).cloned.value; |
| | | const taskDate = dayjs(this.curDay); |
| | | _dayTask.tsguid = _dayTask.tguid; |
| | | _dayTask.tguid = null; |
| | | _dayTask.levelnum = null; |
| | | _dayTask.name = `${taskDate.format('YYYY年MM月DD日')}${ |
| | | _dayTask.cityname |
| | | }${_dayTask.districtname}${_dayTask.typename}任务`; |
| | | _dayTask.starttime = taskDate.startOf('day').toDate(); |
| | | _dayTask.endtime = taskDate.endOf('day').millisecond(0).toDate(); |
| | | _dayTask.settime = dayjs().toDate(); |
| | | _dayTask.t1stverifytime = dayjs().toDate(); |
| | | _dayTask.runingstatus = '未执行'; |
| | | this.daytaskLoading = true; |
| | | taskApi |
| | | .putTask(_dayTask) |
| | | .then((res) => { |
| | | this.curDayTask = { |
| | | guid: res.data.tguid, |
| | | tsGuid: res.data.tsguid, |
| | | changedTaskNum: 0, |
| | | check: true, |
| | | completeTaskNum: 0, |
| | | date: res.data.starttime, |
| | | totalTaskNum: 0 |
| | | }; |
| | | this.subTaskDrawer = true; |
| | | this.handleSubtaskSubmit(); |
| | | }) |
| | | .finally(() => (this.daytaskLoading = false)); |
| | | } |
| | | } |
| | | }, |
| | | mounted() { |