Skip to content

Commit 1e161d2

Browse files
committed
Merge remote-tracking branch 'upstream/feature/bpm' into feature/bpm
2 parents 59281a7 + 6f724d9 commit 1e161d2

File tree

6 files changed

+76
-80
lines changed

6 files changed

+76
-80
lines changed

src/components/SimpleProcessDesignerV2/src/nodes-config/ConditionNodeConfig.vue

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -381,7 +381,7 @@ const fieldOptions = computed(() => {
381381
382382
/** 获取字段名称 */
383383
const getFieldTitle = (field: string) => {
384-
const item = fieldsInfo.find((item) => item.field === field)
384+
const item = fieldOptions.value.find((item) => item.field === field)
385385
return item?.title
386386
}
387387

src/components/SimpleProcessDesignerV2/theme/simple-process-designer.scss

Lines changed: 6 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -173,13 +173,16 @@
173173
height: 100%;
174174
padding-top: 32px;
175175
background-color: #fafafa;
176+
overflow-x: auto;
177+
width: 100%;
178+
176179
.simple-process-model {
177180
display: flex;
178181
flex-direction: column;
179182
justify-content: center;
180183
align-items: center;
181184
transform-origin: 50% 0 0;
182-
overflow: auto;
185+
min-width: fit-content;
183186
transform: scale(1);
184187
transition: transform 0.3s cubic-bezier(0.645, 0.045, 0.355, 1);
185188
background: url(@/assets/svgs/bpm/simple-process-bg.svg) 0 0 repeat;
@@ -473,6 +476,7 @@
473476
.branch-node-container {
474477
position: relative;
475478
display: flex;
479+
min-width: fit-content;
476480

477481
&::before {
478482
position: absolute;
@@ -548,6 +552,7 @@
548552
background: transparent;
549553
border-top: 2px solid #dedede;
550554
border-bottom: 2px solid #dedede;
555+
flex-shrink: 0;
551556

552557
&::before {
553558
position: absolute;

src/components/bpmnProcessDesigner/package/designer/ProcessDesigner.vue

Lines changed: 19 additions & 64 deletions
Original file line numberDiff line numberDiff line change
@@ -309,18 +309,26 @@ const props = defineProps({
309309
})
310310
311311
// 监听value变化,重新加载流程图
312-
watch(() => props.value, (newValue) => {
313-
if (newValue && bpmnModeler) {
314-
createNewDiagram(newValue)
315-
}
316-
}, { immediate: true })
312+
watch(
313+
() => props.value,
314+
(newValue) => {
315+
if (newValue && bpmnModeler) {
316+
createNewDiagram(newValue)
317+
}
318+
},
319+
{ immediate: true }
320+
)
317321
318322
// 监听processId和processName变化
319-
watch([() => props.processId, () => props.processName], ([newId, newName]) => {
320-
if (newId && newName && !props.value) {
321-
createNewDiagram(null)
322-
}
323-
}, { immediate: true })
323+
watch(
324+
[() => props.processId, () => props.processName],
325+
([newId, newName]) => {
326+
if (newId && newName && !props.value) {
327+
createNewDiagram(null)
328+
}
329+
},
330+
{ immediate: true }
331+
)
324332
325333
provide('configGlobal', props)
326334
let bpmnModeler: any = null
@@ -599,16 +607,6 @@ const processZoomOut = (zoomStep = 0.1) => {
599607
defaultZoom.value = newZoom
600608
bpmnModeler.get('canvas').zoom(defaultZoom.value)
601609
}
602-
// const processZoomTo = (newZoom = 1) => {
603-
// if (newZoom < 0.2) {
604-
// throw new Error('[Process Designer Warn ]: The zoom ratio cannot be less than 0.2')
605-
// }
606-
// if (newZoom > 4) {
607-
// throw new Error('[Process Designer Warn ]: The zoom ratio cannot be greater than 4')
608-
// }
609-
// defaultZoom = newZoom
610-
// bpmnModeler.get('canvas').zoom(newZoom)
611-
// }
612610
const processReZoom = () => {
613611
defaultZoom.value = 1
614612
bpmnModeler.get('canvas').zoom('fit-viewport', 'auto')
@@ -647,62 +645,19 @@ const previewProcessXML = () => {
647645
}
648646
const previewProcessJson = () => {
649647
bpmnModeler.saveXML({ format: true }).then(({ xml }) => {
650-
// console.log(xml, 'xml')
651-
652-
// const rootNode = parseXmlString(xml)
653-
// console.log(rootNode, 'rootNoderootNode')
654648
const rootNodes = new XmlNode(XmlNodeType.Root, parseXmlString(xml))
655-
// console.log(rootNodes, 'rootNodesrootNodesrootNodes')
656-
// console.log(rootNodes.parent.toJsObject(), 'rootNodes.toJSON()')
657-
// console.log(JSON.stringify(rootNodes.parent.toJsObject()), 'rootNodes.toJSON()')
658-
// console.log(JSON.stringify(rootNodes.parent.toJSON()), 'rootNodes.toJSON()')
659-
660-
// const parser = new xml2js.XMLParser()
661-
// let jObj = parser.parse(xml)
662-
// console.log(jObj, 'jObjjObjjObjjObjjObj')
663-
// const builder = new xml2js.XMLBuilder(xml)
664-
// const xmlContent = builder
665-
// console.log(xmlContent, 'xmlContent')
666-
// console.log(xml2js, 'convertconvertconvert')
667649
previewResult.value = rootNodes.parent?.toJSON() as unknown as string
668-
// previewResult.value = jObj
669-
// previewResult.value = convert.xml2json(xml, {explicitArray : false},{ spaces: 2 })
670650
previewType.value = 'json'
671651
previewModelVisible.value = true
672652
})
673653
}
654+
674655
/* ------------------------------------------------ 芋道源码 methods ------------------------------------------------------ */
675-
const processSave = async () => {
676-
try {
677-
const { err, xml } = await bpmnModeler.saveXML()
678-
if (err) {
679-
ElMessage.error('保存流程设计失败,请重试!')
680-
return
681-
}
682-
emit('save', xml)
683-
} catch (error) {
684-
console.error(error)
685-
ElMessage.error('保存流程设计失败,请重试!')
686-
}
687-
}
688-
/** 高亮显示 */
689-
// const highlightedCode = (previewType, previewResult) => {
690-
// console.log(previewType, 'previewType, previewResult')
691-
// console.log(previewResult, 'previewType, previewResult')
692-
// console.log(hljs.highlight, 'hljs.highlight')
693-
// const result = hljs.highlight(previewType, previewResult.value || '', true)
694-
// return result.value || '&nbsp;'
695-
// }
696-
onBeforeMount(() => {
697-
console.log(props, 'propspropspropsprops')
698-
})
699656
onMounted(() => {
700657
initBpmnModeler()
701658
createNewDiagram(props.value)
702659
})
703660
onBeforeUnmount(() => {
704-
// this.$once('hook:beforeDestroy', () => {
705-
// })
706661
if (bpmnModeler) bpmnModeler.destroy()
707662
emit('destroy', bpmnModeler)
708663
bpmnModeler = null

src/views/bpm/model/editor/index.vue

Lines changed: 3 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -221,7 +221,7 @@ onBeforeUnmount(() => {
221221
}
222222
})
223223
224-
/** 获取XML字符串 */
224+
/** 获取 XML 字符串 */
225225
const saveXML = async () => {
226226
if (!modeler.value) {
227227
return { xml: xmlString.value }
@@ -273,7 +273,7 @@ defineExpose({
273273
<style lang="scss">
274274
.process-panel__container {
275275
position: absolute;
276-
top: 180px;
277-
right: 60px;
276+
top: 172px;
277+
right: 70px;
278278
}
279279
</style>

src/views/bpm/model/form/index.vue

Lines changed: 7 additions & 8 deletions
Original file line numberDiff line numberDiff line change
@@ -79,14 +79,14 @@
7979
</template>
8080

8181
<script lang="ts" setup>
82-
import { useRouter, useRoute } from 'vue-router'
82+
import { useRoute, useRouter } from 'vue-router'
8383
import { useMessage } from '@/hooks/web/useMessage'
8484
import * as ModelApi from '@/api/bpm/model'
8585
import * as FormApi from '@/api/bpm/form'
8686
import { CategoryApi } from '@/api/bpm/category'
8787
import * as UserApi from '@/api/system/user'
8888
import { useUserStoreWithOut } from '@/store/modules/user'
89-
import { BpmModelType, BpmModelFormType } from '@/utils/constants'
89+
import { BpmModelFormType, BpmModelType } from '@/utils/constants'
9090
import BasicInfo from './BasicInfo.vue'
9191
import FormDesign from './FormDesign.vue'
9292
import ProcessDesign from './ProcessDesign.vue'
@@ -108,16 +108,17 @@ const validateBasic = async () => {
108108
await basicInfoRef.value?.validate()
109109
}
110110
111+
/** 表单设计校验 */
111112
const validateForm = async () => {
112113
await formDesignRef.value?.validate()
113114
}
114115
116+
/** 流程设计校验 */
115117
const validateProcess = async () => {
116118
await processDesignRef.value?.validate()
117119
}
118120
119-
// 步骤控制
120-
const currentStep = ref(0)
121+
const currentStep = ref(0) // 步骤控制
121122
const steps = [
122123
{ title: '基本信息', validator: validateBasic },
123124
{ title: '表单设计', validator: validateForm },
@@ -255,7 +256,6 @@ const handleSave = async () => {
255256
if (formData.value.id) {
256257
// 修改场景
257258
await ModelApi.updateModel(modelData)
258-
message.success('修改成功')
259259
// 询问是否发布流程
260260
try {
261261
await message.confirm('修改流程成功,是否发布流程?')
@@ -266,8 +266,7 @@ const handleSave = async () => {
266266
}
267267
} else {
268268
// 新增场景
269-
const result = await ModelApi.createModel(modelData)
270-
formData.value.id = result
269+
formData.value.id = await ModelApi.createModel(modelData)
271270
message.success('新增成功')
272271
try {
273272
await message.confirm('创建流程成功,是否继续编辑?')
@@ -335,7 +334,7 @@ const handleDeploy = async () => {
335334
await ModelApi.deployModel(formData.value.id)
336335
message.success('发布成功')
337336
// 返回列表页
338-
router.push({ name: 'BpmModel' })
337+
await router.push({ name: 'BpmModel' })
339338
} catch (error: any) {
340339
console.error('发布失败:', error)
341340
message.warning(error.message || '发布失败')

src/views/bpm/processInstance/create/ProcessDefinitionDetail.vue

Lines changed: 40 additions & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -8,7 +8,7 @@
88
<!-- 中间主要内容 tab 栏 -->
99
<el-tabs v-model="activeTab">
1010
<!-- 表单信息 -->
11-
<el-tab-pane label="表单填写" name="form" >
11+
<el-tab-pane label="表单填写" name="form">
1212
<div class="form-scroll-area" v-loading="processInstanceStartLoading">
1313
<el-scrollbar>
1414
<el-row>
@@ -75,7 +75,11 @@
7575
<script lang="ts" setup>
7676
import { decodeFields, setConfAndFields2 } from '@/utils/formCreate'
7777
import { BpmModelType } from '@/utils/constants'
78-
import { CandidateStrategy } from '@/components/SimpleProcessDesignerV2/src/consts'
78+
import {
79+
CandidateStrategy,
80+
NodeId,
81+
FieldPermissionType
82+
} from '@/components/SimpleProcessDesignerV2/src/consts'
7983
import ProcessInstanceBpmnViewer from '../detail/ProcessInstanceBpmnViewer.vue'
8084
import ProcessInstanceSimpleViewer from '../detail/ProcessInstanceSimpleViewer.vue'
8185
import ProcessInstanceTimeline from '../detail/ProcessInstanceTimeline.vue'
@@ -129,8 +133,10 @@ const initProcessInfo = async (row: any, formVariables?: any) => {
129133
}
130134
}
131135
setConfAndFields2(detailForm, row.formConf, row.formFields, formVariables)
136+
132137
await nextTick()
133138
fApi.value?.btn.show(false) // 隐藏提交按钮
139+
134140
// 获取流程审批信息
135141
await getApprovalDetail(row)
136142
@@ -152,7 +158,12 @@ const initProcessInfo = async (row: any, formVariables?: any) => {
152158
/** 获取审批详情 */
153159
const getApprovalDetail = async (row: any) => {
154160
try {
155-
const data = await ProcessInstanceApi.getApprovalDetail({ processDefinitionId: row.id })
161+
// TODO 获取审批详情,设置 activityId 为发起人节点(为了获取字段权限。暂时只对 Simple 设计器有效)
162+
const data = await ProcessInstanceApi.getApprovalDetail({
163+
processDefinitionId: row.id,
164+
activityId: NodeId.START_USER_NODE_ID
165+
})
166+
156167
if (!data) {
157168
message.error('查询不到审批详情信息!')
158169
return
@@ -170,10 +181,36 @@ const getApprovalDetail = async (row: any) => {
170181
171182
// 获取审批节点,显示 Timeline 的数据
172183
activityNodes.value = data.activityNodes
184+
// 获取表单字段权限
185+
const formFieldsPermission = data.formFieldsPermission
186+
// 设置表单字段权限
187+
if (formFieldsPermission) {
188+
Object.keys(formFieldsPermission).forEach((item) => {
189+
setFieldPermission(item, formFieldsPermission[item])
190+
})
191+
}
173192
} finally {
174193
}
175194
}
176195
196+
/**
197+
* 设置表单权限
198+
*/
199+
const setFieldPermission = (field: string, permission: string) => {
200+
if (permission === FieldPermissionType.READ) {
201+
//@ts-ignore
202+
fApi.value?.disabled(true, field)
203+
}
204+
if (permission === FieldPermissionType.WRITE) {
205+
//@ts-ignore
206+
fApi.value?.disabled(false, field)
207+
}
208+
if (permission === FieldPermissionType.NONE) {
209+
//@ts-ignore
210+
fApi.value?.hidden(true, field)
211+
}
212+
}
213+
177214
/** 提交按钮 */
178215
const submitForm = async () => {
179216
if (!fApi.value || !props.selectProcessDefinition) {

0 commit comments

Comments
 (0)