Browse Source

feat:待办工单

dev
zhaobing’ 1 year ago
parent
commit
65a7c59cde
  1. 8
      api/.vscode/launch.json
  2. 62
      api/app/lib/controllers/form/index.js
  3. 2
      api/app/lib/index.js
  4. 58
      api/config.js
  5. 3
      web/client/src/layout/actions/index.js
  6. 15
      web/client/src/layout/actions/workOrders.js
  7. 15
      web/client/src/layout/components/header/index.jsx
  8. 13
      web/client/src/sections/workOrder/containers/aboutMe.jsx
  9. 14
      web/client/src/sections/workOrder/containers/initiated.jsx
  10. 13
      web/client/src/sections/workOrder/containers/preserve.jsx
  11. 13
      web/client/src/sections/workOrder/containers/receipt.jsx
  12. 13
      web/client/src/sections/workOrder/containers/stayDoWorkOrder.jsx
  13. 2
      web/client/src/utils/webapi.js

8
api/.vscode/launch.json

@ -24,8 +24,8 @@
"-g postgres://FashionAdmin:123456@10.8.30.166:5432/POMS", "-g postgres://FashionAdmin:123456@10.8.30.166:5432/POMS",
"-k 10.8.30.72:29092,10.8.30.73:29092,10.8.30.74:29092", "-k 10.8.30.72:29092,10.8.30.73:29092,10.8.30.74:29092",
"-e http://10.8.30.60:9200", "-e http://10.8.30.60:9200",
// "-c https://camundatest.anxinyun.cn", "-c https://camundatest.anxinyun.cn",
// "-r fs-workflow", "-r fs-workflow",
// "-e http://10.8.30.60:5601", // "-e http://10.8.30.60:5601",
"--iotaProxy http://10.8.30.157:17007", "--iotaProxy http://10.8.30.157:17007",
// //
@ -40,8 +40,8 @@
// //
// "--apiEmisUrl http://10.8.30.161:1111", // "--apiEmisUrl http://10.8.30.161:1111",
// "--apiEmisUrl http://10.8.30.161:31111/", // "--apiEmisUrl http://10.8.30.161:31111/",
"--apiEmisUrl https://pepca-demo.anxinyun.cn/_api", // "--apiEmisUrl https://pepca-demo.anxinyun.cn/_api",
// "--apiEmisUrl http://localhost:14000", "--apiEmisUrl http://localhost:14000",
"--apiVcmpUrl http://localhost:4000", "--apiVcmpUrl http://localhost:4000",
"--apiIotAuth http://localhost:4200", "--apiIotAuth http://localhost:4200",
"--godUrl https://restapi.amap.com/v3", "--godUrl https://restapi.amap.com/v3",

62
api/app/lib/controllers/form/index.js

