import { Component, OnInit, TemplateRef, ViewContainerRef } from '@angular/core'; import { FormBuilder, FormGroup, Validators } from '@angular/forms'; import { NzFormatEmitEvent, NzTreeComponent, NzTreeNodeOptions } from 'ng-zorro-antd/tree'; import { NzModalService } from 'ng-zorro-antd/modal'; import { NzMessageService } from 'ng-zorro-antd/message'; import { HttpClient } from '@angular/common/http'; import { TreeService } from 'src/app/service/tree.service'; import * as moment from 'moment'; import { TaskDetailsComponent } from './task-details/task-details.component'; import { CreateTaskComponent } from './create-task/create-task.component'; import { differenceInCalendarDays, setHours } from 'date-fns' import { PlanAdjustmentComponent } from '../da-oneself-plan/plan-adjustment/plan-adjustment.component'; import { MethodService } from 'src/app/service/method.service'; import { NewTaskMessageService } from 'src/app/service/new-task-message.service'; @Component({ selector: 'app-station-weekly-plan', templateUrl: './station-weekly-plan.component.html', styleUrls: ['./station-weekly-plan.component.scss'] }) export class StationWeeklyPlanComponent implements OnInit { constructor(private http: HttpClient, private modal: NzModalService, private message: NzMessageService, private viewContainerRef: ViewContainerRef, public methodService: MethodService, private newTaskMessage: NewTaskMessageService) { } OrganizationId userId isSupervisor today = new Date(); disabledDate = (current: Date): boolean => differenceInCalendarDays(current, this.today) <= 0; months = [ { id: 1, name: '1月', isable: true }, { id: 2, name: '2月', isable: true }, { id: 3, name: '3月', isable: true }, { id: 4, name: '4月', isable: true }, { id: 5, name: '5月', isable: true }, { id: 6, name: '6月', isable: true }, { id: 7, name: '7月', isable: true }, { id: 8, name: '8月', isable: true }, { id: 9, name: '9月', isable: true }, { id: 10, name: '10月', isable: true }, { id: 11, name: '11月', isable: true }, { id: 12, name: '12月', isable: true } ] selectedMonth selectedYear = 2024 selectedTime selectMonth(item) { this.selectedMonth = item.id this.initializeData() this.getTuesdayThursdayNum() this.getTaskList() this.getTaskListPass(this.stationData[0]) } selectYear(e) { this.selectedYear = e this.initializeData() this.getTuesdayThursdayNum() this.getTaskList() this.getTaskListPass(this.stationData[0]) } //当月有几个周二周四 TuesdayThursdayNum = 0 getTuesdayThursdayNum() { let selectedTime = this.selectedYear + '-' + this.selectedMonth + '-' + '01' this.http.get(`/api/TaskTargets/GetTargetCount/${selectedTime}`).subscribe((data: any) => { console.log('最大日期', data) this.TuesdayThursdayNum = data }) } isExpand = true expand() { this.isExpand = !this.isExpand } formatOne = (percent: number): string => `${percent}%\n完成率`; openDetails(data, type) { data.isDetails = type data.badgeNum = 0 } radioChange(e, i, element) { element.isLoading = true let body = { isSpread: e } this.http.patch(`/api/PlanTasks/${i.id}`, body).subscribe({ next: (data) => { this.message.create('success', e ? '宣传通知已发出' : '取消宣传'); element.isLoading = false }, error: (err) => { this.message.create('warning', '发送失败'); element.isLoading = false } }) } checkTime(e, i, element) { console.log(e) if (e) { let time = new Date(moment(e).format('yyyy-MM-DD HH:mm:ss')).toISOString() i.planTime = time } else { i.planTime = null } element.isLoading = true let body = { planTime: i.planTime } this.http.patch(`/api/PlanTasks/${i.id}`, body).subscribe({ next: (data) => { this.message.create('success', '检查日期分配成功'); element.isLoading = false }, error: (err) => { this.message.create('warning', '检查日期分配失败'); element.isLoading = false } }) } //获得辖区下所有救援站 totalCount: string allOrList: any getAllStation() { let params = { ContainsChildren: "true", PageNumber: 1, PageSize: 9999 } this.http.get('/api/Organizations', { params: params }).subscribe((data: any) => { this.totalCount = data.totalCount data.items = data.items.filter(element => { return element.level == 'squadron' }); data.items.forEach(element => { element.isExpand = false element.isLoading = false }); this.stationData = data.items }) } cardData = [ { name: '双随机', badgeNum: 0, isDetails: false, isLoading: false, background: '#1D9DFF', icon: 'suiji.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '行政许可', badgeNum: 0, isDetails: false, isLoading: false, background: '#42B983', icon: 'xuke.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '熟悉演练', badgeNum: 0, isDetails: false, isLoading: false, background: '#9D80FF', icon: 'yanlian.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '联络指导', badgeNum: 0, isDetails: false, isLoading: false, background: '#5483EA', icon: 'zhidao.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '消防宣传', badgeNum: 0, isDetails: false, isLoading: false, background: '#FF5D2A', icon: 'xuanchuan.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '投诉举报', badgeNum: 0, isDetails: false, isLoading: false, background: '#5087FF', icon: 'tousu.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '火灾调查', badgeNum: 0, isDetails: false, isLoading: false, background: '#FF404D', icon: 'huozai.png', passed: 0, inspected: 0, percentage: 0, data: [] } ] //初始化数据 initializeData() { this.cardData = [ { name: '双随机', badgeNum: 0, isDetails: false, isLoading: false, background: '#1D9DFF', icon: 'suiji.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '行政许可', badgeNum: 0, isDetails: false, isLoading: false, background: '#42B983', icon: 'xuke.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '熟悉演练', badgeNum: 0, isDetails: false, isLoading: false, background: '#9D80FF', icon: 'yanlian.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '联络指导', badgeNum: 0, isDetails: false, isLoading: false, background: '#5483EA', icon: 'zhidao.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '消防宣传', badgeNum: 0, isDetails: false, isLoading: false, background: '#FF5D2A', icon: 'xuanchuan.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '投诉举报', badgeNum: 0, isDetails: false, isLoading: false, background: '#5087FF', icon: 'tousu.png', passed: 0, inspected: 0, percentage: 0, data: [] }, { name: '火灾调查', badgeNum: 0, isDetails: false, isLoading: false, background: '#FF404D', icon: 'huozai.png', passed: 0, inspected: 0, percentage: 0, data: [] } ] this.stationData.forEach(element => { element.isExpand = true element.isLoading = false element.data = [] }); } isShow(element) { let isShow = true if (element.creationType == '申领任务') { if (this.isSupervisor) {//检查员 if (element.taskType == '熟悉演练' || (element.taskType == '联络指导' && element.approvalStatus == '待处理' && element.relatedTaskId == null) ) { isShow = false } } else {//消防站 if (element.taskType == '联络指导' || (element.taskType == '熟悉演练' && element.approvalStatus == '待处理' && element.relatedTaskId == null) || (element.taskType == '双随机' && element.relatedTaskId == null)) { isShow = false } } } return isShow } isLoading = false PageNumber = 1 PageSize = 9999 async getTaskList() { this.cardData.forEach(element => { element.data = [] element.percentage = 0 element.passed = 0 element.inspected = 0 }) this.isLoading = true let selectedTime = this.selectedYear + '-' + this.selectedMonth + '-' + '01' let params = { Month: selectedTime, SupervisorId: this.isSupervisor ? this.userId : null, assistantOrganizationId: this.isSupervisor ? null : this.OrganizationId, PageNumber: this.PageNumber, PageSize: this.PageSize, approvalStatuses: ['待处理', '通过', '驳回', '待检查', '已检查'] } return await new Promise((resolve, reject) => { this.http.get('/api/PlanTasks', { params: params }).subscribe((data: any) => { this.isLoading = false // console.log('任务申请列表', data.items) data.items.forEach(element => { if (this.isShow(element)) { this.cardData.forEach((item, key) => { element.taskType == item.name ? this.cardData[key].data.push(element) : null }); } }); this.cardData.forEach(element => { element.data.forEach(item => { item.approvalStatus == '待检查' ? element.passed += 1 : null item.approvalStatus == '已检查' ? element.inspected += 1 : null }) }) this.cardData.forEach(element => { element.percentage = Math.round((element.inspected / element.data.length) * 100) }) resolve(data) console.log('并入卡片数据', this.cardData) }) }) } stationData = [ { name: '', isExpand: true, isLoading: false, data: [], allUnitsNum: 0, awaitInspect: 0, inspected: 0, percentage: 0 } ] async getTaskListPass(item) { let selectedTime = this.selectedYear + '-' + this.selectedMonth + '-' + '01' let params = { Month: selectedTime, approvalStatuses: ['通过', '待检查', '已检查'], SupervisorId: this.isSupervisor ? this.userId : null, assistantOrganizationId: this.isSupervisor ? null : this.OrganizationId, PageNumber: this.PageNumber, PageSize: this.PageSize, TaskTypes: this.isSupervisor ? ['双随机', '联络指导'] : ['熟悉演练'], } item.isLoading = true return await new Promise((resolve, reject) => { this.http.get('/api/PlanTasks', { params: params }).subscribe((data: any) => { item.isLoading = false let listData = [ { name: '双随机', background: '#1D9DFF', icon: 'suiji.png', scale: '0/0', data: [], inspected: 0, finished: 0 }, { name: '行政许可', background: '#42B983', icon: 'xuke.png', scale: '0/0', data: [], inspected: 0, finished: 0 }, { name: '熟悉演练', background: '#9D80FF', icon: 'yanlian.png', scale: '0/0', data: [], inspected: 0, finished: 0 }, { name: '联络指导', background: '#5483EA', icon: 'zhidao.png', scale: '0/0', data: [], inspected: 0, finished: 0 }, { name: '消防宣传', background: '#FF5D2A', icon: 'xuanchuan.png', scale: '0/0', data: [], inspected: 0, finished: 0 }, { name: '投诉举报', background: '#5087FF', icon: 'tousu.png', scale: '0/0', data: [], inspected: 0, finished: 0 }, { name: '火灾调查', background: '#FF404D', icon: 'huozai.png', scale: '0/0', data: [], inspected: 0, finished: 0 } ] data.items.forEach(element => { if (this.isShow(element)) { listData.forEach((item, key) => { element.taskType == item.name ? listData[key].data.push(element) : null }); } }); for (let index = 0; index < listData.length; index++) { const element = listData[index]; if (element.data.length == 0) { listData.splice(index, 1) index-- } } item.data = listData console.log('当前登录用户所有通过的任务', item); item.allUnitsNum = 0 item.awaitInspect = 0 item.inspected = 0 item.finished = 0 item.data.forEach(element => { item.allUnitsNum += element.data.length element.data.forEach(i => { i.approvalStatus == '待检查' ? item.awaitInspect += 1 : null i.approvalStatus == '已检查' ? item.inspected += 1 : null i.approvalStatus == '待检查' ? element.inspected += 1 : null i.approvalStatus == '已检查' ? element.finished += 1 : null }); }); item.percentage = Math.round((item.inspected / item.allUnitsNum) * 100) resolve(data) }) }) } //接受任务 accept(i, item) { if (i.approvalStatus == '通过') { this.message.create('warning', '不能重复接受'); return } if (i.approvalStatus == '待检查') { this.message.create('warning', '任务处于待检查状态,不能再次接受'); return } this.modal.confirm({ nzTitle: `确定要接受该任务吗?`, nzOkText: '确定', nzOkType: 'default', nzOnOk: () => { item.isLoading = true this.http.post(`/api/PlanTasks/Approval/${i.id}`, null, { params: { approvalStatus: '待检查' } }).subscribe({ next: (data) => { this.message.create('success', '已接受'); i.approvalStatus = '待检查' item.isLoading = false item.passed += 1 this.getTaskListPass(this.stationData[0]) }, error: (err) => { this.message.create('warning', '接受失败'); item.isLoading = false } }) }, nzCancelText: '取消' }); } //拒绝任务 reject(i, item) { if (i.approvalStatus == '驳回') { this.message.create('warning', '不能重复驳回'); return } this.modal.confirm({ nzTitle: `确定要拒绝该任务吗?`, nzOkText: '确定', nzOkType: 'default', nzOnOk: () => { item.isLoading = true this.http.post(`/api/PlanTasks/Approval/${i.id}`, null, { params: { approvalStatus: '驳回' } }).subscribe({ next: (data) => { this.message.create('success', '已拒绝'); i.approvalStatus = '驳回' item.isLoading = false item.passed -= 1 this.getTaskListPass(this.stationData[0]) }, error: (err) => { this.message.create('warning', '拒绝失败'); item.isLoading = false } }) }, nzCancelText: '取消' }); } //删除任务 delete(i, item) { console.log(i) console.log(item) this.modal.confirm({ nzTitle: `确定要删除该任务吗?`, nzOkText: '确定', nzOkType: 'primary', nzOnOk: () => { this.http.delete(`/api/PlanTasks/${i.id}`).subscribe(data => { for (let index = 0; index < item.data.length; index++) { const element = item.data[index]; if (element.id == i.id) { item.data.splice(index, 1) index-- } } this.message.create('success', '删除成功!'); }) }, nzCancelText: '取消', nzOnCancel: () => { } }); } userName organizationName ngOnInit(): void { this.OrganizationId = JSON.parse(sessionStorage.getItem('userData')).organizationId this.userId = JSON.parse(sessionStorage.getItem('userData')).id this.userName = JSON.parse(sessionStorage.getItem('userData')).name this.organizationName = JSON.parse(sessionStorage.getItem('userData')).organizationName let roles = JSON.parse(sessionStorage.getItem('userData')).roles let isSupervisor = roles.find(item => { return item.name.indexOf('检查') != -1 }) isSupervisor ? this.isSupervisor = true : this.isSupervisor = false if (isSupervisor) { this.stationData[0].name = this.userName } else { this.stationData[0].name = this.organizationName } this.selectedMonth = new Date().getMonth() + 1 // this.getAllStation() this.getTaskList() this.getTaskListPass(this.stationData[0]) this.getTuesdayThursdayNum() setTimeout(() => { this.rollStart() }, 0); this.newTaskMessage.getMessage().subscribe((data: any) => { console.log('具体任务信息', data); if (data.signalRData.content == '您有一条新的一体化任务,请注意查收。') { this.cardData.forEach((item: any) => { if (item.name == data.taskType) { console.log('要push的数组', item.data) item.data.unshift(data) if (!item.isDetails) { item.badgeNum += 1 } if (data.approvalStatus == '待检查') { item.passed += 1 this.getTaskListPass(this.stationData[0]) } } }) } if (data.signalRData.content == '您参与的任务已取消,请点击查看详情。') { // this.cardData.forEach((item: any) => { // if (item.name == data.taskType) { // for (let index = 0; index < item.data.length; index++) { // const element = item.data[index]; // if (element.id == data.signalRData.planTaskId) { // item.data.splice(index, 1) // index-- // } // } // if (!item.isDetails) { // item.badgeNum -= 1 // } // this.getTaskListPass(this.stationData[0]) // } // }) } if (data.signalRData.content == '您参与的任务时间变更,请点击查看详情。') { this.stationData[0].data.forEach(element => { if (element.name == data.taskType) { element.data.forEach(item => { if (item.id == data.id) { item.planTime = data.planTime } }); } }); } }); } timer rollStart() { var ROLL_SPEED = 100 var noticeList1 = document.getElementById('notice-list'); var noticeList2 = document.getElementById('notice-list-2'); var listWrapper = document.getElementById('list-wrapper'); noticeList2.innerHTML = noticeList1.innerHTML; this.timer = setInterval(rollStart, ROLL_SPEED); function rollStart() { if (Math.abs(_subStr(listWrapper.style.top)) >= noticeList1.clientHeight) { listWrapper.style.top = '0px' } else { var top = listWrapper.style.top listWrapper.style.top = _subStr(top) - 1 + 'px' } } // 截取px前数值 function _subStr(str) { var index = str.indexOf('px'); if (index > -1) { return parseFloat(str.substr(0, index + 1)) } } } mouseEnter() { window.clearInterval(this.timer); } mouseleave() { this.rollStart() } ngOnDestroy(): void { console.log('退出了') this.mouseEnter() } expandcarditem(item) { item.isExpand = !item.isExpand } taskDetails(item) { // console.log(item) const modal = this.modal.create({ nzTitle: item.name, nzContent: TaskDetailsComponent, nzViewContainerRef: this.viewContainerRef, nzWidth: 900, nzMaskClosable: false, nzFooter: null, nzComponentParams: { data: item, parent: this } }); const instance = modal.getContentComponent(); modal.afterOpen.subscribe(() => console.log('[afterOpen] emitted!')); modal.afterClose.subscribe(result => { // item // this.getTaskList() this.getTaskListPass(this.stationData[0]) }); } apply(item) { const modal = this.modal.create({ nzTitle: '新增' + item.name + '任务', nzContent: CreateTaskComponent, nzViewContainerRef: this.viewContainerRef, nzWidth: 660, nzMaskClosable: false, nzComponentParams: { title: item.name, }, nzOnOk: async () => { console.log(instance.validateForm.value) if (instance.validateForm.valid) { await new Promise((resolve, reject) => { let selectedMonth = this.selectedMonth < 10 ? "0" + this.selectedMonth : this.selectedMonth; let selectedTime = this.selectedYear + '-' + selectedMonth + '-' + '01' let body = { month: selectedTime, taskName: instance.validateForm.value.taskname, taskType: instance.validateForm.value.taskname, companyId: instance.validateForm.value.unitname.id, organizationId: this.OrganizationId, supervisorIds: this.isSupervisor ? [this.userId] : [], assistantOrganizationIds: this.isSupervisor ? [] : [this.OrganizationId], creationType: '自主任务', approvalStatus: '待检查' } this.http.post('/api/PlanTasks', body).subscribe({ next: (data: any) => { console.log(item) data.company = instance.validateForm.value.unitname item.data.unshift(data) item.passed += 1 // this.getTaskList() this.getTaskListPass(this.stationData[0]) this.message.create('success', '创建成功'); resolve(data) return true }, error: (err) => { this.message.create('warning', '创建失败'); reject(err) return false } }) }) } else { this.message.create('warning', '请填写完整!'); return false } } }); const instance = modal.getContentComponent(); modal.afterOpen.subscribe(() => console.log('[afterOpen] emitted!')); modal.afterClose.subscribe(result => console.log('[afterClose] The result is:', result)); } createTask(element) { console.log(element) let taskIds = [] element.data.forEach(item => { item.data.forEach(i => { i.planTime && i.approvalStatus != '已检查' ? taskIds.push(i.id) : null }); }); let params = { ids: taskIds, approvalStatus: '待检查' } this.http.post('/api/PlanTasks/ApprovalMany', null, { params: params }).subscribe({ next: (data: any) => { this.getTaskListPass(this.stationData[0]) this.message.create('success', '发布成功'); }, error: (err) => { this.message.create('warning', '发布失败'); } }) } adjustment(item) { let selectedTime = this.selectedYear + '-' + this.selectedMonth + '-' + '01' const modal = this.modal.create({ nzTitle: "任务调整", nzContent: PlanAdjustmentComponent, nzViewContainerRef: this.viewContainerRef, nzWidth: 900, nzFooter: null, nzComponentParams: { data: JSON.parse(JSON.stringify(item)), time: selectedTime, level: '非大队' } }); const instance = modal.getContentComponent(); modal.afterClose.subscribe(result => { this.getTaskList() this.getTaskListPass(this.stationData[0]) }); } allPass(item) { console.log(item) this.modal.confirm({ nzTitle: `确定要全部接受该模块下所有任务吗?`, nzOkText: '确定', nzOkType: 'default', nzOnOk: () => { let ids = [] item.data.forEach(element => { if (element.approvalStatus == '待处理' || element.approvalStatus == '驳回') ids.push(element.id) }); this.http.post(`/api/PlanTasks/ApprovalMany`, null, { params: { ids: ids, approvalStatus: '待检查' } }).subscribe({ next: (data) => { this.message.create('success', '成功'); item.data.forEach(element => { element.approvalStatus = '待检查' }); this.getTaskListPass(this.stationData[0]) }, error: (err) => { this.message.create('warning', '失败'); item.isLoading = false } }) }, nzCancelText: '取消' }); } ischat = false taskId openchat(item) { console.log(item) this.taskId = item.id this.ischat = true } closechat() { this.ischat = false } }