2025-03-11 09:37:15 +08:00
|
|
|
|
<template>
|
|
|
|
|
|
<div ref="formWrap">
|
|
|
|
|
|
<Form ref="formRef" :label-col="getProps?.labelCol" :labelAlign="getProps?.labelAlign"
|
|
|
|
|
|
:layout="getProps?.layout" :model="formModel" :wrapper-col="getProps?.wrapperCol"
|
|
|
|
|
|
@keypress.enter="handleEnterPress">
|
|
|
|
|
|
<!-- id -->
|
|
|
|
|
|
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('e21c39e056964ba1af0207c8dfa7b54b')"
|
|
|
|
|
|
v-show="getIsShow2('e21c39e056964ba1af0207c8dfa7b54b')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['e21c39e056964ba1af0207c8dfa7b54b'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['e21c39e056964ba1af0207c8dfa7b54b'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['e21c39e056964ba1af0207c8dfa7b54b'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['e21c39e056964ba1af0207c8dfa7b54b']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
<!-- 节点名称 -->
|
|
|
|
|
|
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('a7f8acb0021c4df09452039b01ec313d')"
|
|
|
|
|
|
v-show="getIsShow2('a7f8acb0021c4df09452039b01ec313d')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['a7f8acb0021c4df09452039b01ec313d'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['a7f8acb0021c4df09452039b01ec313d'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['a7f8acb0021c4df09452039b01ec313d'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['a7f8acb0021c4df09452039b01ec313d']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
<!-- 流程名称 -->
|
|
|
|
|
|
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('7107f6f6ef594c6687b9087e7f823c4d')"
|
|
|
|
|
|
v-show="getIsShow2('7107f6f6ef594c6687b9087e7f823c4d')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['7107f6f6ef594c6687b9087e7f823c4d'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['7107f6f6ef594c6687b9087e7f823c4d'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['7107f6f6ef594c6687b9087e7f823c4d'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['7107f6f6ef594c6687b9087e7f823c4d']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
<!-- 流程默认id -->
|
|
|
|
|
|
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('76db839377a7417f87d9d7540dd1f5f4')"
|
|
|
|
|
|
v-show="getIsShow2('76db839377a7417f87d9d7540dd1f5f4')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['76db839377a7417f87d9d7540dd1f5f4'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['76db839377a7417f87d9d7540dd1f5f4'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['76db839377a7417f87d9d7540dd1f5f4'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['76db839377a7417f87d9d7540dd1f5f4']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
<!-- 根节点实例id -->
|
|
|
|
|
|
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('11acfec9f51b4a45a390840acd00b077')"
|
|
|
|
|
|
v-show="getIsShow2('11acfec9f51b4a45a390840acd00b077')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['11acfec9f51b4a45a390840acd00b077'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['11acfec9f51b4a45a390840acd00b077'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['11acfec9f51b4a45a390840acd00b077'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['11acfec9f51b4a45a390840acd00b077']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
<!-- 流程实例id -->
|
|
|
|
|
|
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('31d294d5c7c845f88d1176ab5a4913e0')"
|
|
|
|
|
|
v-show="getIsShow2('31d294d5c7c845f88d1176ab5a4913e0')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['31d294d5c7c845f88d1176ab5a4913e0'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['31d294d5c7c845f88d1176ab5a4913e0'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['31d294d5c7c845f88d1176ab5a4913e0'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['31d294d5c7c845f88d1176ab5a4913e0']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
<!-- 执行节点id -->
|
|
|
|
|
|
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('f58327d6d3b04aad93eb415b3b8bfc60')"
|
|
|
|
|
|
v-show="getIsShow2('f58327d6d3b04aad93eb415b3b8bfc60')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['f58327d6d3b04aad93eb415b3b8bfc60'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['f58327d6d3b04aad93eb415b3b8bfc60'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['f58327d6d3b04aad93eb415b3b8bfc60'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['f58327d6d3b04aad93eb415b3b8bfc60']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
<!-- 节点实例id -->
|
|
|
|
|
|
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('c88aeae388c4488aa459e023cd1a35e8')"
|
|
|
|
|
|
v-show="getIsShow2('c88aeae388c4488aa459e023cd1a35e8')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['c88aeae388c4488aa459e023cd1a35e8'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['c88aeae388c4488aa459e023cd1a35e8'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['c88aeae388c4488aa459e023cd1a35e8'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['c88aeae388c4488aa459e023cd1a35e8']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
<!-- 节点名称 -->
|
|
|
|
|
|
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('e444605174364af2b10897b2987d2dec')"
|
|
|
|
|
|
v-show="getIsShow2('e444605174364af2b10897b2987d2dec')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['e444605174364af2b10897b2987d2dec'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['e444605174364af2b10897b2987d2dec'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['e444605174364af2b10897b2987d2dec'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['e444605174364af2b10897b2987d2dec']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
|
|
|
|
|
|
<!--任务id-->
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('e111605174364af2b10897b2987d2dec')"
|
|
|
|
|
|
v-show="getIsShow2('e111605174364af2b10897b2987d2dec')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['e111605174364af2b10897b2987d2dec'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['e111605174364af2b10897b2987d2dec'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['e111605174364af2b10897b2987d2dec'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['e111605174364af2b10897b2987d2dec']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
|
|
|
|
|
|
<!--任务名称-->
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('e444555174364af2b10897b2987d2dec')"
|
|
|
|
|
|
v-show="getIsShow2('e444555174364af2b10897b2987d2dec')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['e444555174364af2b10897b2987d2dec'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['e444555174364af2b10897b2987d2dec'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['e444555174364af2b10897b2987d2dec'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['e444555174364af2b10897b2987d2dec']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
|
|
|
|
|
|
<!--审核人-->
|
|
|
|
|
|
<!-- <Col v-if="getIfShow2('c33aeae997a4488aa459e023ae1a21e8')"
|
|
|
|
|
|
v-show="getIsShow2('c33aeae997a4488aa459e023ae1a21e8')"
|
|
|
|
|
|
:span="getColWidth(schemaMap['c33aeae997a4488aa459e023ae1a21e8'])">
|
|
|
|
|
|
<template v-if="showComponent(schemaMap['c33aeae997a4488aa459e023ae1a21e8'])">
|
|
|
|
|
|
<SimpleFormItem v-model:value="formModel[schemaMap['c33aeae997a4488aa459e023ae1a21e8'].field]"
|
|
|
|
|
|
:form-api="formApi" :isWorkFlow="isWorkFlow" :refreshFieldObj="refreshFieldObj"
|
|
|
|
|
|
:schema="schemaMap['c33aeae997a4488aa459e023ae1a21e8']" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
</Col> -->
|
|
|
|
|
|
|
|
|
|
|
|
<!--流程id-->
|
|
|
|
|
|
<div class="ant-col ant-col-24">
|
|
|
|
|
|
<div class="ant-row ant-form-item" style="row-gap: 0px;">
|
|
|
|
|
|
<div class="ant-col ant-form-item-label" style="width: 120px;">
|
|
|
|
|
|
<label>流程实列id</label>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-form-item-control">
|
|
|
|
|
|
<div class="ant-form-item-control-input">
|
|
|
|
|
|
<div class="ant-form-item-control-input-content">
|
|
|
|
|
|
<div class="field-readonly">
|
|
|
|
|
|
{{ assignee.value.processInstId }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-col-24">
|
|
|
|
|
|
<div class="ant-row ant-form-item" style="row-gap: 0px;">
|
|
|
|
|
|
<div class="ant-col ant-form-item-label" style="width: 120px;">
|
|
|
|
|
|
<label>子流程实例id</label>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-form-item-control">
|
|
|
|
|
|
<div class="ant-form-item-control-input">
|
|
|
|
|
|
<div class="ant-form-item-control-input-content">
|
|
|
|
|
|
<div class="field-readonly">
|
|
|
|
|
|
{{ assignee.value.subProcessInstId ? assignee.value.subProcessInstId : '无' }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-col-24">
|
|
|
|
|
|
<div class="ant-row ant-form-item" style="row-gap: 0px;">
|
|
|
|
|
|
<div class="ant-col ant-form-item-label" style="width: 120px;">
|
|
|
|
|
|
<label>子流程实例名</label>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-form-item-control">
|
|
|
|
|
|
<div class="ant-form-item-control-input">
|
|
|
|
|
|
<div class="ant-form-item-control-input-content">
|
|
|
|
|
|
<div class="field-readonly">
|
|
|
|
|
|
{{ assignee.value.subProcessInstName ? assignee.value.subProcessInstName : '无' }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<!--任务名称-->
|
|
|
|
|
|
<div class="ant-col ant-col-24">
|
|
|
|
|
|
<div class="ant-row ant-form-item" style="row-gap: 0px;">
|
|
|
|
|
|
<div class="ant-col ant-form-item-label" style="width: 120px;">
|
|
|
|
|
|
<label>节点key</label>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-form-item-control">
|
|
|
|
|
|
<div class="ant-form-item-control-input">
|
|
|
|
|
|
<div class="ant-form-item-control-input-content">
|
|
|
|
|
|
<div class="field-readonly">
|
|
|
|
|
|
{{ assignee.value.taskDefKey }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<!--任务id-->
|
|
|
|
|
|
<div class="ant-col ant-col-24">
|
|
|
|
|
|
<div class="ant-row ant-form-item" style="row-gap: 0px;">
|
|
|
|
|
|
<div class="ant-col ant-form-item-label" style="width: 120px;">
|
|
|
|
|
|
<label>节点id</label>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-form-item-control">
|
|
|
|
|
|
<div class="ant-form-item-control-input">
|
|
|
|
|
|
<div class="ant-form-item-control-input-content">
|
|
|
|
|
|
<div class="field-readonly">
|
|
|
|
|
|
{{ assignee.value.taskId }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-col-24">
|
|
|
|
|
|
<div class="ant-row ant-form-item" style="row-gap: 0px;">
|
|
|
|
|
|
<div class="ant-col ant-form-item-label" style="width: 120px;">
|
|
|
|
|
|
<label>节点名称</label>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-form-item-control">
|
|
|
|
|
|
<div class="ant-form-item-control-input">
|
|
|
|
|
|
<div class="ant-form-item-control-input-content">
|
|
|
|
|
|
<div class="field-readonly">
|
|
|
|
|
|
{{ assignee.value.taskName }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-form-item-control ant-col-12">
|
|
|
|
|
|
<a-button v-auth="'monitor:appointedAuditor'" @click="flowChange">{{
|
|
|
|
|
|
t('将任务流转到')
|
|
|
|
|
|
}}</a-button>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<!--审批人-->
|
|
|
|
|
|
<div class="ant-col ant-col-24">
|
|
|
|
|
|
<div class="ant-row ant-form-item" style="row-gap: 0px;">
|
|
|
|
|
|
<div class="ant-col ant-form-item-label" style="width: 120px;">
|
|
|
|
|
|
<label>审批人</label>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-form-item-control">
|
|
|
|
|
|
<div class="ant-form-item-control-input">
|
|
|
|
|
|
<div class="ant-form-item-control-input-content">
|
|
|
|
|
|
<div class="field-readonly">
|
|
|
|
|
|
{{ users }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-form-item-control ant-col-12">
|
|
|
|
|
|
<!-- <a-button style="width: 20%;" v-auth="'monitor:appointedAuditor'" @click="addOrSubtractUser">{{
|
|
|
|
|
|
t('加减签')
|
|
|
|
|
|
}}</a-button> -->
|
|
|
|
|
|
<a-button v-if="!showAdd" v-auth="'monitor:appointedAuditor'" style="margin-right: 10px;"
|
|
|
|
|
|
@click="approveUser">{{
|
|
|
|
|
|
t('修改审批人')
|
|
|
|
|
|
}}</a-button>
|
|
|
|
|
|
<AddOrSubtract v-else :schemaId="schemaId" :taskId="assignee.value.taskId"
|
|
|
|
|
|
:selectedUser="assignee.value.assigneeVoList">
|
|
|
|
|
|
</AddOrSubtract>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<!-- 创建时间 -->
|
|
|
|
|
|
<div class="ant-col ant-col-24">
|
|
|
|
|
|
<div class="ant-row ant-form-item" style="row-gap: 0px;">
|
|
|
|
|
|
<div class="ant-col ant-form-item-label" style="width: 120px;">
|
|
|
|
|
|
<label>创建时间</label>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<div class="ant-col ant-form-item-control">
|
|
|
|
|
|
<div class="ant-form-item-control-input">
|
|
|
|
|
|
<div class="ant-form-item-control-input-content">
|
|
|
|
|
|
<div class="field-readonly">
|
|
|
|
|
|
{{ assignee.value.createTime }}
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
|
|
|
|
|
|
<div :style="{ textAlign: getProps.buttonLocation }">
|
|
|
|
|
|
<slot name="buttonBefore"></slot>
|
|
|
|
|
|
<a-button v-if="getProps.showSubmitButton" type="primary" @click="handleSubmit">
|
|
|
|
|
|
{{ t('提交') }}
|
|
|
|
|
|
</a-button>
|
|
|
|
|
|
<a-button v-if="getProps.showResetButton" style="margin-left: 10px" @click="handleReset">
|
|
|
|
|
|
{{ t('重置') }}
|
|
|
|
|
|
</a-button>
|
|
|
|
|
|
<slot name="buttonAfter"></slot>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
</Form>
|
|
|
|
|
|
</div>
|
|
|
|
|
|
<template>
|
|
|
|
|
|
<ApproveProcessMonitor v-if="showApproveUser" :taskId="assignee.value.taskId" :userList="assignee.value"
|
|
|
|
|
|
title="修改审批人" @close="
|
|
|
|
|
|
(val) => {
|
|
|
|
|
|
showApproveUser = false;
|
|
|
|
|
|
if (val.length > 0) {
|
|
|
|
|
|
assignee.value.assigneeNameStr = val.map((ele) => {
|
|
|
|
|
|
return ele.name;
|
|
|
|
|
|
}).join(',');
|
|
|
|
|
|
}
|
|
|
|
|
|
}
|
|
|
|
|
|
" />
|
|
|
|
|
|
</template>
|
|
|
|
|
|
<!-- 指派审核人 -->
|
|
|
|
|
|
<!-- 流程流转 -->
|
|
|
|
|
|
<opinionDialog ref="opinionDlg" />
|
|
|
|
|
|
<!-- <AddOrSubtract v-if="showAdd"></AddOrSubtract> -->
|
|
|
|
|
|
|
|
|
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
|
|
<script>
|
|
|
|
|
|
// 注意,这里继承的是SimpleFormSetup,使用script setup写法的组件无法继承,必须使用特别的版本
|
|
|
|
|
|
import SimpleFormSetup from '/@/components/SimpleForm/src/SimpleFormSetup.vue';
|
|
|
|
|
|
import { Col, Form, message, Row } from 'ant-design-vue';
|
|
|
|
|
|
import SimpleFormItem from '/@/components/SimpleForm/src/components/SimpleFormItem.vue';
|
|
|
|
|
|
import { ref, reactive, inject } from 'vue';
|
|
|
|
|
|
import { CheckCircleOutlined } from '@ant-design/icons-vue';
|
|
|
|
|
|
import ApproveProcessMonitor from '../../../views/workflow/task/components/flow/ApproveProcessMonitorUser.vue';
|
|
|
|
|
|
import { data } from '../../demo/excel/data';
|
|
|
|
|
|
import opinionDialog from '/@/components/SecondDev/OpinionDialogSelected.vue';
|
|
|
|
|
|
import { getProcessUserNodes, SetChangeProcessNode } from '/@/api/workflow/adminOperation'
|
|
|
|
|
|
import AddOrSubtract from '../../workflow/task/components/flow/AddOrSubtractWork.vue';
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
const FormItem = Form.Item;
|
|
|
|
|
|
|
|
|
|
|
|
export default {
|
|
|
|
|
|
components: {
|
|
|
|
|
|
CheckCircleOutlined,
|
|
|
|
|
|
Form,
|
|
|
|
|
|
Col,
|
|
|
|
|
|
SimpleFormItem,
|
|
|
|
|
|
Row,
|
|
|
|
|
|
FormItem,
|
|
|
|
|
|
ApproveProcessMonitor,
|
|
|
|
|
|
opinionDialog,
|
|
|
|
|
|
AddOrSubtract,
|
|
|
|
|
|
},
|
|
|
|
|
|
mixins: [SimpleFormSetup],
|
|
|
|
|
|
setup(props, ctx) {
|
|
|
|
|
|
const ret = SimpleFormSetup.setup(props, ctx);
|
|
|
|
|
|
const expose = ctx.expose;
|
|
|
|
|
|
const assignee = ctx.attrs.clickedTaskAssignees
|
|
|
|
|
|
const currentTaskAssigneeNames = ctx.attrs.currentTaskAssigneeNames
|
|
|
|
|
|
const isCustom = ref(Boolean)
|
|
|
|
|
|
const schemaId = ctx.attrs.schemaId;
|
|
|
|
|
|
const processId = ctx.attrs.processId;
|
|
|
|
|
|
isCustom.value = ctx.attrs.isCustom;
|
|
|
|
|
|
|
|
|
|
|
|
const showApproveUser = ref(Boolean);
|
|
|
|
|
|
showApproveUser.value = false;
|
|
|
|
|
|
const showAdd = ref(Boolean);
|
|
|
|
|
|
showAdd.value = true;
|
|
|
|
|
|
|
|
|
|
|
|
const opinionDlg = ref();
|
|
|
|
|
|
const selectedInfo = ref();
|
|
|
|
|
|
const allTaskNodes = inject('taskNode');;
|
|
|
|
|
|
|
|
|
|
|
|
const users = ref('');
|
|
|
|
|
|
users.value = assignee.value.assigneeVoList.map((ele) => {
|
|
|
|
|
|
return ele.name + '(' + ele.code + ')';
|
|
|
|
|
|
}).join(',')
|
|
|
|
|
|
|
|
|
|
|
|
if (assignee.value.assigneeVoList.length > 1) {
|
|
|
|
|
|
showAdd.value = false;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function approveUser() {
|
|
|
|
|
|
showApproveUser.value = true;
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function flowChange() {
|
|
|
|
|
|
opinionDlg.value.toggleDialog({
|
|
|
|
|
|
action: 'select',
|
|
|
|
|
|
schemaId: schemaId,
|
|
|
|
|
|
choseTime: false,
|
|
|
|
|
|
title: '流程流转',
|
|
|
|
|
|
taskNode: allTaskNodes,
|
|
|
|
|
|
callback(args) {
|
|
|
|
|
|
selectedInfo.value = args.info
|
|
|
|
|
|
submit(args.info)
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function submit(info) {
|
|
|
|
|
|
const key = info.taskId;
|
|
|
|
|
|
const userIds = info.selectedList.map((ele) => {
|
|
|
|
|
|
return ele.id
|
|
|
|
|
|
}).join(',');
|
|
|
|
|
|
SetChangeProcessNode({
|
2025-06-23 16:41:11 +08:00
|
|
|
|
'taskId': assignee.value.taskId,
|
2025-03-11 09:37:15 +08:00
|
|
|
|
'targetTaskNodeId': info.taskId,
|
|
|
|
|
|
'nextTaskUserMap': {
|
|
|
|
|
|
[key]: userIds
|
|
|
|
|
|
},
|
|
|
|
|
|
"remark": info.opinion
|
|
|
|
|
|
}).then((res) => {
|
|
|
|
|
|
if (res) {
|
|
|
|
|
|
message.info("流程流转成功!");
|
|
|
|
|
|
flowFail();
|
|
|
|
|
|
} else {
|
|
|
|
|
|
message.info("操作失败,请稍后再试!");
|
|
|
|
|
|
}
|
|
|
|
|
|
})
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function flowFail() {
|
|
|
|
|
|
opinionDlg.value.stopLoading();
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
return {
|
|
|
|
|
|
approveUser,
|
|
|
|
|
|
flowChange,
|
|
|
|
|
|
showAdd,
|
|
|
|
|
|
processId,
|
|
|
|
|
|
schemaId,
|
|
|
|
|
|
showApproveUser,
|
|
|
|
|
|
isCustom,
|
|
|
|
|
|
assignee,
|
|
|
|
|
|
currentTaskAssigneeNames,
|
|
|
|
|
|
opinionDlg,
|
|
|
|
|
|
users,
|
|
|
|
|
|
...ret
|
|
|
|
|
|
};
|
|
|
|
|
|
},
|
|
|
|
|
|
computed: {
|
|
|
|
|
|
// 这里需要增加一个计算属性 否则流程关联时字段读写状态会失效
|
|
|
|
|
|
schemaMap() {
|
|
|
|
|
|
const schemaMap = {};
|
|
|
|
|
|
this.getSchemas.forEach((schema) => {
|
|
|
|
|
|
schemaMap[schema.key] = schema;
|
|
|
|
|
|
if (schema.children) {
|
|
|
|
|
|
schema.children.forEach(sChild => {
|
|
|
|
|
|
if (sChild.list) {
|
|
|
|
|
|
sChild.list.forEach(lChild => {
|
|
|
|
|
|
schemaMap[lChild.key] = lChild;
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
}
|
|
|
|
|
|
});
|
|
|
|
|
|
return schemaMap;
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
methods: {
|
|
|
|
|
|
getIfShow2: function (key) {
|
|
|
|
|
|
return this.getIfShow(this.schemaMap[key], this.formModel[this.schemaMap[key].field]);
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
getIsShow2: function (key) {
|
|
|
|
|
|
return this.getIsShow(this.schemaMap[key], this.formModel[this.schemaMap[key].field]);
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
getTabProps(key) {
|
|
|
|
|
|
const schema = this.schemaMap[key];
|
|
|
|
|
|
return {
|
|
|
|
|
|
size: schema.componentProps.tabSize,
|
|
|
|
|
|
tabPosition: schema.componentProps.tabPosition,
|
|
|
|
|
|
type: schema.componentProps.type
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
|
|
|
|
getTdStyle(tdElement) {
|
|
|
|
|
|
return {
|
|
|
|
|
|
height: tdElement.height ? tdElement.height + 'px' : '',
|
|
|
|
|
|
minHeight: (tdElement.height || '42') + 'px',
|
|
|
|
|
|
overflow: 'hidden',
|
|
|
|
|
|
padding: '10px'
|
|
|
|
|
|
}
|
|
|
|
|
|
},
|
|
|
|
|
|
// approveUser: function () {
|
|
|
|
|
|
// return data.value.approvedUserVisible = true;
|
|
|
|
|
|
// }
|
|
|
|
|
|
}
|
|
|
|
|
|
};
|
|
|
|
|
|
</script>
|