detail.vue 30.6 KB
Newer Older
lanbaoming's avatar
lanbaoming committed
1 2 3
<template>
  <div class="app-container">
    <!-- 审批信息 -->
332784038@qq.com's avatar
6  
332784038@qq.com committed
4
    <el-card class="box-card" v-loading="processInstanceLoading" v-for="(item, index) in runningTasks" :key="index">
lanbaoming's avatar
lanbaoming committed
5
      <div slot="header" class="clearfix">
332784038@qq.com's avatar
6  
332784038@qq.com committed
6
        <span class="el-icon-picture-outline">{{ $t("审批任务") }}{{ item.name }}</span>
lanbaoming's avatar
lanbaoming committed
7 8
      </div>
      <el-col :span="16" :offset="6">
332784038@qq.com's avatar
6  
332784038@qq.com committed
9 10
        <el-form :ref="'form' + index" :model="auditForms[index]" :rules="auditRule2" label-width="100px">
          <el-form-item :label="$t('流程名')" v-if="processInstance && processInstance.name">
lanbaoming's avatar
lanbaoming committed
11 12
            {{ processInstance.name }}
          </el-form-item>
332784038@qq.com's avatar
6  
332784038@qq.com committed
13
          <el-form-item :label="$t('流程发起人')" v-if="processInstance && processInstance.startUser">
lanbaoming's avatar
lanbaoming committed
14
            {{ processInstance.startUser.nickname }}
332784038@qq.com's avatar
6  
332784038@qq.com committed
15
            <el-tag type="info" size="mini">{{ processInstance.startUser.deptName }}</el-tag>
lanbaoming's avatar
lanbaoming committed
16 17
          </el-form-item>
          <el-form-item :label="$t('抄送人')" prop="copyUserIds">
332784038@qq.com's avatar
6  
332784038@qq.com committed
18 19
            <el-select v-model="auditForms[index].copyUserIds" clearable multiple filterable style="width: 100%">
              <el-option v-for="item in userOptions" :key="parseInt(item.id)" :label="item.nickname" :value="parseInt(item.id)" />
lanbaoming's avatar
lanbaoming committed
20 21 22
            </el-select>
          </el-form-item>
          <el-form-item :label="$t('审批建议')" prop="comment">
332784038@qq.com's avatar
6  
332784038@qq.com committed
23
            <el-input type="textarea" v-model="auditForms[index].comment" :placeholder="$t('请输入审批建议')" />
lanbaoming's avatar
lanbaoming committed
24 25
          </el-form-item>
        </el-form>
lanbaoming's avatar
lanbaoming committed
26
        <div style="margin-left: 10%; margin-bottom: 20px; font-size: 14px">
332784038@qq.com's avatar
6  
332784038@qq.com committed
27 28 29
          <el-button :loading="loading" icon="el-icon-edit-outline" type="success" size="mini" @click="handleAudit(item, true)">{{ $t("通过") }} </el-button>
          <el-button :loading="loading" icon="el-icon-circle-close" type="danger" size="mini" @click="handleAudit(item, false)">{{ $t("不通过") }} </el-button>
          <el-button :loading="loading" icon="el-icon-edit-outline" type="primary" size="mini" @click="handleUpdateAssignee(item)">{{ $t("转办") }} </el-button>
lanbaoming's avatar
lanbaoming committed
30 31
          <!--          <el-button icon="el-icon-edit-outline" type="primary" size="mini" @click="handleDelegate(item)">{{ $t('委派') }}</el-button>-->
          <!--          <el-button icon="el-icon-refresh-left" type="warning" size="mini" @click="handleBack(item)">{{ $t('退回') }}</el-button>-->
lanbaoming's avatar
lanbaoming committed
32 33 34
        </div>
      </el-col>
    </el-card>
35

lanbaoming's avatar
lanbaoming committed
36 37 38
    <!-- 申请信息 -->
    <el-card class="box-card mt-10" v-loading="processInstanceLoading">
      <div slot="header" class="clearfix">
332784038@qq.com's avatar
6  
332784038@qq.com committed
39
        <span class="el-icon-document">{{ $t("申请信息") }}{{ processInstance.name }}</span>
lanbaoming's avatar
lanbaoming committed
40
      </div>
332784038@qq.com's avatar
6  
332784038@qq.com committed
41
      <el-col v-if="this.processInstance.processDefinition && this.processInstance.processDefinition.formType === 10" :span="16" :offset="6">
lanbaoming's avatar
lanbaoming committed
42
        <div>
332784038@qq.com's avatar
6  
332784038@qq.com committed
43
          <parser :key="new Date().getTime()" :form-conf="detailForm" @submit="submitForm" />
lanbaoming's avatar
lanbaoming committed
44 45
        </div>
      </el-col>
332784038@qq.com's avatar
6  
332784038@qq.com committed
46 47
      <div v-if="this.processInstance.processDefinition && this.processInstance.processDefinition.formType === 20">
        <component v-if="businessKeyToComponent" :is="businessKeyToComponent.component" v-bind="businessKeyToComponent" />
lanbaoming's avatar
lanbaoming committed
48 49

        <div v-else>
332784038@qq.com's avatar
6  
332784038@qq.com committed
50
          <router-link :to="this.processInstance.processDefinition.formCustomViewPath + '?id=' + this.processInstance.businessKey">
lanbaoming's avatar
lanbaoming committed
51
            <el-button type="primary">{{ $t("点击查看") }}</el-button>
lanbaoming's avatar
lanbaoming committed
52 53 54 55 56 57
          </router-link>
        </div>
      </div>
    </el-card>
    <el-card class="box-card mt-10" v-loading="tasksLoad">
      <div slot="header" class="clearfix">
lanbaoming's avatar
lanbaoming committed
58
        <span class="el-icon-picture-outline">{{ $t("审批记录") }}</span>
