From 03c04289bada1abfcfbc300fd98c43028d4acff7 Mon Sep 17 00:00:00 2001
From: linwei <872216696@qq.com>
Date: Fri, 19 Jan 2024 11:39:03 +0800
Subject: [PATCH] 代码优化

---
 src/views/work/process/maintenanceFundApply/handle.vue |  739 ++++++++++++++++++++++++++++----------------------------
 1 files changed, 369 insertions(+), 370 deletions(-)

diff --git a/src/views/work/process/maintenanceFundApply/handle.vue b/src/views/work/process/maintenanceFundApply/handle.vue
index 9e1d425..793e916 100644
--- a/src/views/work/process/maintenanceFundApply/handle.vue
+++ b/src/views/work/process/maintenanceFundApply/handle.vue
@@ -1,420 +1,419 @@
 <template>
-    <basic-container>
-        <el-form ref="form" :model="form" :rules="rules" label-width="80px">
-            <el-row type="flex" class="row-bg" justify="end">
-                <el-form-item>
-                    <el-button @click="handleCancel">关闭</el-button>
-                </el-form-item>
-            </el-row>
+  <basic-container>
+    <el-form ref="form" :model="form" :rules="rules" label-width="80px">
+      <el-row type="flex" class="row-bg" justify="end">
+        <el-form-item>
+          <el-button @click="handleCancel">关闭</el-button>
+        </el-form-item>
+      </el-row>
 
-            <el-card shadow="hover">
-                <div slot="header">
-                    <span>审批信息</span>
-                </div>
-                <avue-form :option="option" v-model="form"></avue-form>
-            </el-card>
+      <el-card shadow="hover">
+        <div slot="header">
+          <span>审批信息</span>
+        </div>
+        <avue-form :option="option" v-model="form"></avue-form>
+      </el-card>
 
