You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
183 lines
6.3 KiB
183 lines
6.3 KiB
2 years ago
|
'use strict';
|
||
|
|
||
|
|
||
|
//维护计划
|
||
|
async function getMaintenancePlan(ctx) {
|
||
|
try {
|
||
|
const { models } = ctx.fs.dc
|
||
|
const { clickHouse } = ctx.app.fs
|
||
|
const query = ctx.query
|
||
|
//console.log('11121', query)
|
||
|
let resCount = await models.MaintenancePlan.count({
|
||
|
where: { type: query.type }
|
||
|
})
|
||
|
const res = await models.MaintenancePlan.findAndCount({
|
||
|
order: [['id', 'DESC']],
|
||
|
offset: (query.pageIndex - 1) * query.pageSize,
|
||
|
|
||
|
limit: query.pageSize,
|
||
|
attributes: ['id', 'missionName', 'remark', 'reason', 'planFinishTime', 'actualFinishTime', 'type', 'state'],
|
||
|
where: { type: query.type },
|
||
|
include: [{
|
||
|
attributes: ['id', 'maintenancePlanId', 'pepUserId'],
|
||
|
model: models.MaintenancePlanExecuteUser
|
||
|
}]
|
||
|
})
|
||
|
//console.log('res1', res)
|
||
|
const arrayUserId = []
|
||
|
res.rows.forEach((item) => { item.maintenancePlanExecuteUsers.forEach((item1) => { arrayUserId.push(item1.pepUserId) }) })
|
||
|
const arrayUserIdCopy = [...new Set(arrayUserId)]
|
||
|
const whereOption = '(' + arrayUserIdCopy.toString() + ')'
|
||
|
const userRes = await clickHouse.pepEmis.query(`
|
||
|
SELECT * FROM user
|
||
|
WHERE id in ${whereOption}
|
||
|
`).toPromise()
|
||
|
//console.log('userRes', userRes)
|
||
|
//console.log('res.rows', res.rows)
|
||
|
const responseRes = res.rows.map((item) => {
|
||
|
return {
|
||
|
id: item.id,
|
||
|
missionName: item.missionName,
|
||
|
remark: item.remark,
|
||
|
reason: item.reason,
|
||
|
planFinishTime: item.planFinishTime,
|
||
|
actualFinishTime: item.actualFinishTime,
|
||
|
type: item.type,
|
||
|
state: item.state,
|
||
|
maintenancePlanExecuteUsers:
|
||
|
item.maintenancePlanExecuteUsers.map((item1) => {
|
||
|
return {
|
||
|
id: item1.id,
|
||
|
maintenancePlanId: item1.maintenancePlanId,
|
||
|
pepUserId: item1.pepUserId,
|
||
|
name: userRes.filter((ac) => { return ac.id == item1.pepUserId })[0].name
|
||
|
}
|
||
|
})
|
||
|
}
|
||
|
})
|
||
|
ctx.body = { count: resCount, responseRes }
|
||
|
//console.log('responseRes', responseRes)
|
||
|
ctx.status = 200
|
||
|
|
||
|
} catch (error) {
|
||
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`)
|
||
|
ctx.status = 400
|
||
|
ctx.body = {
|
||
|
message: `${query.msg}失败`
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
async function delMaintenancePlan(ctx) {
|
||
|
const transaction = await ctx.fs.dc.orm.transaction();
|
||
|
try {
|
||
|
const { models } = ctx.fs.dc
|
||
|
const query = ctx.query
|
||
|
const { responseId } = query
|
||
|
//console.log('queryzz', [...responseId])
|
||
|
await models.MaintenancePlanExecuteUser.destroy({ where: { maintenancePlanId: responseId } })
|
||
|
await models.MaintenancePlan.destroy({ where: { id: responseId } })
|
||
|
ctx.status = 204
|
||
|
await transaction.commit();
|
||
|
|
||
|
} catch (error) {
|
||
|
await transaction.rollback();
|
||
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`)
|
||
|
ctx.status = 400
|
||
|
ctx.body = {
|
||
|
message: '删除临时响应失败'
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
async function editMaintenancePlan(ctx) {
|
||
|
const transaction = await ctx.fs.dc.orm.transaction();
|
||
|
try {
|
||
|
const { models } = ctx.fs.dc
|
||
|
const data = ctx.request.body
|
||
|
//console.log('data1', data)
|
||
|
//存在id为编辑,否则是添加
|
||
|
if (data.id) {
|
||
|
if (data.type == 'temp') {
|
||
|
await models.MaintenancePlan.update({
|
||
|
actualFinishTime: data.actualFinishTime,
|
||
|
missionName: data.missionName,
|
||
|
remark: data.remark,
|
||
|
reason: data.reason,
|
||
|
planFinishTime: data.planFinishTime,
|
||
|
state: data.state
|
||
|
}, { where: { id: data.id } })
|
||
|
} else {
|
||
|
await models.MaintenancePlan.update({
|
||
|
actualFinishTime: data.actualFinishTime,
|
||
|
missionName: data.missionName,
|
||
|
remark: data.remark,
|
||
|
planFinishTime: data.planFinishTime,
|
||
|
state: data.state
|
||
|
}, { where: { id: data.id } })
|
||
|
}
|
||
|
//删除相关联的所有执行者
|
||
|
await models.MaintenancePlanExecuteUser.destroy({ where: { maintenancePlanId: data.id } })
|
||
|
//重新创建相关的执行者
|
||
|
const insertVal = data.manger.map((item) => {
|
||
|
return {
|
||
|
maintenancePlanId: data.id, pepUserId: item
|
||
|
}
|
||
|
})
|
||
|
await models.MaintenancePlanExecuteUser.bulkCreate(insertVal)
|
||
|
|
||
|
} else {
|
||
|
if (data.type == 'temp') {
|
||
|
const plan = await models.MaintenancePlan.create({
|
||
|
actualFinishTime: data.actualFinishTime,
|
||
|
missionName: data.missionName,
|
||
|
remark: data.remark,
|
||
|
reason: data.reason,
|
||
|
planFinishTime: data.planFinishTime,
|
||
|
type: data.type,
|
||
|
state: data.state
|
||
|
})
|
||
|
//console.log('data.manger',data.manger)
|
||
|
const insertVal = data.manger.map((item) => {
|
||
|
return {
|
||
|
maintenancePlanId: plan.id, pepUserId: item
|
||
|
}
|
||
|
})
|
||
|
await models.MaintenancePlanExecuteUser.bulkCreate(insertVal)
|
||
|
} else {
|
||
|
//console.log('data.manger', data.manger)
|
||
|
const plan = await models.MaintenancePlan.create({
|
||
|
actualFinishTime: data.actualFinishTime,
|
||
|
missionName: data.missionName,
|
||
|
remark: data.remark,
|
||
|
planFinishTime: data.planFinishTime,
|
||
|
type: data.type,
|
||
|
state: data.state
|
||
|
})
|
||
|
//console.log('planId1', plan.id)
|
||
|
const insertVal = data.manger.map((item) => {
|
||
|
return {
|
||
|
maintenancePlanId: plan.id, pepUserId: item
|
||
|
}
|
||
|
})
|
||
|
await models.MaintenancePlanExecuteUser.bulkCreate(insertVal)
|
||
|
}
|
||
|
}
|
||
|
ctx.status = 204
|
||
|
await transaction.commit();
|
||
|
}
|
||
|
|
||
|
catch (error) {
|
||
|
await transaction.rollback();
|
||
|
ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`)
|
||
|
ctx.status = 400
|
||
|
ctx.body = {
|
||
|
message: `${data.msg}失败`
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|
||
|
module.exports = {
|
||
|
getMaintenancePlan, delMaintenancePlan, editMaintenancePlan
|
||
|
}
|