lanbaoming's avatar
lanbaoming committed
59 60 61 62
      </div>
      <el-col :span="16" :offset="4">
        <div class="block">
          <el-timeline>
332784038@qq.com's avatar
6  
332784038@qq.com committed
63
            <el-timeline-item v-for="(item, index) in tasks" :key="index" :icon="getTimelineItemIcon(item)" :type="getTimelineItemType(item)">
lanbaoming's avatar
lanbaoming committed
64
              <p style="font-weight: 700">{{ $t("任务") }}{{ item.name }}</p>
lanbaoming's avatar
lanbaoming committed
65
              <el-card :body-style="{ padding: '10px' }">
332784038@qq.com's avatar
6  
332784038@qq.com committed
66
                <label v-if="item.assigneeUser" style="font-weight: normal; margin-right: 30px">
lanbaoming's avatar
lanbaoming committed
67
                  {{ $t("审批人") }}{{ item.assigneeUser.nickname }}
332784038@qq.com's avatar
6  
332784038@qq.com committed
68
                  <el-tag type="info" size="mini">{{ item.assigneeUser.deptName }}</el-tag>
lanbaoming's avatar
lanbaoming committed
69
                </label>
332784038@qq.com's avatar
6  
332784038@qq.com committed
70 71 72 73 74 75
                <label style="font-weight: normal">{{ $t("创建时间") }}</label>
                <label style="color: #8a909c; font-weight: normal">{{ parseTime(item.createTime) }}</label>
                <label v-if="item.endTime" style="margin-left: 30px; font-weight: normal">{{ $t("审批时间") }}</label>
                <label v-if="item.endTime" style="color: #8a909c; font-weight: normal"> {{ parseTime(item.endTime) }}</label>
                <label v-if="item.durationInMillis" style="margin-left: 30px; font-weight: normal">{{ $t("耗时") }}</label>
                <label v-if="item.durationInMillis" style="color: #8a909c; font-weight: normal">
lanbaoming's avatar
lanbaoming committed
76
                  {{ getDateStar(item.durationInMillis) }}
lanbaoming's avatar
lanbaoming committed
77 78
                </label>
                <p v-if="item.comment">
332784038@qq.com's avatar
6  
332784038@qq.com committed
79
                  <el-tag :type="getTimelineItemType(item)">{{ item.comment }}</el-tag>
lanbaoming's avatar
lanbaoming committed
80 81 82 83 84 85 86 87 88 89 90
                </p>
              </el-card>
            </el-timeline-item>
          </el-timeline>
        </div>
      </el-col>
    </el-card>

    <!-- 高亮流程图 -->
    <el-card class="box-card mt-10" v-loading="processInstanceLoading">
      <div slot="header" class="clearfix">
lanbaoming's avatar
lanbaoming committed
91
        <span class="el-icon-picture-outline">{{ $t("流程图") }}</span>
lanbaoming's avatar
lanbaoming committed
92
      </div>
332784038@qq.com's avatar
6  
332784038@qq.com committed
93
      <my-process-viewer key="designer" v-model="bpmnXML" v-bind="bpmnControlForm" :activityData="activityList" :processInstanceData="processInstance" :taskData="tasks" />
lanbaoming's avatar
lanbaoming committed
94 95 96
    </el-card>

    <!-- 对话框(转派审批人) -->
332784038@qq.com's avatar
6  
332784038@qq.com committed
97 98
    <el-dialog :title="$t('转派审批人')" :visible.sync="updateAssignee.open" width="500px" append-to-body>
      <el-form ref="updateAssigneeForm" :model="updateAssignee.form" :rules="updateAssignee.rules" label-width="110px">
lanbaoming's avatar
lanbaoming committed
99
        <el-form-item :label="$t('新审批人')" prop="assigneeUserId">
332784038@qq.com's avatar
6  
332784038@qq.com committed
100 101
          <el-select v-model="updateAssignee.form.assigneeUserId" clearable style="width: 100%">
            <el-option v-for="item in userOptions" :key="parseInt(item.id)" :label="item.nickname" :value="parseInt(item.id)" />
lanbaoming's avatar
lanbaoming committed
102 103 104 105
          </el-select>
        </el-form-item>
      </el-form>
      <div slot="footer" class="dialog-footer">
332784038@qq.com's avatar
6  
332784038@qq.com committed
106 107
        <el-button type="primary" @click="submitUpdateAssigneeForm">{{ $t("确定") }}</el-button>
        <el-button @click="cancelUpdateAssigneeForm">{{ $t("取消") }}</el-button>
lanbaoming's avatar
lanbaoming committed
108 109 110 111 112 113
      </div>
    </el-dialog>
  </div>
</template>