@ -11,41 +11,41 @@ async function getUnfinished (ctx) {
const assignee='fsUser'+userInfo.pepUserId const assignee='fsUser'+userInfo.pepUserId
const BeforeAssignUser='fsBeforeAssignUser'+userInfo.pepUserId const BeforeAssignUser='fsBeforeAssignUser'+userInfo.pepUserId
const AfterAssignUser='fsAfterAssignUser'+userInfo.pepUserId const AfterAssignUser='fsAfterAssignUser'+userInfo.pepUserId
// and pro.business_key_ in ('831')
// and pro.business_key_ in ('840','834','831') 测试环境的对应的business_key_(运维中台技术申请工单),(运维中台售后问题处理工单),(运维中台工单)
try{ try{
let all=await clickHouse.camWorkflow.query(` let all=await clickHouse.camWorkflow.query(`
SELECT DISTINCT * select distinct * from(
FROM ( select * from (
SELECT * select distinct RES.*
FROM ( from act_hi_taskinst RES,act_hi_procinst pro
SELECT DISTINCT RES.* WHERE RES.end_time_ is null
FROM act_hi_taskinst RES, act_hi_procinst PRO and RES.assignee_ = '${assignee}'
WHERE 1 = 1 and pro.proc_inst_id_=RES.proc_inst_id_
AND RES.end_time_ IS NULL and pro.business_key_ in ('840','834','831')
AND 1 = 1
AND RES.assignee_ = '${assignee}'
AND RES.proc_inst_id_ = PRO.proc_inst_id_
AND PRO.business_key_ in ('160','159')
) RES ) RES
UNION ALL union all
SELECT * select * from (
FROM ( select distinct RES.*
SELECT DISTINCT RES.* from act_hi_taskinst RES, act_hi_varinst VAR,act_hi_procinst pro
FROM act_hi_taskinst RES WHERE RES.end_time_ is null
WHERE 1 = 1 and VAR.name_ in ('${AfterAssignUser}', '${BeforeAssignUser}')
AND RES.end_time_ IS NULL and VAR.task_id_ = RES.id_
AND 1 = 1 and pro.proc_inst_id_=RES.proc_inst_id_
AND RES.id_ IN ( and pro.business_key_ in ('840','834','831')
SELECT id_ and (( VAR.var_type_ is not null and VAR.var_type_ = 'string' and VAR.text_ is not null and VAR.text_ = 'pending' ))
FROM act_hi_varinst VAR ) RES ) as res,act_hi_varinst t
WHERE name_ IN ('${BeforeAssignUser}','${AfterAssignUser}')
AND var_type_ IS NOT NULL where
AND var_type_ = 'string' t.proc_inst_id_=res.proc_inst_id_
AND text_ IS NOT NULL and t.name_='backout'
AND text_ = 'pending' and t.task_id_ is null
) and t.var_type_ is not null
) RES and t.var_type_='boolean'
) AS res; and t.long_ is not null
and t.long_=0
`).toPromise() `).toPromise()
const procinstIds = [...new Set(all.map(e => e.proc_inst_id_))]; const procinstIds = [...new Set(all.map(e => e.proc_inst_id_))];
// 获取流程实例变量 // 获取流程实例变量

2
api/app/lib/index.js

@ -49,7 +49,7 @@ module.exports.entry = function (app, router, opts) {
// 鉴权中间件 // 鉴权中间件
router.use(authenticator(app, opts)); router.use(authenticator(app, opts));
//camundarest //camundarest
// router.use(camundarest(app, router, opts.camundarest)); router.use(camundarest(app, router, opts.camundarest));
// 日志记录 // 日志记录
// router.use(apiLog(app, opts)); // router.use(apiLog(app, opts));

58
api/config.js

@ -13,8 +13,8 @@ args.option(['g', 'pg'], 'postgre 服务 URL');
args.option(['f', 'fileHost'], '文件中心本地化存储: WebApi 服务器地址(必填), 该服务器提供文件上传Web服务'); args.option(['f', 'fileHost'], '文件中心本地化存储: WebApi 服务器地址(必填), 该服务器提供文件上传Web服务');
args.option(['k', 'kafka'], 'kafka 服务 URL'); args.option(['k', 'kafka'], 'kafka 服务 URL');
args.option(['e', 'es'], 'es 服务 URL'); args.option(['e', 'es'], 'es 服务 URL');
// args.option(['c', 'camundaHost'], 'camunda rest host'); args.option(['c', 'camundaHost'], 'camunda rest host');
// args.option(['r', 'camundaRoot'], 'camunda rest root'); args.option(['r', 'camundaRoot'], 'camunda rest root');
args.option('iotaProxy', '以太代理') args.option('iotaProxy', '以太代理')
args.option('redisHost', 'redisHost'); args.option('redisHost', 'redisHost');
@ -66,8 +66,8 @@ const flags = args.parse(process.argv);
const POMS_DB = process.env.POMS_DB || flags.pg; const POMS_DB = process.env.POMS_DB || flags.pg;
const LOCAL_SVR_ORIGIN = process.env.LOCAL_SVR_ORIGIN || flags.fileHost; const LOCAL_SVR_ORIGIN = process.env.LOCAL_SVR_ORIGIN || flags.fileHost;
//项企 //项企
// const FS_CAMUNDA_HOST = process.env.CAMUNDA_HOST || flags.camundaHost; const FS_CAMUNDA_HOST = process.env.CAMUNDA_HOST || flags.camundaHost;
// const FS_CAMUNDA_ROOT = process.env.CAMUNDA_ROOT || flags.camundaRoot; const FS_CAMUNDA_ROOT = process.env.CAMUNDA_ROOT || flags.camundaRoot;
// kafka // kafka
const ANXINCLOUD_KAFKA_BROKERS = process.env.ANXINCLOUD_KAFKA_BROKERS || flags.kafka; const ANXINCLOUD_KAFKA_BROKERS = process.env.ANXINCLOUD_KAFKA_BROKERS || flags.kafka;
@ -135,24 +135,28 @@ const ES_PLATFORM_NAME = process.env.ES_PLATFORM_NAME || flags.esPlatformName
|| 'anxinyun'; || 'anxinyun';
const ANXINCLOUD_ES_NODES_REST = process.env.ANXINCLOUD_ES_NODES_REST || flags.es; const ANXINCLOUD_ES_NODES_REST = process.env.ANXINCLOUD_ES_NODES_REST || flags.es;
// //business_key // //business_key
// const BUSINESS_KEY=process.env.BUSINESS_KEY||['160','161'] // const BUSINESS_KEY=process.env.BUSINESS_KEY||['834','840']
if (
const requireParams = { // !BUSINESS_KEY||
// FS_CAMUNDA_HOST, FS_CAMUNDA_ROOT, !FS_CAMUNDA_HOST || !FS_CAMUNDA_ROOT ||
POMS_DB, !POMS_DB
IOTA_REDIS_SERVER_HOST, IOTA_REDIS_SERVER_PORT, || !IOTA_REDIS_SERVER_HOST || !IOTA_REDIS_SERVER_PORT
ANXINCLOUD_KAFKA_BROKERS, || !ANXINCLOUD_KAFKA_BROKERS
GOD_KEY, || !GOD_KEY
API_ANXINYUN_URL, || !API_ANXINYUN_URL
API_EMIS_URL, || !API_EMIS_URL
API_VCMP_URL, || !API_VCMP_URL
API_IOT_AUTH, || !API_IOT_AUTH
QINIU_DOMAIN_QNDMN_RESOURCE, QINIU_BUCKET_RESOURCE, QINIU_AK, QINIU_SK, || !QINIU_DOMAIN_QNDMN_RESOURCE || !QINIU_BUCKET_RESOURCE || !QINIU_AK || !QINIU_SK
CLICKHOUST_URL, CLICKHOUST_PORT, || !CLICKHOUST_URL || !CLICKHOUST_PORT
CLICKHOUST_ANXINCLOUD, CLICKHOUST_PEP_EMIS, CLICKHOUST_PROJECT_MANAGE, CLICKHOUST_VCMP, CLICKHOUST_DATA_ALARM, CLICKHOUST_IOT, || !CLICKHOUST_ANXINCLOUD || !CLICKHOUST_PEP_EMIS || !CLICKHOUST_PROJECT_MANAGE || !CLICKHOUST_VCMP || !CLICKHOUST_DATA_ALARM || !CLICKHOUST_IOT
// CLICKHOUST_CAM_WORKFLOW, // || !CLICKHOUST_CAM_WORKFLOW
CONFIRM_ALARM_ANXIN_USER_ID, || !CONFIRM_ALARM_ANXIN_USER_ID
VCMP_APP_ID, VCMP_APP_SECRET, || !VCMP_APP_ID || !VCMP_APP_SECRET
) {
console.log('缺少启动参数,异常退出');
args.showHelp();
process.exit(-1);
} }
Object.keys(requireParams).forEach(key => { Object.keys(requireParams).forEach(key => {
@ -182,11 +186,11 @@ const product = {
entry: require('./app').entry, entry: require('./app').entry,
opts: { opts: {
dev, dev,
// BUSINESS_KEY, // business_key:BUSINESS_KEY,
// camundarest: { camundarest: {
// host: FS_CAMUNDA_HOST, host: FS_CAMUNDA_HOST,
// root: FS_CAMUNDA_ROOT root: FS_CAMUNDA_ROOT
// }, },
exclude: [ exclude: [
// "*", // "*",
{ p: '/attachments/:p', o: 'POST' }, { p: '/attachments/:p', o: 'POST' },

3
web/client/src/layout/actions/index.js

@ -2,8 +2,9 @@
import * as global from './global' import * as global from './global'
import * as socket from './webSocket'; import * as socket from './webSocket';
import * as workOrders from './workOrders'
export default { export default {
...global, ...global,
...socket, ...socket,
...workOrders
}; };

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

@ -0,0 +1,15 @@
'use strict';
import { ApiTable, basicAction } from '$utils'
export function getWorkOrders () { //获取工单的待办
console.log('xxxxx',ApiTable.workOrders)
return dispatch => basicAction({
type: 'get',
dispatch: dispatch,
actionType: 'GET_WORK_ORDERS',
url: `${ApiTable.workOrders}`,
msg: { option: '获取工单的待办' },
reducer: { name: 'workOrders' }
});
}

15
web/client/src/layout/components/header/index.jsx

@ -8,11 +8,12 @@ import { IconTreeTriangleDown, IconSearch, IconEdit, IconDelete } from '@douyinf
import CustomProjGroupModal from './components/customProjGroupModal' import CustomProjGroupModal from './components/customProjGroupModal'
import PerfectScrollbar from "perfect-scrollbar"; import PerfectScrollbar from "perfect-scrollbar";
import "./index.less"; import "./index.less";
import layout from '../../containers/layout';
let newScrollbar; let newScrollbar;
const Header = (props) => { const Header = (props) => {
const { dispatch, history, user, actions, socket, headerItems, tochange, projectGroup } = props; const { dispatch, history, user, actions, socket, headerItems, tochange, projectGroup } = props;
const { install, projectGroup: projectGroupAC } = actions const { install, projectGroup: projectGroupAC,layout } = actions
const [pomsList, setPomsList] = useState([]) const [pomsList, setPomsList] = useState([])
const [pomsName, setPomsName] = useState('全局') const [pomsName, setPomsName] = useState('全局')
const [pepProjectId, setPepProjectId] = useState() const [pepProjectId, setPepProjectId] = useState()
@ -23,6 +24,8 @@ const Header = (props) => {
const [customProjGroupModalVis, setCustomProjGroupModalVis] = useState(false) const [customProjGroupModalVis, setCustomProjGroupModalVis] = useState(false)
const [customProjGroupDelPopVis, setCustomProjGroupDelPopVis] = useState(false) const [customProjGroupDelPopVis, setCustomProjGroupDelPopVis] = useState(false)
const [customProjGroupEditData, setCustomProjGroupEditData] = useState(null) const [customProjGroupEditData, setCustomProjGroupEditData] = useState(null)
const [count,setCount]=useState(0)//
// console.log('actions1',actions)
let userRole = user?.pomsUserInfo?.role let userRole = user?.pomsUserInfo?.role
let modalRole = [] let modalRole = []
if (userRole) { if (userRole) {
@ -52,7 +55,14 @@ const Header = (props) => {
} }
}) })
getProjGroup() getProjGroup()
dispatch(layout.getWorkOrders()).then((res)=>{
if(res.success){
setCount(res.payload.data?.count)
} }
})
}
}, []) }, [])
useEffect(() => { useEffect(() => {
@ -287,8 +297,7 @@ const Header = (props) => {
<Nav.Sub <Nav.Sub
key={index + 'a'} key={index + 'a'}
itemKey={item.itemKey} itemKey={item.itemKey}
// text={item.text===''?`${item.text}${111}`:item.text} text={item.text==='工单'?`${item.text}${count}`:item.text}
text={item.text}
dropdownStyle={{ color: '#F2F3F5' }} dropdownStyle={{ color: '#F2F3F5' }}
> >
{item.hasOwnProperty('items') && item.items.map((ite, idx) => ( {item.hasOwnProperty('items') && item.items.map((ite, idx) => (

13
web/client/src/sections/workOrder/containers/aboutMe.jsx

@ -121,11 +121,18 @@ const Rest = (props) => {
return record?.pomsNeedData?.handlingPerson?.value ? allPepUsersIncludeDel.find(u => u.id == record?.pomsNeedData?.handlingPerson?.value)?.name : '' return record?.pomsNeedData?.handlingPerson?.value ? allPepUsersIncludeDel.find(u => u.id == record?.pomsNeedData?.handlingPerson?.value)?.name : ''
} }
}, },
// {
// title: '',
// dataIndex: 'handlingResult',
// render: (text, record, index) => {
// return record?.pomsNeedData?.handlingResult?.value || ''
// }
// },
{ {
title: '处理结果', title: '事项名称',
dataIndex: 'handlingResult', dataIndex: 'fsFormItemName',
render: (text, record, index) => { render: (text, record, index) => {
return record?.pomsNeedData?.handlingResult?.value || '' return record?.name || ''
} }
}, },
{ {

14
web/client/src/sections/workOrder/containers/initiated.jsx

@ -16,7 +16,6 @@ const Rest = (props) => {
const [workflowModalType, setWorkflowModalType] = useState('') const [workflowModalType, setWorkflowModalType] = useState('')
const [checkProcessInstanceId, setCheckProcessInstanceId] = useState(null) const [checkProcessInstanceId, setCheckProcessInstanceId] = useState(null)
const [params, setParams] = useState({}) const [params, setParams] = useState({})
useEffect(() => { useEffect(() => {
backlogData() backlogData()
if (!pomsProjectBasicAll.length) { if (!pomsProjectBasicAll.length) {
@ -112,11 +111,18 @@ const Rest = (props) => {
return record?.pomsNeedData?.handlingPerson?.value ? allPepUsersIncludeDel.find(u => u.id == record?.pomsNeedData?.handlingPerson?.value)?.name : '' return record?.pomsNeedData?.handlingPerson?.value ? allPepUsersIncludeDel.find(u => u.id == record?.pomsNeedData?.handlingPerson?.value)?.name : ''
} }
}, },
// {
// title: '',
// dataIndex: 'handlingResult',
// render: (text, record, index) => {
// return record?.pomsNeedData?.handlingResult?.value || ''
// }
// },
{ {
title: '处理结果', title: '事项名称',
dataIndex: 'handlingResult', dataIndex: 'fsFormItemName',
render: (text, record, index) => { render: (text, record, index) => {
return record?.pomsNeedData?.handlingResult?.value || '' return record?.name || ''
} }
}, },
{ {

13
web/client/src/sections/workOrder/containers/preserve.jsx

@ -113,11 +113,18 @@ const Rest = (props) => {
return record?.pomsNeedData?.handlingPerson?.value ? allPepUsersIncludeDel.find(u => u.id == record?.pomsNeedData?.handlingPerson?.value)?.name : '' return record?.pomsNeedData?.handlingPerson?.value ? allPepUsersIncludeDel.find(u => u.id == record?.pomsNeedData?.handlingPerson?.value)?.name : ''
} }
}, },
// {
// title: '',
// dataIndex: 'handlingResult',
// render: (text, record, index) => {
// return record?.pomsNeedData?.handlingResult?.value || ''
// }
// },
{ {
title: '处理结果', title: '事项名称',
dataIndex: 'handlingResult', dataIndex: 'fsFormItemName',
render: (text, record, index) => { render: (text, record, index) => {
return record?.pomsNeedData?.handlingResult?.value || '' return record?.name || ''
} }
}, },
{ {

13
web/client/src/sections/workOrder/containers/receipt.jsx

@ -123,11 +123,18 @@ const Rest = (props) => {
return record?.pomsNeedData?.handlingPerson?.value ? allPepUsersIncludeDel.find(u => u.id == record?.pomsNeedData?.handlingPerson?.value)?.name : '' return record?.pomsNeedData?.handlingPerson?.value ? allPepUsersIncludeDel.find(u => u.id == record?.pomsNeedData?.handlingPerson?.value)?.name : ''
} }
}, },
// {
// title: '',
// dataIndex: 'handlingResult',
// render: (text, record, index) => {
// return record?.pomsNeedData?.handlingResult?.value || ''
// }
// },
{ {
title: '处理结果', title: '事项名称',
dataIndex: 'handlingResult', dataIndex: 'fsFormItemName',
render: (text, record, index) => { render: (text, record, index) => {
return record?.pomsNeedData?.handlingResult?.value || '' return record?.name || ''
} }
}, },
{ {

13
web/client/src/sections/workOrder/containers/stayDoWorkOrder.jsx

@ -106,11 +106,18 @@ const Rest = (props) => {
return record?.pomsNeedData?.handlingPerson?.value ? allPepUsersIncludeDel.find(u => u.id == record?.pomsNeedData?.handlingPerson?.value)?.name : '' return record?.pomsNeedData?.handlingPerson?.value ? allPepUsersIncludeDel.find(u => u.id == record?.pomsNeedData?.handlingPerson?.value)?.name : ''
} }
}, },
// {
// title: '',
// dataIndex: 'handlingResult',
// render: (text, record, index) => {
// return record?.pomsNeedData?.handlingResult?.value || ''
// }
// },
{ {
title: '处理结果', title: '事项名称',
dataIndex: 'handlingResult', dataIndex: 'fsFormItemName',
render: (text, record, index) => { render: (text, record, index) => {
return record?.pomsNeedData?.handlingResult?.value || '' return record?.fsFormItemName || ''
} }
}, },
{ {

2
web/client/src/utils/webapi.js

@ -143,6 +143,8 @@ export const ApiTable = {
respondRecord: 'respond-record', respondRecord: 'respond-record',
//待办工单
workOrders:'unfinished'
}; };
// 项企的接口 // 项企的接口

Loading…
Cancel
Save