-            <el-card shadow="hover">
-                <div slot="header">
-                    <span>流程信息</span>
-                </div>
-                <el-row type="flex" class="row-bg">
-                    <el-timeline>
-                        <el-timeline-item :key="flow.id" :timestamp="flow.createTime" v-for="flow in flowList"
-                            placement="top">
-                            <el-card shadow="hover">
-                                <p>{{ flow.assigneeName }} 在 [{{ flow.createTime }}] 开始处理 [{{ flow.historyActivityName }}]
-                                    环节</p>
-                                <p v-if="flow.historyActivityDurationTime !== ''">任务历时 [{{ flow.historyActivityDurationTime
+      <el-card shadow="hover">
+        <div slot="header">
+          <span>流程信息</span>
+        </div>
+        <el-row type="flex" class="row-bg">
+          <el-timeline>
+            <el-timeline-item :key="flow.id" :timestamp="flow.createTime" v-for="flow in flowList" placement="top">
+              <el-card shadow="hover">
+                <p>{{ flow.assigneeName }} 在 [{{ flow.createTime }}] 开始处理 [{{ flow.historyActivityName }}]
+                  环节</p>
+                <p v-if="flow.historyActivityDurationTime !== ''">任务历时 [{{ flow.historyActivityDurationTime
                                 }}]
-                                </p>
-                                <p v-if="flow.comment !== ''">批复意见: [{{ flow.comment }}]</p>
-                                <p v-if="flow.endTime !== ''">结束时间: [{{ flow.endTime }}]</p>
-                            </el-card>
-                        </el-timeline-item>
-                    </el-timeline>
-                </el-row>
-            </el-card>
-            <el-card shadow="hover">
-                <div slot="header">
-                    <span>流程跟踪</span>
-                </div>
-                <el-row class="row-bg">
-                    <flow-design :is-display="true" :process-instance-id="processInstanceId"></flow-design>
-                </el-row>
-            </el-card>
-        </el-form>
+                </p>
+                <p v-if="flow.comment !== ''">批复意见: [{{ flow.comment }}]</p>
+                <p v-if="flow.endTime !== ''">结束时间: [{{ flow.endTime }}]</p>
+              </el-card>
+            </el-timeline-item>
+          </el-timeline>
+        </el-row>
+      </el-card>
+      <el-card shadow="hover">
+        <div slot="header">
+          <span>流程跟踪</span>
+        </div>
+        <el-row class="row-bg">
+          <flow-design :is-display="true" :process-instance-id="processInstanceId"></flow-design>
+        </el-row>
+      </el-card>
+    </el-form>
 
-        <!-- <div style="">
+    <!-- <div style="">
       <el-button type="primary" @click="handleAgree">同意</el-button>
       <el-button type="danger" @click="handleDisagree">驳回</el-button>
     </div> -->
 
-        <div style="text-align: center;
+    <div style="text-align: center;
     position: fixed;
     left: 0;
     right: 0;
     bottom: 10px;">
-            <el-button type="primary" @click="handleAgree">同意</el-button>
-            <el-button type="danger" @click="handleDisagree">驳回</el-button>
-        </div>
+      <el-button type="primary" @click="handleAgree">同意</el-button>
+      <el-button type="danger" @click="handleDisagree">驳回</el-button>
+    </div>
 
-    </basic-container>
+  </basic-container>
 </template>
 
 <script>
-import {
+  import {
     historyFlowList,
     leaveDetail
-} from "@/api/work/process"
+  } from "@/api/work/process"
 
-import {
+  import {
     getList,
     remove,
     update,
     add,
     getPropertyCapitalApply
-} from "@/api/property/propertyCapitalApply"
-import {
+  } from "@/api/property/propertyCapitalApply"
+  import {
     completeTask
-} from "@/api/work/work"
-import website from '@/config/website'
+  } from "@/api/work/work"
+  import website from '@/config/website'
 
-export default {
-    data () {
-        return {
-            taskId: '',
-            businessId: '',
-            processInstanceId: '',
-            src: '',
-            flowList: [],
-            form: {
-                flow: {
-                    assigneeName: '',
-                },
-                startTime: '',
-                endTime: '',
-                reason: '',
+  export default {
+    data() {
+      return {
+        taskId: '',
+        businessId: '',
+        processInstanceId: '',
+        src: '',
+        flowList: [],
+        form: {
+          flow: {
+            assigneeName: '',
+          },
+          startTime: '',
+          endTime: '',
+          reason: '',
+        },
+        option: {
+          height: "auto",
+          calcHeight: 54,
+          dialogWidth: 1150,
+          tip: false,
+          searchShow: true,
+          searchMenuSpan: 3,
+          menuWidth: 350,
+          border: true,
+          //stripe:true,
+          submitBtn: false,
+          emptyBtn: false,
+          index: true,
+          viewBtn: true,
+          selection: true,
+          dialogClickModal: false,
+          column: [{
+              label: "小区",
+              prop: "districtId",
+              searchSpan: 5,
+              search: true,
+              type: 'tree',
+              dicUrl: `/api/blade-district/district/getDistrictTree`,
+              props: {
+                label: "name",
+                value: "id"
+              },
+              defaultExpandedKeys: ["361102003"],
+              span: 12,
+              labelWidth: 120,
+              width: 220,
+              overHidden: true,
+              rules: [{
+                required: true,
+                message: "请选择小区",
+                trigger: "blur",
+              }, ],
+              disabled: true
             },
-            option: {
-                height: "auto",
-                calcHeight: 54,
-                dialogWidth: 1150,
-                tip: false,
-                searchShow: true,
-                searchMenuSpan: 3,
-                menuWidth: 350,
-                border: true,
-                //stripe:true,
-                submitBtn: false,
-                emptyBtn: false,
-                index: true,
-                viewBtn: true,
-                selection: true,
-                dialogClickModal: false,
-                column: [{
-                    label: "小区",
-                    prop: "districtId",
-                    searchSpan: 5,
-                    search: true,
-                    type: 'tree',
-                    dicUrl: `/api/blade-district/district/getDistrictTree`,
-                    props: {
-                        label: "name",
-                        value: "id"
-                    },
-                    defaultExpandedKeys: ["361102003"],
-                    span: 12,
-                    labelWidth: 120,
-                    width: 220,
-                    overHidden: true,
-                    rules: [{
-                        required: true,
-                        message: "请选择小区",
-                        trigger: "blur",
-                    },],
-                    disabled: true
-                },
-                {
-                    label: '维修项目名称',
-                    prop: 'name',
-                    searchLabelWidth: 120,
-                    searchSpan: 5,
-                    search: true,
-                    span: 12,
-                    labelWidth: 140,
-                    rules: [{
-                        required: true,
-                        message: "请输入维修项目名称",
-                        trigger: "blur",
-                    },],
-                    disabled: true
-                },
-                {
-                    label: "预计开工时间",
-                    prop: "runTime",
-                    span: 12,
-                    labelWidth: 140,
-                    type: "date",
-                    format: "yyyy-MM-dd",
-                    valueFormat: "yyyy-MM-dd",
-                    rules: [{
-                        required: true,
-                        message: "请选择合同开始时间",
-                        trigger: "blur",
-                    },],
-                    disabled: true
-                },
-                {
-                    label: "预计竣工时间",
-                    prop: "completedTime",
-                    labelWidth: 140,
-                    span: 12,
-                    type: "date",
-                    format: "yyyy-MM-dd",
-                    valueFormat: "yyyy-MM-dd",
-                    rules: [{
-                        required: true,
-                        message: "请选择合同结束时间",
-                        trigger: "blur",
-                    },],
-                    disabled: true
-                },
-                {
-                    label: "项目分摊方式",
-                    prop: "allocationWay",
-                    labelWidth: 140,
-                    value: '按建筑面积分摊',
-                    span: 14,
-                    row: true,
-                    disabled: true
-                },
-                {
-                    label: '联系人',
-                    prop: 'linkman',
-                    span: 12,
-                    labelWidth: 120,
-                    search: true,
-                    searchSpan: 4,
-                    rules: [{
-                        required: true,
-                        message: "请输入联系人",
-                        trigger: "blur",
-                    },],
-                    disabled: true
-                },
-                {
-                    label: '联系方式',
-                    prop: 'linkPhone',
-                    span: 12,
-                    labelWidth: 140,
-                    rules: [{
-                        required: true,
-                        message: "请输入联系方式",
-                        trigger: "blur",
-                    },],
-                    disabled: true
-                },
-                {
-                    label: "项目预算总金额(元)",
-                    prop: "budgetAmount",
-                    span: 12,
-                    hide: true,
-                    labelWidth: 140,
-                    type: 'number',
-                    precision: 2,
-                    value: '0.00',
-                    disabled: true
-                },
-                {
-                    label: "实际预算金额(元)",
-                    prop: "actualAmount",
-                    span: 12,
-                    hide: true,
-                    labelWidth: 140,
-                    type: 'number',
-                    precision: 2,
-                    value: '0.00',
-                    disabled: true
-                },
-                {
-                    label: "自筹金额(元)",
-                    prop: "selfAmount",
-                    span: 12,
-                    hide: true,
-                    labelWidth: 140,
-                    type: 'number',
-                    precision: 2,
-                    value: '0.00',
-                    disabled: true
-                },
-                {
-                    label: "预算应拨付金额(元)",
-                    prop: "budgetAppropriateAmount",
-                    span: 12,
-                    hide: true,
-                    labelWidth: 140,
-                    type: 'number',
-                    precision: 2,
-                    value: '0.00',
-                    disabled: true
-                },
-                {
-                    label: "项目摘要",
-                    span: 24,
-                    hide: true,
-                    prop: "projectDigest",
-                    placeholder: "例如:“XX小区XX栋XX设施设备维修,总的预算金额是X,是否含有审价,本次维修涉及范围共XX户,总面积的建筑面积为XX平方米”",
-                    labelWidth: 140,
-                    type: "textarea",
-                    disabled: true
-                },
-                {
-                    label: "项目进度描述",
-                    span: 24,
-                    hide: true,
-                    prop: "projectDescribe",
-                    labelWidth: 140,
-                    type: "textarea",
-                    disabled: true
-                }, {
-                    label: "批复意见",
-                    span: 24,
-                    hide: true,
-                    prop: "comment",
-                    labelWidth: 140,
-                    type: "textarea",
-                    rules: [{
-                        required: true,
-                        message: "请输入批复意见",
-                        trigger: "blur",
-                    },],
-                },
-                {
-                    label: '施工方案附件',
-                    prop: 'constructionSchemeUrls',
-                    type: 'upload',
-                    listType: 'picture-img',
-                    span: 24,
-                    hide: true,
-                    labelWidth: 140,
-                    multiple: true,
-                    // showFileList: true,
-                    propsHttp: {
-                        res: 'data',
-                        name: "originalName",
-                        url: "link"
-                    },
-                    action: '/api/blade-resource/oss/endpoint/put-file-attach',
-                    rules: [{
-                        required: true,
-                        message: "请上传施工方案",
-                        trigger: "blur",
-                    },],
-                }
-                ],
+            {
+              label: '维修项目名称',
+              prop: 'name',
+              searchLabelWidth: 120,
+              searchSpan: 5,
+              search: true,
+              span: 12,
+              labelWidth: 140,
+              rules: [{
+                required: true,
+                message: "请输入维修项目名称",
+                trigger: "blur",
+              }, ],
+              disabled: true
+            },
+            {
+              label: "预计开工时间",
+              prop: "runTime",
+              span: 12,
+              labelWidth: 140,
+              type: "date",
+              format: "yyyy-MM-dd",
+              valueFormat: "yyyy-MM-dd",
+              rules: [{
+                required: true,
+                message: "请选择合同开始时间",
+                trigger: "blur",
+              }, ],
+              disabled: true
+            },
+            {
+              label: "预计竣工时间",
+              prop: "completedTime",
+              labelWidth: 140,
+              span: 12,
+              type: "date",
+              format: "yyyy-MM-dd",
+              valueFormat: "yyyy-MM-dd",
+              rules: [{
+                required: true,
+                message: "请选择合同结束时间",
+                trigger: "blur",
+              }, ],
+              disabled: true
+            },
+            {
+              label: "项目分摊方式",
+              prop: "allocationWay",
+              labelWidth: 140,
+              value: '按建筑面积分摊',
+              span: 12,
+              row: true,
+              disabled: true
+            },
+            {
+              label: '联系人',
+              prop: 'linkman',
+              span: 12,
+              labelWidth: 120,
+              search: true,
+              searchSpan: 4,
+              rules: [{
+                required: true,
+                message: "请输入联系人",
+                trigger: "blur",
+              }, ],
+              disabled: true
+            },
+            {
+              label: '联系方式',
+              prop: 'linkPhone',
+              span: 12,
+              labelWidth: 140,
+              rules: [{
+                required: true,
+                message: "请输入联系方式",
+                trigger: "blur",
+              }, ],
+              disabled: true
+            },
+            {
+              label: "项目预算总金额(元)",
+              prop: "budgetAmount",
+              span: 12,
+              hide: true,
+              labelWidth: 140,
+              type: 'number',
+              precision: 2,
+              value: '0.00',
+              disabled: true
+            },
+            {
+              label: "实际预算金额(元)",
+              prop: "actualAmount",
+              span: 12,
+              hide: true,
+              labelWidth: 140,
+              type: 'number',
+              precision: 2,
+              value: '0.00',
+              disabled: true
+            },
+            {
+              label: "自筹金额(元)",
+              prop: "selfAmount",
+              span: 12,
+              hide: true,
+              labelWidth: 140,
+              type: 'number',
+              precision: 2,
+              value: '0.00',
+              disabled: true
+            },
+            {
+              label: "预算应拨付金额(元)",
+              prop: "budgetAppropriateAmount",
+              span: 12,
+              hide: true,
+              labelWidth: 140,
+              type: 'number',
+              precision: 2,
+              value: '0.00',
+              disabled: true
+            },
+            {
+              label: "项目摘要",
+              span: 24,
+              hide: true,
+              prop: "projectDigest",
+              placeholder: "例如:“XX小区XX栋XX设施设备维修,总的预算金额是X,是否含有审价,本次维修涉及范围共XX户,总面积的建筑面积为XX平方米”",
+              labelWidth: 140,
+              type: "textarea",
+              disabled: true
+            },
+            {
+              label: "项目进度描述",
+              span: 24,
+              hide: true,
+              prop: "projectDescribe",
+              labelWidth: 140,
+              type: "textarea",
+              disabled: true
+            }, {
+              label: "批复意见",
+              span: 24,
+              hide: true,
+              prop: "comment",
+              labelWidth: 140,
+              type: "textarea",
+              rules: [{
+                required: true,
+                message: "请输入批复意见",
+                trigger: "blur",
+              }, ],
+            },
+            {
+              label: '施工方案附件',
+              prop: 'constructionSchemeUrls',
+              type: 'upload',
+              listType: 'picture-img',
+              span: 24,
+              hide: true,
+              labelWidth: 140,
+              multiple: true,
+              // showFileList: true,
+              propsHttp: {
+                res: 'data',
+                name: "originalName",
+                url: "link"
+              },
+              action: '/api/blade-resource/oss/endpoint/put-file-attach',
+              rules: [{
+                required: true,
+                message: "请上传施工方案",
+                trigger: "blur",
+              }, ],
             }
+          ],
         }
+      }
     },
-    created () {
+    created() {
+      this.init()
+    },
+    beforeRouteUpdate(to, from, next) {
+      // 在当前路由改变,但是该组件被复用时调用
+      // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候
+      // 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用
+      // 可以访问组件实例 `this`
+      if (to.fullPath !== from.fullPath) {
+        next()
         this.init()
-    },
-    beforeRouteUpdate (to, from, next) {
-        // 在当前路由改变,但是该组件被复用时调用
-        // 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候
-        // 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用
-        // 可以访问组件实例 `this`
-        if (to.fullPath !== from.fullPath) {
-            next()
-            this.init()
-        }
+      }
     },
     methods: {
-        init () {
-            this.taskId = this.$route.params.taskId
-            this.processInstanceId = this.$route.params.processInstanceId
-            this.businessId = this.$route.params.businessId
-            historyFlowList(this.processInstanceId).then(res => {
-                const data = res.data
-                if (data.success) {
-                    this.flowList = data.data
-                }
-            })
-            getPropertyCapitalApply(this.businessId).then(res => {
-                const data = res.data
-                if (data.success) {
-                    data.data.constructionSchemeUrls = website.minioUrl + data.data.constructionSchemeUrls
-                    this.form = data.data
-                }
-            })
-        },
-        handleAgree () {
-            if (!this.form.comment) {
-                this.$message.warning('请先填写批复意见')
-                return
-            }
-            const params = {
-                taskId: this.taskId,
-                processInstanceId: this.processInstanceId,
-                flag: 'ok',
-                comment: this.form.comment,
-            }
-            completeTask(params).then(res => {
-                const data = res.data
-                if (data.success) {
-                    this.$message.success(data.msg)
-                    this.$router.$avueRouter.closeTag()
-                    this.$router.push({
-                        path: `/work/todo`
-                    })
-                } else {
-                    this.$message.error(data.msg || '提交失败')
-                }
-            })
-        },
-        handleDisagree () {
-            if (!this.form.comment) {
-                this.$message.warning('请先填写批复意见')
-                return
-            }
-            const params = {
-                taskId: this.taskId,
-                processInstanceId: this.processInstanceId,
-                comment: this.form.comment,
-            }
-            completeTask(params).then(res => {
-                const data = res.data
-                if (data.success) {
-                    this.$message.success(data.msg)
-                    this.$router.$avueRouter.closeTag()
-                    this.$router.push({
-                        path: `/work/todo`
-                    })
-                } else {
-                    this.$message.error(data.msg || '提交失败')
-                }
-            })
-        },
-        handleCancel () {
+      init() {
+        this.taskId = this.$route.params.taskId
+        this.processInstanceId = this.$route.params.processInstanceId
+        this.businessId = this.$route.params.businessId
+        historyFlowList(this.processInstanceId).then(res => {
+          const data = res.data
+          if (data.success) {
+            this.flowList = data.data
+          }
+        })
+        getPropertyCapitalApply(this.businessId).then(res => {
+          const data = res.data
+          if (data.success) {
+            data.data.constructionSchemeUrls = website.minioUrl + data.data.constructionSchemeUrls
+            this.form = data.data
+          }
+        })
+      },
+      handleAgree() {
+        if (!this.form.comment) {
+          this.$message.warning('请先填写批复意见')
+          return
+        }
+        const params = {
+          taskId: this.taskId,
+          processInstanceId: this.processInstanceId,
+          flag: 'ok',
+          comment: this.form.comment,
+        }
+        completeTask(params).then(res => {
+          const data = res.data
+          if (data.success) {
+            this.$message.success(data.msg)
             this.$router.$avueRouter.closeTag()
             this.$router.push({
-                path: `/work/todo`
+              path: `/work/todo`
             })
+          } else {
+            this.$message.error(data.msg || '提交失败')
+          }
+        })
+      },
+      handleDisagree() {
+        if (!this.form.comment) {
+          this.$message.warning('请先填写批复意见')
+          return
         }
+        const params = {
+          taskId: this.taskId,
+          processInstanceId: this.processInstanceId,
+          comment: this.form.comment,
+        }
+        completeTask(params).then(res => {
+          const data = res.data
+          if (data.success) {
+            this.$message.success(data.msg)
+            this.$router.$avueRouter.closeTag()
+            this.$router.push({
+              path: `/work/todo`
+            })
+          } else {
+            this.$message.error(data.msg || '提交失败')
+          }
+        })
+      },
+      handleCancel() {
+        this.$router.$avueRouter.closeTag()
+        this.$router.push({
+          path: `/work/todo`
+        })
+      }
     }
-}
+  }
 </script>
 
 <style scoped>
-.container {
+  .container {
     position: relative;
     /* 确保按钮相对于该元素定位 */
-}
+  }
 
-#myButton {
+  #myButton {
     position: fixed;
     bottom: 0;
     left: 50%;
     transform: translateX(-50%);
-}
+  }
 </style>
\ No newline at end of file

--
Gitblit v1.9.3