<script>
332784038@qq.com's avatar
6  
332784038@qq.com committed
114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130
import { getProcessDefinitionBpmnXML } from "@/api/bpm/definition"
import { DICT_TYPE, getDictDatas } from "@/utils/dict"
import store from "@/store"
import { decodeFields } from "@/utils/formGenerator"
import Parser from "@/components/parser/Parser"
import { createProcessInstance, getProcessInstance } from "@/api/bpm/processInstance"
import { approveTask, getTaskListByProcessInstanceId, rejectTask, updateTaskAssignee } from "@/api/bpm/task"
import { getDate } from "@/utils/dateUtils"
import { listSimpleUsers } from "@/api/system/user"
import { getActivityList } from "@/api/bpm/activity"
import OfferSpecialDetail from "@/views/ecw/offer/components/SpecialDetail"
import warehouseDetails from "@/views/ecw/order/components/warehouseDetails"
import shippingDetail from "@/views/ecw/box/shippingDetail"
import SplitDetail from "@/views/ecw/order/components/SplitDetail"
import MergeDetail from "@/views/ecw/order/components/MergeDetail"
import CargoControlDetail from "@/views/ecw/order/components/CargoControlDetail"
import BoxSplitDetail from "@/views/ecw/order/components/BoxSplitDetail"
lanbaoming's avatar
lanbaoming committed
131 132 133 134 135 136 137 138 139 140 141
// 流程实例的详情页,可用于审批
export default {
  name: "ProcessInstanceDetail",
  components: {
    Parser,
    OfferSpecialDetail,
    warehouseDetails,
    shippingDetail,
    SplitDetail,
    MergeDetail,
    CargoControlDetail,
332784038@qq.com's avatar
6  
332784038@qq.com committed
142
    BoxSplitDetail
lanbaoming's avatar
lanbaoming committed
143
  },
lanbaoming's avatar
lanbaoming committed
144
  computed: {
lanbaoming's avatar
lanbaoming committed
145 146 147 148 149 150 151
    auditRule2() {
      if (this.isMust == true) {
        var obj = {
          comment: [
            {
              required: true,
              message: this.$t("审批建议不能为空"),
332784038@qq.com's avatar
6  
332784038@qq.com committed
152 153 154 155 156
              trigger: "blur"
            }
          ]
        }
        return obj
lanbaoming's avatar
lanbaoming committed
157
      } else {
332784038@qq.com's avatar
6  
332784038@qq.com committed
158
        return {}
lanbaoming's avatar
lanbaoming committed
159 160
      }
    },
lanbaoming's avatar
lanbaoming committed
161
    matterNum() {
332784038@qq.com's avatar
6  
332784038@qq.com committed
162
      return this.$store.state.user.matterNum
lanbaoming's avatar
lanbaoming committed
163
    },
lanbaoming's avatar
lanbaoming committed
164
    businessKeyToComponent() {
332784038@qq.com's avatar
6  
332784038@qq.com committed
165 166
      if (!this.processInstance.processDefinition || !this.processInstance.processDefinition.formCustomViewPath) {
        return false
lanbaoming's avatar
lanbaoming committed
167 168
      }
      const map = {
lanbaoming's avatar
lanbaoming committed
169
        shippingDetail: {
lanbaoming's avatar
lanbaoming committed
170
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
171
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
172 173 174
        },
        // 报价单特价审核,原来配置的组件名
        "special-discount": {
lanbaoming's avatar
lanbaoming committed
175
          component: "OfferSpecialDetail",
lanbaoming's avatar
lanbaoming committed
176
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
177
          type: 1
lanbaoming's avatar
lanbaoming committed
178 179 180
        },
        // 报价单特价审核,符合命名规则的组件名
        offer_special: {
lanbaoming's avatar
lanbaoming committed
181
          component: "OfferSpecialDetail",
lanbaoming's avatar
lanbaoming committed
182
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
183
          type: 1
lanbaoming's avatar
lanbaoming committed
184 185
        },
        offer_commission: {
lanbaoming's avatar
lanbaoming committed
186
          component: "OfferSpecialDetail",
lanbaoming's avatar
lanbaoming committed
187
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
188
          type: 2
lanbaoming's avatar
lanbaoming committed
189 190 191 192 193
        },
        // 原来的费用申请
        free_apply: {
          component: "warehouseDetails",
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
194
          type: 2
lanbaoming's avatar
lanbaoming committed
195 196 197
        },
        // 2.0空运加的批量申请
        batch_free_apply: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
198
          component: () => import("@/views/ecw/order/components/BatchFeeApplication"),
lanbaoming's avatar
lanbaoming committed
199
          businessId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
200
          processInstanceId: this.$route.query.id
lanbaoming's avatar
lanbaoming committed
201 202 203 204
        },
        retired_warehouse: {
          component: "warehouseDetails",
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
205
          type: 3
lanbaoming's avatar
lanbaoming committed
206 207 208 209
        },
        warehouse_transfer: {
          component: "warehouseDetails",
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
210
          type: 1
lanbaoming's avatar
lanbaoming committed
211 212 213 214
        },
        warehouse_update: {
          component: "warehouseDetails",
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
215
          type: 4
lanbaoming's avatar
lanbaoming committed
216 217 218
        },
        container_modify: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
219
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
220 221 222
        },
        trailer_modify: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
223
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
224 225 226
        },
        ship_modify: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
227
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
228 229 230
        },
        customs_declare_modify: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
231
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
232 233 234
        },
        arrival_modify: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
235
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
236 237 238
        },
        customs_clearance_modify: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
239
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
240 241 242
        },
        customs_exit_part: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
243
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
244 245 246
        },
        customs_exit_all: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
247
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
248 249 250
        },
        start_port_modify: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
251
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
252 253 254
        },
        book_space_modify: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
255
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
256 257 258
        },
        sorting_apply_no: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
259
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
260 261 262
        },
        sorting_apply: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
263
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
264 265 266
        },
        unload_container_no: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
267
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
268 269 270 271
        },
        unload_container: {
          component: "shippingDetail",
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
272
          type: "unload_container"
lanbaoming's avatar
lanbaoming committed
273 274 275 276
        },
        close_container: {
          component: "shippingDetail",
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
277
          type: "close_container"
lanbaoming's avatar
lanbaoming committed
278 279 280
        },
        shipment_preassemble: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
