Browse Source

feat: fix bugs

dev
zhaobing’ 1 year ago
parent
commit
b017a0c0f1
  1. 27
      api/app/lib/controllers/project/group.js
  2. 9
      api/app/lib/schedule/workOrder.js
  3. 1
      web/client/src/layout/actions/workOrders.js
  4. 36
      web/client/src/sections/projectGroup/containers/bigscreen.jsx

27
api/app/lib/controllers/project/group.js

@ -587,30 +587,30 @@ async function groupProject (ctx) {
} }
async function getProjectWorkOrders(){ async function getProjectWorkOrders(ctx){
try{ try{
// 计算一个月前的日期 // 计算一个月前的日期
const oneMonthAgo = moment().subtract(1, 'months').toDate() const oneMonthAgo = moment().subtract(1, 'months').toDate()
const { models } = ctx.fs.dc const { models } = ctx.fs.dc
const {Op, fn, col} = ctx.fs.dc.ORM.sequelize const sequelize = ctx.fs.dc.ORM
const { projectIds } = ctx.query const { projectIds } = ctx.query
if(projectIds&&projectIds.length){ if(projectIds&&projectIds.length){
const projectIdsArr=projectIds.split(',').map(Number) const projectIdsArr=projectIds.split(',').map(Number)
const res= await models.FormDataTable.findAll({ const res= await models.FormDataTable.findAll({
attributes: [ attributes: [
'projectId', 'projectId',
[fn('COUNT', col('id')), 'count'], [sequelize.fn('COUNT', sequelize.col('id')), 'count'],
], ],
where: { where: {
projectIds: { projectId: {
[Op.in]: projectIdsArr, $in: projectIdsArr,
}, },
startTime: { startTime: {
[Op.gte]: oneMonthAgo, $gte: oneMonthAgo,
}, },
}, },
group: ['projectId'], group: ['projectId'],
order: [[fn('COUNT', col('id')), 'DESC']], order: [[sequelize.fn('COUNT', sequelize.col('id')), 'DESC']],
}) })
ctx.body=res ctx.body=res
ctx.status=200 ctx.status=200
@ -628,24 +628,25 @@ async function getProjectWorkOrders(){
} }
} }
async function getWorkOrdersRepairRank(){ async function getWorkOrdersRepairRank(ctx){
try{ try{
const oneMonthAgo = moment().subtract(1, 'months').toDate() const oneMonthAgo = moment().subtract(1, 'months').toDate()
const { models } = ctx.fs.dc const { models } = ctx.fs.dc
const {Op, fn, col} = ctx.fs.dc.ORM.sequelize const sequelize = ctx.fs.dc.ORM
const { projectIds } = ctx.query const { projectIds } = ctx.query
if(projectIds&&projectIds.length){ if(projectIds&&projectIds.length){
const res= await models.FormDataTable.findAll({ const res= await models.FormDataTable.findAll({
where: { where: {
projectIds: { projectId: {
[Op.in]: projectIds.split(',').map(Number), $in: projectIds.split(',').map(Number)
}, },
startTime: { startTime: {
[Op.gte]: oneMonthAgo, $gte: oneMonthAgo,
} }
}, },
order: [ order: [
[fn('TIMESTAMPDIFF', literal('SECOND'), col('endTime'), col('startTime')), 'DESC'] [sequelize.literal('(EXTRACT(EPOCH FROM "end_time" - "start_time"))'), 'DESC']
] ]
}) })
ctx.body=res ctx.body=res

9
api/app/lib/schedule/workOrder.js

@ -53,37 +53,40 @@ module.exports = function (app, opts) {
ON fgroup.id = fprocess.group_id ON fgroup.id = fprocess.group_id
INNER JOIN ${camWorkflow}.act_hi_procinst AS procin INNER JOIN ${camWorkflow}.act_hi_procinst AS procin
ON procin.id_ = story.procinst_id ON procin.id_ = story.procinst_id
AND procin.state_='COMPLETED'
${rescount ?` WHERE procin.end_time_ is not null ${rescount ?` WHERE procin.end_time_ is not null
AND procin.end_time_ > '${lastExecutionTime}' AND procin.end_time_ > '${lastExecutionTime}'
AND procin.end_time_ <='${startTime}'` AND procin.end_time_ <='${startTime}'`
: ''}` : ''}`
).toPromise() ).toPromise()
console.log('formRes1',formRes)
const procinstIds = [...new Set(formRes.map(e => e.procinstId))]; const procinstIds = [...new Set(formRes.map(e => e.procinstId))];
console.log('formRes1',procinstIds)
// 获取流程实例变量 // 获取流程实例变量
if(formRes && formRes.length > 0){ if(formRes && formRes.length > 0){
let procinstsVariables = await ctx.app.camunda.request.post(encodeURI(`/engine-rest/history/variable-instance`), { let procinstsVariables = await ctx.app.camunda.request.post(encodeURI(`/engine-rest/history/variable-instance`), {
processInstanceIdIn: procinstIds processInstanceIdIn: procinstIds
}) })
console.log('formRes2',procinstsVariables)
for (let f of formRes) { for (let f of formRes) {
const parseData = parseProcessData({ const parseData = parseProcessData({
formSchema: JSON.parse(f.formSchema), formSchema: JSON.parse(f.formSchema),
formData: JSON.parse(f.formData) formData: JSON.parse(f.formData)
}) })
await models.Workorder.create({ const res=await models.Workorder.create({
projectId:parseData.pomsProjectId.value || null, projectId:parseData.pomsProjectId.value || null,
formname:procinstsVariables.find(item=>item.id===f.procinstId).name||null, formname:procinstsVariables.find(item=>item.id===f.procinstId).name||null,
state: f.state||null, state: f.state||null,
endTime:f.endTime||null, endTime:f.endTime||null,
startTime:f.createTime||null startTime:f.createTime||null
}) })
console.log('formRes3',res)
console.log('工单数据抽取结束') console.log('工单数据抽取结束')
} }
} }
}catch(error){ }catch(error){
console.error(error) console.error('失败原因',error)
} }
} }
); );

1
web/client/src/layout/actions/workOrders.js

@ -3,7 +3,6 @@
import { ApiTable, basicAction } from '$utils' import { ApiTable, basicAction } from '$utils'
export function getWorkOrders () { //获取工单的待办 export function getWorkOrders () { //获取工单的待办
console.log('xxxxx',ApiTable.workOrders)
return dispatch => basicAction({ return dispatch => basicAction({
type: 'get', type: 'get',
dispatch: dispatch, dispatch: dispatch,

36
web/client/src/sections/projectGroup/containers/bigscreen.jsx

@ -25,7 +25,7 @@ const Bigscreen = (props) => {
const [proportion, setProportion] = useState([]) const [proportion, setProportion] = useState([])
const [formatter, setFormatter] = useState({}) const [formatter, setFormatter] = useState({})
const [groupDetail, setGroupDetail] = useState({}) const [groupDetail, setGroupDetail] = useState({})
const [allProjects,setAllProjects]=useState([])
const [alarmData, setAlarmData] = useState()// const [alarmData, setAlarmData] = useState()//
const [biggest, setBiggest] = useState()// const [biggest, setBiggest] = useState()//
const [mockData, setMockData] = useState()// const [mockData, setMockData] = useState()//
@ -67,7 +67,11 @@ const Bigscreen = (props) => {
setGroupDetail(res.payload.data) setGroupDetail(res.payload.data)
} }
}) })
dispatch(actions.workOrder.getPomsProjectBasicAll()).then(res => {
if (res.success) {
setAllProjects(res.payload.data)
}
})
@ -135,27 +139,27 @@ const Bigscreen = (props) => {
} }
}, [mockData]) }, [mockData])
console.log('xxx1',actions)
useEffect(() => { useEffect(() => {
if(groupDetail?.pomsProjectIds&&groupDetail?.pomsProjectIds.length){ if(groupDetail?.pomsProjectIds&&groupDetail?.pomsProjectIds.length&&allProjects&&allProjects.length){
const query=groupDetail?.pomsProjectIds+'' const query=groupDetail?.pomsProjectIds
dispatch(actions.projectGroup.getProjectWorkOrders({projectIds:query})).then(res=>{ dispatch(actions.projectGroup.getProjectWorkOrders({projectIds:query})).then(res=>{
if(res.success){ if(res.success){
setProportion([...res.payload.data?.slice(0, 3)?.map(v => ({ name: pomsProjectBasicAll.find(item=>item.valiue===v.projectId)?.label, value: v.count })), setProportion([...res.payload.data?.slice(0, 3)?.map(v => ({ name: allProjects?.find(item=>item.value===v.projectId)?.label, value: Number(v.count) })),
{ value: res.payload.data&&res.payload.data.length>3?res.payload.data?.slice(3)?.reduce((p,c)=>{ { name: '其它', value: res.payload.data&&res.payload.data.length>3?res.payload.data?.slice(3)?.reduce((p,c)=>{
return p+c.count return p+Number(c.count)
},0):0, name: '其它' }]) },0):0 }])
} }
}) })
dispatch(actions.projectGroup.getProjectWorkOrders({projectIds:query})).then(res=>{ dispatch(actions.projectGroup.getWorkOrdersRepairRank({projectIds:query})).then(res=>{
if(res.success){ if(res.success){
setGroupProject(res.payload.data?.slice(0, 10).map(v => ({name:v.formname,duration:v?.endTime.diff(v?.startTime,'hours') })) || []) setGroupProject(res.payload.data?.slice(0, 10).map(v => ({name:v.formname,duration:moment(v?.endTime).diff(v?.startTime,'hours') })) || [])
} }
}) })
} }
},[groupDetail]) },[groupDetail,allProjects])
let statisticOnline = (groupId) => { let statisticOnline = (groupId) => {
dispatch(actions.projectGroup.groupStatisticOnline({ groupId })).then(res => { dispatch(actions.projectGroup.groupStatisticOnline({ groupId })).then(res => {
@ -502,12 +506,16 @@ console.log('xxx1',actions)
} }
function mapStateToProps (state) { function mapStateToProps (state) {
const { auth, global, groupStatisticOnline } = state;
const { auth, global, groupStatisticOnline,pomsProjectBasicAll } = state;
console.log('global1',global)
return { return {
user: auth.user, user: auth.user,
actions: global.actions, actions: global.actions,
clientHeight: global.clientHeight, clientHeight: global.clientHeight,
groupStatisticOnline: groupStatisticOnline?.data groupStatisticOnline: groupStatisticOnline?.data,
pomsProjectBasicAll: pomsProjectBasicAll.data || [],
}; };
} }

Loading…
Cancel
Save