'use strict'; // const moment = require('moment'); // const CamundaApi = require('../../utils/camunda-api'); //运维相关的待办事项 async function getUnfinished (ctx) { const { models } = ctx.fs.dc const { clickHouse } = ctx.app.fs const userInfo = ctx.fs.api.userInfo; // const { camundaUserId } =ctx.fs.api const assignee='fsUser'+userInfo.pepUserId const BeforeAssignUser='fsBeforeAssignUser'+userInfo.pepUserId const AfterAssignUser='fsAfterAssignUser'+userInfo.pepUserId try{ let all=await clickHouse.camWorkflow.query(` SELECT DISTINCT * FROM ( SELECT * FROM ( SELECT DISTINCT RES.* FROM act_hi_taskinst RES, act_hi_procinst PRO WHERE 1 = 1 AND RES.end_time_ IS NULL AND 1 = 1 AND RES.assignee_ = '${assignee}' AND RES.proc_inst_id_ = PRO.proc_inst_id_ AND PRO.business_key_ in ('160','159') ) RES UNION ALL SELECT * FROM ( SELECT DISTINCT RES.* FROM act_hi_taskinst RES WHERE 1 = 1 AND RES.end_time_ IS NULL AND 1 = 1 AND RES.id_ IN ( SELECT id_ FROM act_hi_varinst VAR WHERE name_ IN ('${BeforeAssignUser}','${AfterAssignUser}') AND var_type_ IS NOT NULL AND var_type_ = 'string' AND text_ IS NOT NULL AND text_ = 'pending' ) ) RES ) AS res; `).toPromise() const procinstIds = [...new Set(all.map(e => e.proc_inst_id_))]; // 获取流程实例变量 if(all && all.length > 0){ let procinstsVariables = await ctx.app.camunda.request.post(encodeURI(`/engine-rest/history/variable-instance`), { processInstanceIdIn: procinstIds }) let data = { list: all, procinstsVariables: procinstsVariables, keywords: null, userInfo: userInfo, userId: userInfo.pepUserId }; ctx.body = { count: countFilters(data) } }else { ctx.body = { count: 0 }; } ctx.status = 200 }catch(error){ ctx.fs.logger.error(`path: ${ctx.path}, error: ${error}`); ctx.status = 400; ctx.body = { message: typeof error == 'string' ? error : undefined } } } function countFilters(data) { let totalCount = 0; // let searchKeywords = data.keywords ? data.keywords.toLowerCase() : null; let keywordsFlag = false; data.list.map(e => { let curVariables = data.procinstsVariables.body && data.procinstsVariables.body.filter(item => item.processInstanceId === e.processInstanceId); keywordsFlag = false; const isAssignee = e.assignee === `fsUser${data.userId}`; if (isAssignee) { //当前节点任务的办理人是自己才会过滤是否有前后加签 const fsAfterAssignUnNum = curVariables.find(v => (v.name == 'fsAfterAssignUnNum' && e.id == v.taskId)) ? true : false; const fsBeforeAssignUnNum = curVariables.find(v => (v.name == 'fsBeforeAssignUnNum' && e.id == v.taskId)) ? curVariables.find(v => (v.name == 'fsBeforeAssignUnNum' && e.id == v.taskId)) : false; //需要过滤一下前后加签,如果是当前用户的任务但是操作过前后加签不显示代办任务里 if (fsBeforeAssignUnNum) { //存在前加签判断是否前加签的人员已经处理完了 if (fsBeforeAssignUnNum.value === 0) { keywordsFlag = true; }; } else { //判断是否存在后加签,有后加签就不显示当前用户的待办任务 if (!fsAfterAssignUnNum) { keywordsFlag = true; } } } else { keywordsFlag = true; } if (keywordsFlag) { //暂未用到关键词传参 // if (searchKeywords) { // const fsFormItemName = curVariables.find(t => t.name == 'fsFormItemName') ? curVariables.find(t => t.name == 'fsFormItemName').value : ''; // const fsEmisApplyUserName = curVariables.find(t => t.name == 'fsEmisApplyUserName') ? curVariables.find(t => t.name == 'fsEmisApplyUserName').value : ''; // if (!((fsFormItemName && fsFormItemName.toLowerCase().includes(searchKeywords)) || (fsEmisApplyUserName.includes(searchKeywords)) // )) { // totalCount++; // } // } else { totalCount++; // } } }); return totalCount; } module.exports = { getUnfinished };