281
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
282 283 284
        },
        close_container_no: {
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
285
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
286 287 288 289
        },
        // 拆单审核
        split_detail: {
          component: "SplitDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
290
          id: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
291 292 293 294
        },
        // 出货拆单审核
        shipment_split_detail: {
          component: "BoxSplitDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
295
          id: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
296 297 298 299
        },
        // 退场拆单,跟出货装柜拆单一样
        exit_split: {
          component: "BoxSplitDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
300
          id: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
301 302 303
        },
        merge_detail: {
          component: "MergeDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
304
          id: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
305 306 307
        },
        // 放货修改
        order_update_release: {
lanbaoming's avatar
lanbaoming committed
308
          component: "CargoControlDetail",
lanbaoming's avatar
lanbaoming committed
309
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
310
          applyType: 7
lanbaoming's avatar
lanbaoming committed
311 312 313
        },
        // 反复核
        order_fallback: {
lanbaoming's avatar
lanbaoming committed
314
          component: "CargoControlDetail",
lanbaoming's avatar
lanbaoming committed
315
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
316
          applyType: 8
lanbaoming's avatar
lanbaoming committed
317 318 319
        },
        // 调货审核
        order_transfer: {
lanbaoming's avatar
lanbaoming committed
320
          component: "CargoControlDetail",
lanbaoming's avatar
lanbaoming committed
321
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
322
          applyType: 9
lanbaoming's avatar
lanbaoming committed
323 324 325
        },
        // 取消放货审核
        order_cancel_release: {
lanbaoming's avatar
lanbaoming committed
326
          component: "CargoControlDetail",
lanbaoming's avatar
lanbaoming committed
327
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
328
          applyType: 10
lanbaoming's avatar
lanbaoming committed
329 330
        },
        // 提单审核
lanbaoming's avatar
lanbaoming committed
331
        order_landing_bill: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
332
          component: () => import("@/views/ecw/order/components/LandingBillDetail"),
lanbaoming's avatar
lanbaoming committed
333
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
334
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
335 336
        },
        // 订单审核详情
lanbaoming's avatar
lanbaoming committed
337
        order_approval: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
338
          component: () => import("@/views/ecw/order/components/ApprovalDetail"),
lanbaoming's avatar
lanbaoming committed
339
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
340
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
341 342
        },
        // 订单修改审批
lanbaoming's avatar
lanbaoming committed
343 344
        order_update: {
          component: () => import("@/views/ecw/order/components/UpdateDetail"),
lanbaoming's avatar
lanbaoming committed
345
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
346
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
347 348
        },
        // 预付异常审核
lanbaoming's avatar
lanbaoming committed
349
        prepay_excetion: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
350
          component: () => import("@/views/ecw/order/components/PrepayExceptionDetail"),
lanbaoming's avatar
lanbaoming committed
351
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
352
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
353 354
        },
        // 客户延期
lanbaoming's avatar
lanbaoming committed
355 356
        customer_delay: {
          component: () => import("@/views/ecw/customer/components/Delay"),
lanbaoming's avatar
lanbaoming committed
357
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
358
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
359 360
        },
        //付款单审核-所有审核流程详情组件
lanbaoming's avatar
lanbaoming committed
361
        finance_payment_approve: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
362
          component: () => import("@/views/ecw/financial/components/PaymentApproval"),
lanbaoming's avatar
lanbaoming committed
363
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
364
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
365 366
        },
        //收款单审核
lanbaoming's avatar
lanbaoming committed
367
        finance_receipt_approve: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
368
          component: () => import("@/views/ecw/financial/components/CollectionApproval"),
lanbaoming's avatar
lanbaoming committed
369
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
370
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
371 372
        },
        //收款单核销
lanbaoming's avatar
lanbaoming committed
373
        finance_receipt_write_off: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
374
          component: () => import("@/views/ecw/financial/components/CollectionWriteoff"),
lanbaoming's avatar
lanbaoming committed
375
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
376
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
377 378
        },
        //收款单反核销审核
lanbaoming's avatar
lanbaoming committed
379
        finance_receipt_write_off_no: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
380
          component: () => import("@/views/ecw/financial/components/CollectionApproval"),
lanbaoming's avatar
lanbaoming committed
381
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
382
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
383 384
        },
        //收款单核销反审核
lanbaoming's avatar
lanbaoming committed
385
        finance_receipt_approve_no: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
386
          component: () => import("@/views/ecw/financial/components/CollectionApproval"),
lanbaoming's avatar
lanbaoming committed
387
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
388
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
389 390
        },
        //收款单银行实收明细核销
lanbaoming's avatar
lanbaoming committed
391
        finance_receipt_item_write_off: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
392
          component: () => import("@/views/ecw/financial/components/CollectionBankDetail"),
lanbaoming's avatar
lanbaoming committed
393
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
394
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
395 396
        },
        //收款单银行实收反核销
lanbaoming's avatar
lanbaoming committed
397
        finance_receipt_item_write_off_no: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
398
          component: () => import("@/views/ecw/financial/components/CollectionBankDetail"),
lanbaoming's avatar
lanbaoming committed
399
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
400
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
401 402 403
        },
        //佣金付款单审核详情-关于佣金付款单所有审核详情
        commissionPaymentDetails: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
404
          component: () => import("@/views/ecw/financial/components/commissionPaymentDetails.vue"),
lanbaoming's avatar
lanbaoming committed
405
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
406
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
407 408
        },
        /*撤销拆单*/
lanbaoming's avatar
lanbaoming committed
409
        split_revoke: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
410 411
          component: () => import("@/views/ecw/order/components/SplitRevokeDetail"),
          id: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
412 413
        },
        // 不可出渠道异常审核
lanbaoming's avatar
lanbaoming committed
414
        not_shiping_channel: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
415
          component: () => import("@/views/ecw/order/components/NotShipingChannel"),
lanbaoming's avatar
lanbaoming committed
416
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
417
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
418 419
        },
        // 出货批量加价审核
lanbaoming's avatar
lanbaoming committed
420
        box_batch_markup: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
421
          component: () => import("@/views/ecw/box/components/batchMakeUpDetail.vue"),
lanbaoming's avatar
lanbaoming committed
422
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
423
          type: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
424 425 426
        },
        //   可获移交详情
        customer_handover_details: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
427
          component: () => import("@/views/ecw/customer/components/customer-handover-details.vue"),
lanbaoming's avatar
lanbaoming committed
428
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
429
          type: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
430 431 432 433 434
        },
        // 出货审核
        air_shipment: {
          component: "shippingDetail",
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
435
          type: "shipment"
lanbaoming's avatar
lanbaoming committed
436 437
        },
        //排单分拣审核
lanbaoming's avatar
lanbaoming committed
438
        shipment_order_sorting: {
lanbaoming's avatar
lanbaoming committed
439
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
440
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
441 442
        },
        // 出货反审
lanbaoming's avatar
lanbaoming committed
443
        shipment_review: {
lanbaoming's avatar
lanbaoming committed
444
          component: "shippingDetail",
332784038@qq.com's avatar
6  
332784038@qq.com committed
445
          processId: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
446 447
        },
        // 删单退场
lanbaoming's avatar
lanbaoming committed
448
        customs_declare_remove: {
lanbaoming's avatar
lanbaoming committed
449 450
          component: "shippingDetail",
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
451
          type: "deleteExit"
lanbaoming's avatar
lanbaoming committed
452 453 454 455 456
        },
        // 空运到仓审核
        air_warehouse: {
          component: "shippingDetail",
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
457
          type: "air_warehouse"
lanbaoming's avatar
lanbaoming committed
458 459 460 461 462
        },
        // 空运到仓审核
        air_warehouse_no: {
          component: "shippingDetail",
          processId: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
463
          type: "air_warehouse"
lanbaoming's avatar
lanbaoming committed
464
        },
lanbaoming's avatar
lanbaoming committed
465 466
        revoke_clear: {
          component: () => import("@/views/ecw/box/components/RevokeClear"),
332784038@qq.com's avatar
6  
332784038@qq.com committed
467
          id: this.processInstance.businessKey
lanbaoming's avatar
lanbaoming committed
468 469
        },
        // 重量超限
lanbaoming's avatar
lanbaoming committed
470
        over_weight_exception: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
471
          component: () => import("@/views/ecw/order/exception/components/overweightException"),
lanbaoming's avatar
lanbaoming committed
472
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
473
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
474 475
        },
        // 线路重量超限
lanbaoming's avatar
lanbaoming committed
476
        line_weight_exception: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
477
          component: () => import("@/views/ecw/order/exception/components/overweightException"),
lanbaoming's avatar
lanbaoming committed
478
          id: this.processInstance.businessKey,
332784038@qq.com's avatar
6  
332784038@qq.com committed
479
          path: this.processInstance.processDefinition?.formCustomViewPath
lanbaoming's avatar
lanbaoming committed
480
        },
481
        // 收货人限制修改申请
332784038@qq.com's avatar
6  
332784038@qq.com committed
482
        order_consignee_limit_change: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
483 484
          component: () => import("@/views/ecw/order/components/updateReleaseLimitApproval"),
          id: this.processInstance.businessKey
485 486
        },
        // 海外仓修改申请,下面的组件待改
332784038@qq.com's avatar
6  
332784038@qq.com committed
487
        order_overseas_warehouse_change: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
488 489 490 491 492 493 494
          component: () => import("@/views/ecw/order/components/updateReleaseTypeApproval"),
          id: parseInt(this.processInstance.businessKey)
        }
      }
      console.log("formCustomViewPath", this.processInstance.processDefinition.formCustomViewPath.trim())
      return map[this.processInstance.processDefinition.formCustomViewPath.trim()]
    }
lanbaoming's avatar
lanbaoming committed
495 496 497 498 499 500 501 502 503 504 505 506
  },
  data() {
    return {
      // 提交中
      loading: false,
      // 遮罩层
      processInstanceLoading: true,
      // 流程实例
      id: undefined, // 流程实例的编号
      processInstance: {},
      // 流程表单详情
      detailForm: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
507
        fields: []
lanbaoming's avatar
lanbaoming committed
508
      },
lanbaoming's avatar
lanbaoming committed
509
      isMust: true,
lanbaoming's avatar
lanbaoming committed
510 511 512
      // BPMN 数据
      bpmnXML: null,
      bpmnControlForm: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
513
        prefix: "activiti"
lanbaoming's avatar
lanbaoming committed
514 515 516 517 518 519 520 521 522
      },
      activityList: [],
      // 审批记录
      tasksLoad: true,
      tasks: [],
      // 审批表单
      runningTasks: [],
      auditForms: [],
      auditRule: {
lanbaoming's avatar
lanbaoming committed
523 524
        comment: [
          {
lanbaoming's avatar
lanbaoming committed
525
            required: this.isMust,
lanbaoming's avatar
lanbaoming committed
526
            message: this.$t("审批建议不能为空"),
332784038@qq.com's avatar
6  
332784038@qq.com committed
527 528 529
            trigger: "blur"
          }
        ]
lanbaoming's avatar
lanbaoming committed
530 531 532 533 534 535 536
      },

      // 转派审批人
      userOptions: [],
      updateAssignee: {
        open: false,
        form: {
332784038@qq.com's avatar
6  
332784038@qq.com committed
537
          assigneeUserId: undefined
lanbaoming's avatar
lanbaoming committed
538 539
        },
        rules: {
lanbaoming's avatar
lanbaoming committed
540 541 542 543
          assigneeUserId: [
            {
              required: true,
              message: this.$t("新审批人不能为空"),
332784038@qq.com's avatar
6  
332784038@qq.com committed
544 545 546 547
              trigger: "change"
            }
          ]
        }
lanbaoming's avatar
lanbaoming committed
548 549 550
      },

      // 数据字典
332784038@qq.com's avatar
6  
332784038@qq.com committed
551 552
      categoryDictDatas: getDictDatas(DICT_TYPE.BPM_MODEL_CATEGORY)
    }
lanbaoming's avatar
lanbaoming committed
553 554
  },
  created() {
332784038@qq.com's avatar
6  
332784038@qq.com committed
555
    this.id = this.$route.query.id
lanbaoming's avatar
lanbaoming committed
556
    if (!this.id) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
557 558
      this.$message.error("未传递 id 参数,无法查看流程信息")
      return
lanbaoming's avatar
lanbaoming committed
559
    }
332784038@qq.com's avatar
6  
332784038@qq.com committed
560
    this.getDetail()
lanbaoming's avatar
lanbaoming committed
561 562

    // 获得用户列表
332784038@qq.com's avatar
6  
332784038@qq.com committed
563
    this.userOptions = []
lanbaoming's avatar
lanbaoming committed
564
    listSimpleUsers().then((response) => {
332784038@qq.com's avatar
6  
332784038@qq.com committed
565 566
      this.userOptions.push(...response.data)
    })
lanbaoming's avatar
lanbaoming committed
567 568 569 570 571
  },
  methods: {
    /** 获得流程实例 */
    getDetail() {
      // 获得流程实例相关
332784038@qq.com's avatar
6  
332784038@qq.com committed
572
      this.processInstanceLoading = true
lanbaoming's avatar
lanbaoming committed
573
      getProcessInstance(this.id).then((response) => {
lanbaoming's avatar
lanbaoming committed
574
        if (!response.data) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
575 576
          this.$message.error("查询不到流程信息!")
          return
lanbaoming's avatar
lanbaoming committed
577 578
        }
        // 设置流程信息
332784038@qq.com's avatar
6  
332784038@qq.com committed
579 580
        this.processInstance = response.data
        console.log(this.processInstance)
lanbaoming's avatar
lanbaoming committed
581

lanbaoming's avatar
lanbaoming committed
582
        //银行实收明细核销不限制必填 lanbm 2024-05-24 add
332784038@qq.com's avatar
6  
332784038@qq.com committed
583 584
        if (this.processInstance.processDefinition.formCustomViewPath == undefined || this.processInstance.processDefinition.formCustomViewPath == null || this.processInstance.processDefinition.formCustomViewPath == "") {
          this.isMust = true
lanbaoming's avatar
lanbaoming committed
585
        } else {
332784038@qq.com's avatar
6  
332784038@qq.com committed
586 587
          if (this.processInstance.processDefinition.formCustomViewPath.trim() == "finance_receipt_item_write_off") {
            this.isMust = false
lanbaoming's avatar
lanbaoming committed
588
          } else {
332784038@qq.com's avatar
6  
332784038@qq.com committed
589
            this.isMust = true
lanbaoming's avatar
lanbaoming committed
590 591 592 593
          }
        }
        //end 银行实收明细核销不限制必填 lanbm 2024-05-24 add

lanbaoming's avatar
lanbaoming committed
594 595 596 597 598 599
        // 设置表单信息
        if (this.processInstance.processDefinition.formType === 10) {
          this.detailForm = {
            ...JSON.parse(this.processInstance.processDefinition.formConf),
            disabled: true, // 表单禁用
            formBtns: false, // 按钮隐藏
332784038@qq.com's avatar
6  
332784038@qq.com committed
600 601
            fields: decodeFields(this.processInstance.processDefinition.formFields)
          }
lanbaoming's avatar
lanbaoming committed
602
          // 设置表单的值
lanbaoming's avatar
lanbaoming committed
603
          this.detailForm.fields.forEach((item) => {
332784038@qq.com's avatar
6  
332784038@qq.com committed
604
            const val = this.processInstance.formVariables[item.__vModel__]
lanbaoming's avatar
lanbaoming committed
605
            if (val) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
606
              item.__config__.defaultValue = val
lanbaoming's avatar
lanbaoming committed
607
            }
332784038@qq.com's avatar
6  
332784038@qq.com committed
608
          })
lanbaoming's avatar
lanbaoming committed
609 610 611
        }

        // 加载流程图
332784038@qq.com's avatar
6  
332784038@qq.com committed
612 613 614
        getProcessDefinitionBpmnXML(this.processInstance.processDefinition.id).then((response) => {
          this.bpmnXML = response.data
        })
lanbaoming's avatar
lanbaoming committed
615 616
        // 加载活动列表
        getActivityList({
332784038@qq.com's avatar
6  
332784038@qq.com committed
617
          processInstanceId: this.processInstance.id
lanbaoming's avatar
lanbaoming committed
618
        }).then((response) => {
332784038@qq.com's avatar
6  
332784038@qq.com committed
619 620
          this.activityList = response.data
        })
lanbaoming's avatar
lanbaoming committed
621 622

        // 取消加载中
332784038@qq.com's avatar
6  
332784038@qq.com committed
623 624
        this.processInstanceLoading = false
      })
lanbaoming's avatar
lanbaoming committed
625 626

      // 获得流程任务列表(审批记录)
332784038@qq.com's avatar
6  
332784038@qq.com committed
627 628 629
      this.tasksLoad = true
      this.runningTasks = []
      this.auditForms = []
lanbaoming's avatar
lanbaoming committed
630
      getTaskListByProcessInstanceId(this.id).then((response) => {
lanbaoming's avatar
lanbaoming committed
631
        // 审批记录
332784038@qq.com's avatar
6  
332784038@qq.com committed
632
        this.tasks = response.data
lanbaoming's avatar
lanbaoming committed
633 634 635 636
        // 排序,将未完成的排在前面,已完成的排在后面;
        this.tasks.sort((a, b) => {
          // 有已完成的情况,按照完成时间倒序
          if (a.endTime && b.endTime) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
637
            return b.endTime - a.endTime
lanbaoming's avatar
lanbaoming committed
638
          } else if (a.endTime) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
639
            return 1
lanbaoming's avatar
lanbaoming committed
640
          } else if (b.endTime) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
641
            return -1
lanbaoming's avatar
lanbaoming committed
642 643
            // 都是未完成,按照创建时间倒序
          } else {
332784038@qq.com's avatar
6  
332784038@qq.com committed
644
            return b.createTime - a.createTime
lanbaoming's avatar
lanbaoming committed
645
          }
332784038@qq.com's avatar
6  
332784038@qq.com committed
646
        })
lanbaoming's avatar
lanbaoming committed
647 648

        // 需要审核的记录
332784038@qq.com's avatar
6  
332784038@qq.com committed
649
        const userId = store.getters.userId
lanbaoming's avatar
lanbaoming committed
650 651 652
        this.tasks.forEach((task) => {
          if (task.result !== 1) {
            // 只有待处理才需要
332784038@qq.com's avatar
6  
332784038@qq.com committed
653
            return
lanbaoming's avatar
lanbaoming committed
654
          }
lanbaoming's avatar
lanbaoming committed
655 656
          if (!task.assigneeUser || task.assigneeUser.id !== userId) {
            // 自己不是处理人
332784038@qq.com's avatar
6  
332784038@qq.com committed
657
            return
lanbaoming's avatar
lanbaoming committed
658
          }
332784038@qq.com's avatar
6  
332784038@qq.com committed
659
          this.runningTasks.push({ ...task })
lanbaoming's avatar
lanbaoming committed
660
          this.auditForms.push({
332784038@qq.com's avatar
6  
332784038@qq.com committed
661 662 663
            comment: ""
          })
        })
lanbaoming's avatar
lanbaoming committed
664 665

        // 取消加载中
332784038@qq.com's avatar
6  
332784038@qq.com committed
666 667
        this.tasksLoad = false
      })
lanbaoming's avatar
lanbaoming committed
668 669 670 671
    },
    /** 处理选择流程的按钮操作 **/
    handleSelect(row) {
      // 设置选择的流程
332784038@qq.com's avatar
6  
332784038@qq.com committed
672
      this.selectProcessInstance = row
lanbaoming's avatar
lanbaoming committed
673 674 675 676 677 678

      // 流程表单
      if (row.formId) {
        // 设置对应的表单
        this.detailForm = {
          ...JSON.parse(row.formConf),
332784038@qq.com's avatar
6  
332784038@qq.com committed
679 680
          fields: decodeFields(row.formFields)
        }
lanbaoming's avatar
lanbaoming committed
681
      } else if (row.formCustomCreatePath) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
682
        this.$router.push({ path: row.formCustomCreatePath })
lanbaoming's avatar
lanbaoming committed
683 684 685 686 687 688
        // 这里暂时无需加载流程图,因为跳出到另外个 Tab;
      }
    },
    /** 提交按钮 */
    submitForm(params) {
      if (!params) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
689
        return
lanbaoming's avatar
lanbaoming committed
690 691
      }
      // 设置表单禁用
332784038@qq.com's avatar
6  
332784038@qq.com committed
692 693 694
      const conf = params.conf
      conf.disabled = true // 表单禁用
      conf.formBtns = false // 按钮隐藏
lanbaoming's avatar
lanbaoming committed
695 696

      // 提交表单,创建流程
332784038@qq.com's avatar
6  
332784038@qq.com committed
697
      const variables = params.values
lanbaoming's avatar
lanbaoming committed
698 699
      createProcessInstance({
        processDefinitionId: this.selectProcessInstance.id,
332784038@qq.com's avatar
6  
332784038@qq.com committed
700
        variables: variables
lanbaoming's avatar
lanbaoming committed
701
      })
lanbaoming's avatar
lanbaoming committed
702
        .then((response) => {
332784038@qq.com's avatar
6  
332784038@qq.com committed
703
          this.$modal.msgSuccess("发起流程成功")
lanbaoming's avatar
lanbaoming committed
704
          // 关闭当前窗口
332784038@qq.com's avatar
6  
332784038@qq.com committed
705 706
          this.$tab.closeOpenPage()
          this.$router.go(-1)
lanbaoming's avatar
lanbaoming committed
707 708
        })
        .catch(() => {
332784038@qq.com's avatar
6  
332784038@qq.com committed
709 710 711
          conf.disabled = false // 表单开启
          conf.formBtns = true // 按钮展示
        })
lanbaoming's avatar
lanbaoming committed
712 713
    },
    getDateStar(ms) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
714
      return getDate(ms)
lanbaoming's avatar
lanbaoming committed
715 716 717
    },
    getTimelineItemIcon(item) {
      if (item.result === 1) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
718
        return "el-icon-time"
lanbaoming's avatar
lanbaoming committed
719 720
      }
      if (item.result === 2) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
721
        return "el-icon-check"
lanbaoming's avatar
lanbaoming committed
722 723
      }
      if (item.result === 3) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
724
        return "el-icon-close"
lanbaoming's avatar
lanbaoming committed
725 726
      }
      if (item.result === 4) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
727
        return "el-icon-remove-outline"
lanbaoming's avatar
lanbaoming committed
728
      }
332784038@qq.com's avatar
6  
332784038@qq.com committed
729
      return ""
lanbaoming's avatar
lanbaoming committed
730 731 732
    },
    getTimelineItemType(item) {
      if (item.result === 1) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
733
        return "primary"
lanbaoming's avatar
lanbaoming committed
734 735
      }
      if (item.result === 2) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
736
        return "success"
lanbaoming's avatar
lanbaoming committed
737 738
      }
      if (item.result === 3) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
739
        return "danger"
lanbaoming's avatar
lanbaoming committed
740 741
      }
      if (item.result === 4) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
742
        return "info"
lanbaoming's avatar
lanbaoming committed
743
      }
332784038@qq.com's avatar
6  
332784038@qq.com committed
744
      return ""
lanbaoming's avatar
lanbaoming committed
745 746 747
    },
    /** 处理审批通过和不通过的操作 */
    handleAudit(task, pass) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
748
      const index = this.runningTasks.indexOf(task)
lanbaoming's avatar
lanbaoming committed
749
      this.$refs["form" + index][0].validate((valid) => {
lanbaoming's avatar
lanbaoming committed
750
        if (!valid) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
751
          return
lanbaoming's avatar
lanbaoming committed
752 753 754 755
        }
        const data = {
          id: task.id,
          comment: this.auditForms[index].comment,
332784038@qq.com's avatar
6  
332784038@qq.com committed
756 757 758
          copyUserIds: this.auditForms[index].copyUserIds
        }
        this.loading = true
lanbaoming's avatar
lanbaoming committed
759
        if (pass) {
lanbaoming's avatar
lanbaoming committed
760 761
          approveTask(data)
            .then((response) => {
332784038@qq.com's avatar
6  
332784038@qq.com committed
762
              let p = this.matterNum
lanbaoming's avatar
lanbaoming committed
763
              //this.$store.commit('GET_MAATER', --p)
332784038@qq.com's avatar
6  
332784038@qq.com committed
764 765
              this.$modal.msgSuccess("审批通过成功!")
              this.getDetail() // 获得最新详情
lanbaoming's avatar
lanbaoming committed
766 767
            })
            .finally(() => {
332784038@qq.com's avatar
6  
332784038@qq.com committed
768 769
              this.loading = false
            })
lanbaoming's avatar
lanbaoming committed
770
        } else {
lanbaoming's avatar
lanbaoming committed
771 772
          rejectTask(data)
            .then((response) => {
332784038@qq.com's avatar
6  
332784038@qq.com committed
773
              let p = this.matterNum
lanbaoming's avatar
lanbaoming committed
774
              //this.$store.commit('GET_MAATER', --p)
332784038@qq.com's avatar
6  
332784038@qq.com committed
775 776
              this.$modal.msgSuccess("审批不通过成功!")
              this.getDetail() // 获得最新详情
lanbaoming's avatar
lanbaoming committed
777 778
            })
            .finally(() => {
332784038@qq.com's avatar
6  
332784038@qq.com committed
779 780
              this.loading = false
            })
lanbaoming's avatar
lanbaoming committed
781
        }
332784038@qq.com's avatar
6  
332784038@qq.com committed
782
      })
lanbaoming's avatar
lanbaoming committed
783 784 785 786
    },
    /** 处理转派审批人 */
    handleUpdateAssignee(task) {
      // 设置表单
332784038@qq.com's avatar
6  
332784038@qq.com committed
787 788
      this.resetUpdateAssigneeForm()
      this.updateAssignee.form.id = task.id
lanbaoming's avatar
lanbaoming committed
789
      // 设置为打开
332784038@qq.com's avatar
6  
332784038@qq.com committed
790
      this.updateAssignee.open = true
lanbaoming's avatar
lanbaoming committed
791 792 793
    },
    /** 提交转派审批人 */
    submitUpdateAssigneeForm() {
lanbaoming's avatar
lanbaoming committed
794
      this.$refs["updateAssigneeForm"].validate((valid) => {
lanbaoming's avatar
lanbaoming committed
795
        if (!valid) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
796
          return
lanbaoming's avatar
lanbaoming committed
797
        }
lanbaoming's avatar
lanbaoming committed
798
        updateTaskAssignee(this.updateAssignee.form).then((response) => {
332784038@qq.com's avatar
6  
332784038@qq.com committed
799 800
          this.$modal.msgSuccess("转派任务成功!")
          let p = this.matterNum
lanbaoming's avatar
lanbaoming committed
801
          // this.$store.commit('GET_MAATER', --p)
332784038@qq.com's avatar
6  
332784038@qq.com committed
802 803 804 805
          this.updateAssignee.open = false
          this.getDetail() // 获得最新详情
        })
      })
lanbaoming's avatar
lanbaoming committed
806 807 808
    },
    /** 取消转派审批人 */
    cancelUpdateAssigneeForm() {
332784038@qq.com's avatar
6  
332784038@qq.com committed
809 810
      this.updateAssignee.open = false
      this.resetUpdateAssigneeForm()
lanbaoming's avatar
lanbaoming committed
811 812 813 814 815
    },
    /** 重置转派审批人 */
    resetUpdateAssigneeForm() {
      this.updateAssignee.form = {
        id: undefined,
332784038@qq.com's avatar
6  
332784038@qq.com committed
816 817 818
        assigneeUserId: undefined
      }
      this.resetForm("updateAssigneeForm")
lanbaoming's avatar
lanbaoming committed
819 820 821
    },
    /** 处理审批退回的操作 */
    handleDelegate(task) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
822
      this.$modal.msgError("暂不支持【委派】功能,可以使用【转派】替代!")
lanbaoming's avatar
lanbaoming committed
823 824 825
    },
    /** 处理审批退回的操作 */
    handleBack(task) {
332784038@qq.com's avatar
6  
332784038@qq.com committed
826 827 828 829
      this.$modal.msgError("暂不支持【退回】功能!")
    }
  }
}
lanbaoming's avatar
lanbaoming committed
830 831 832 833 834 835 836 837 838 839 840 841
</script>

<style lang="scss" scoped>
.my-process-designer {
  height: calc(100vh - 200px);
}

.box-card {
  width: 100%;
  margin-bottom: 20px;
}
</style>