From 4522ab3fe8bd45ee753ef187448c1e884bbc601f Mon Sep 17 00:00:00 2001
From: shuishen <1109946754@qq.com>
Date: Thu, 18 Apr 2024 11:09:27 +0800
Subject: [PATCH] Merge branch 'master' of http://s16s652780.51mypc.cn:49896/r/jczz_web

---
 src/views/property/propertyCapitalApply.vue |  635 +++++++++++++++++++++++++++++++++++++++++++++++++++++----
 1 files changed, 588 insertions(+), 47 deletions(-)

diff --git a/src/views/property/propertyCapitalApply.vue b/src/views/property/propertyCapitalApply.vue
index 57a1d4c..3c66426 100644
--- a/src/views/property/propertyCapitalApply.vue
+++ b/src/views/property/propertyCapitalApply.vue
@@ -5,12 +5,32 @@
       v-model="form" :permission="permissionList" @row-update="rowUpdate" @row-save="rowSave" :before-open="beforeOpen"
       @search-change="searchChange" @search-reset="searchReset" @selection-change="selectionChange"
       @current-change="currentChange" @size-change="sizeChange" @refresh-change="refreshChange" @on-load="onLoad">
+      <template slot-scope="{ row, size, index }" slot="voteForm">
+        <div>{{ topicTitle }}</div>
+        <el-table :data="topictData" v-if="topictData.length">
+          <el-table-column width="300" property="optionContent" label="选项"
+            label-class-name="workOrderStyle"></el-table-column>
+          <el-table-column width="300" property="number" label="人数" label-class-name="workOrderStyle">
+          </el-table-column>
+          <el-table-column width="300">
+            <template slot-scope="scope">
+              <el-button slot="reference" type="primary" size="mini" @click="openUserPopup(scope.row, 1)">详情</el-button>
+            </template>
+          </el-table-column>
+        </el-table>
+      </template>
+
+
 
       <template slot-scope="{ row, size, index }" slot="menu">
-        <el-button :size="size" type="text" v-if="row.applyStatus === 4" @click="handleWork(row)">调整申请
-        </el-button>
+
         <el-button :size="size" type="text" @click="goDetail(row)">查看申请
         </el-button>
+
+        <el-button :size="size" type="text" v-if="row.applyStatus === 4" @click="handleWork(row)">调整申请
+        </el-button>
+        <!-- <el-button :size="size" type="text" @click="goDetail(row)">查看申请
+        </el-button> -->
         <!-- <el-button :size="size" type="text" @click="goDetail(row)">删 除
         </el-button> -->
       </template>
@@ -22,10 +42,43 @@
       <!-- <template slot="constructionSchemeUrlsType" slot-scope="{file}">
         <span>{{ file }}</span>
       </template> -->
+
+      <template slot-scope="{row, size}" slot="linkPhone">
+        <el-button :size="size" type="text" @click="showStringDispose(row, 'linkPhoneflag')"
+          v-text="textDispose(row, 'linkPhoneflag', 'linkPhone')">
+        </el-button>
+      </template>
+      <!-- <template slot="constructionSchemeUrlsType" slot-scope="{file}">
+        <span>{{ file }}</span>
+      </template> -->
     </avue-crud>
+
+
+    <el-drawer append-to-body :visible.sync="showDialog" width="80%" :modal="false">
+      <span slot="title">{{ topicTitle }}</span>
+      <avue-crud :option="optionList" :data="topictData" ref="crud2">
+        <!-- <template #icon="scope">
+          <i :class="scope.row.icon" style="font-size:14px"></i>
+        </template> -->
+        <template slot-scope="{row}" slot="number">
+          <span style="margin-right:10px;">1</span>
+          <el-button slot="reference" type="primary" size="mini" @click="openUserPopup(row, 1)">详情</el-button>
+          <!-- <el-popover placement="right" width="400" trigger="click">
+            <el-table :data="gridData">
+              <el-table-column width="150" property="date" label="日期"></el-table-column>
+              <el-table-column width="100" property="name" label="姓名"></el-table-column>
+              <el-table-column width="300" property="address" label="地址"></el-table-column>
+            </el-table>
+            <el-button slot="reference" type="primary"  size="mini">详情</el-button>
+          </el-popover> -->
+        </template>
+      </avue-crud>
+    </el-drawer>
+
+    <deitDiscussion ref="DeitDiscussion">
+    </deitDiscussion>
   </basic-container>
 </template>
-
 <script>
   import {
     getList,
@@ -39,9 +92,20 @@
   } from "vuex"
   import website from '@/config/website'
   import func from "@/util/func"
+  import {
+    getLists,
+  } from "@/api/discuss/topics"
+
+  import deitDiscussion from "./components/deitDiscussion"
+
+
   export default {
+    components: {
+      deitDiscussion
+    },
     data() {
       return {
+        showDialog: false,
         form: {
           // constructionSchemeUrls:[]
         },
@@ -59,7 +123,7 @@
           searchLabelWidth: 96,
           searchShow: true,
           searchMenuSpan: 3,
-          menuWidth: 140,
+          menuWidth: 210,
 
           height: "auto",
           calcHeight: 54,
@@ -73,6 +137,7 @@
           delBtn: false,
           selection: true,
           dialogClickModal: false,
+          viewBtnText: "查看申请",
           column: [{
               width: 220,
               overHidden: true,
@@ -83,6 +148,7 @@
               prop: "districtName",
               search: true,
               searchSpan: 4,
+              searchLabelWidth: 76,
               rules: [{
                 required: true,
                 message: "请输入小区名称",
@@ -97,7 +163,8 @@
               prop: "districtId",
               search: false,
               type: 'tree',
-              dicUrl: `/api/blade-district/district/getDistrictTree`,
+              dicUrl: `/api/blade-district/district/getDistrictTree?filterFlag=1`,
+              cascader: ['articleId'],
               props: {
                 label: "name",
                 value: "id"
@@ -124,6 +191,27 @@
                 message: "请输入维修项目名称",
                 trigger: "blur",
               }, ],
+            },
+            {
+              width: 110,
+              label: "所属街道",
+              addDisplay: false,
+              editDisplay: false,
+              viewDisplay: false,
+              prop: "streetName",
+              search: true,
+              searchSpan: 4
+            },
+            {
+              width: 156,
+              overHidden: true,
+              label: "所属社区",
+              addDisplay: false,
+              editDisplay: false,
+              viewDisplay: false,
+              prop: "communityName",
+              search: true,
+              searchSpan: 4
             },
             {
               width: 100,
@@ -154,11 +242,16 @@
               }, ],
             },
             {
-              label: "项目分摊方式",
-              prop: "allocationWay",
-              value: '按建筑面积分摊',
-              span: 14,
+              label: "楼栋",
+              prop: "buildingName",
+              value: '',
+              span: 12,
               row: true,
+              rules: [{
+                required: true,
+                message: "请输入楼栋",
+                trigger: "blur",
+              }, ],
             },
             {
               width: 110,
@@ -206,7 +299,7 @@
                 label: "街道",
                 value: 2,
               }, {
-                label: "住建局",
+                label: "区住建局",
                 value: 3,
               }, {
                 label: "调整申请",
@@ -217,6 +310,9 @@
               }, {
                 label: "审核不通过",
                 value: 6,
+              }, {
+                label: "上饶住建局",
+                value: 7,
               }]
             },
             {
@@ -256,6 +352,52 @@
               value: '0.00'
             },
             {
+              display: false,
+              hide: true,
+              parent: false,
+              label: "投票结果",
+              prop: "articleId",
+              search: false,
+              viewDisabled: false,
+              type: 'select',
+              dicUrl: `/api/blade-article/article/getArticleByDistrictId?type=4&eventType=1&districtId={{districtId}}`,
+              // slot: true,
+              formslot: true,
+              cascader: ['vote'],
+              props: {
+                label: "title",
+                value: "id"
+              },
+              defaultExpandedKeys: ["361102003"],
+              span: 12,
+              width: 260,
+              rules: [{
+                required: true,
+                message: "请选择议事",
+                trigger: "blur",
+              }, ],
+              change: (val) => {
+                console.log("val===>", val)
+                // console.log("form===>",this.form)
+                if (val.value && !this.form.id) {
+                  this.articleRange = val.articleRange;
+                  // this.showDialog = true;
+                  // this.getDetail(val.value, val.articleRange)
+                }
+
+              }
+            },
+
+            {
+              display: false,
+              span: 24,
+              hide: true,
+              prop: "vote",
+              formslot: true,
+              label: "投票详情"
+            },
+
+            {
               label: "项目摘要",
               span: 24,
               hide: true,
@@ -270,32 +412,333 @@
               prop: "projectDescribe",
               type: "textarea"
             },
+            // {
+            //   label: '施工方案附件',
+            //   prop: 'constructionSchemeUrls',
+            //   type: 'upload',
+            //   span: 24,
+            //   hide: true,
+            //   multiple: true,
+            //   listType: "text",
+            //   propsHttp: {
+            //     res: 'data',
+            //     name: "name",
+            //     url: "link"
+            //   },
+            //   action: '/api/blade-resource/oss/endpoint/put-file-attach',
+            //   rules: [{
+            //     required: true,
+            //     message: "请上传施工方案",
+            //     trigger: "blur",
+            //   }]
+            // },
             {
-              label: '施工方案附件',
-              prop: 'constructionSchemeUrls',
-              type: 'upload',
+
+              label: "维修资金使用申请审批表",
+              offset: 2,
+              labelPosition: "top",
+              prop: "file1",
+              type: "upload",
+              listType: "text",
+              action: "/api/blade-resource/oss/endpoint/put-file-attach",
+              propsHttp: {
+                res: "data",
+                name: 'name',
+                url: "link",
+              },
               span: 24,
               hide: true,
-              multiple: true,
-              // showFileList: true,
-              propsHttp: {
-                res: 'data',
-                name: "originalName",
-                url: "link"
-              },
-              action: '/api/blade-resource/oss/endpoint/put-file-attach',
               rules: [{
                 required: true,
-                message: "请上传施工方案",
+                message: "请上传文件",
                 trigger: "blur",
-              }, ],
-            }
+              }],
+            },
+            {
+
+              label: "申请使用维修资金的报告、附维修部位彩色照片、业委会(物管会)会议纪要(社区意见)",
+              offset: 2,
+              labelPosition: "top",
+              prop: "file2",
+              type: "upload",
+              listType: "text",
+              action: "/api/blade-resource/oss/endpoint/put-file-attach",
+              propsHttp: {
+                res: "data",
+                name: 'name',
+                url: "link",
+              },
+              span: 24,
+              hide: true,
+              rules: [{
+                required: true,
+                message: "请上传文件",
+                trigger: "blur",
+              }],
+            },
+            {
+
+              label: "公示单,现场勘察图片、公示照片(公示期7天)",
+              offset: 2,
+              labelPosition: "top",
+              prop: "file3",
+              type: "upload",
+              listType: "text",
+              action: "/api/blade-resource/oss/endpoint/put-file-attach",
+              propsHttp: {
+                res: "data",
+                name: 'name',
+                url: "link",
+              },
+              span: 24,
+              hide: true,
+              rules: [{
+                required: true,
+                message: "请上传文件",
+                trigger: "blur",
+              }],
+            },
+            {
+
+              label: "维修单位出具的工程款发票(验收合格后以竣工决算审核报告审定金额开具)",
+              offset: 2,
+              labelPosition: "top",
+              prop: "file4",
+              type: "upload",
+              listType: "text",
+              action: "/api/blade-resource/oss/endpoint/put-file-attach",
+              propsHttp: {
+                res: "data",
+                name: 'name',
+                url: "link",
+              },
+              span: 24,
+              hide: true,
+              rules: [{
+                required: true,
+                message: "请上传文件",
+                trigger: "blur",
+              }],
+            },
+            {
+              label: "应急维修需提供专业机构出具的检验检测报告或(乡镇人民政府)街道办事处现场核实意见",
+              offset: 2,
+              labelPosition: "top",
+              prop: "file5",
+              type: "upload",
+              listType: "text",
+              action: "/api/blade-resource/oss/endpoint/put-file-attach",
+              propsHttp: {
+                res: "data",
+                name: 'name',
+                url: "link",
+              },
+              span: 24,
+              hide: true,
+              rules: [{
+                required: true,
+                message: "请上传文件",
+                trigger: "blur",
+              }],
+            },
+            {
+
+              label: "业主签名表或线上表决记录(应急情况不提供)",
+              offset: 2,
+              labelPosition: "top",
+              prop: "file6",
+              type: "upload",
+              listType: "text",
+              action: "/api/blade-resource/oss/endpoint/put-file-attach",
+              propsHttp: {
+                res: "data",
+                name: 'name',
+                url: "link",
+              },
+              span: 24,
+              hide: true,
+              rules: [{
+                required: true,
+                message: "请上传文件",
+                trigger: "blur",
+              }],
+            },
+            {
+              label: "政府采购资料",
+              offset: 2,
+              labelPosition: "top",
+              prop: "file7",
+              type: "upload",
+              listType: "text",
+              action: "/api/blade-resource/oss/endpoint/put-file-attach",
+              propsHttp: {
+                res: "data",
+                name: 'name',
+                url: "link",
+              },
+              span: 24,
+              hide: true,
+              rules: [{
+                required: true,
+                message: "请上传文件",
+                trigger: "blur",
+              }],
+            },
+            {
+
+              label: "维修和更新、改造方案、维修项目的协议或合同",
+              offset: 2,
+              labelPosition: "top",
+              prop: "file8",
+              type: "upload",
+              listType: "text",
+              action: "/api/blade-resource/oss/endpoint/put-file-attach",
+              propsHttp: {
+                res: "data",
+                name: 'name',
+                url: "link",
+              },
+              span: 24,
+              hide: true,
+              rules: [{
+                required: true,
+                message: "请上传文件",
+                trigger: "blur",
+              }],
+            },
+            {
+
+              label: "维修改造工程竣工验收单一式两份(维修完工需经申请人签字);维修项目签证单(超出预算清单内容的需出具签证单)",
+              offset: 2,
+              labelPosition: "top",
+              prop: "file9",
+              type: "upload",
+              listType: "text",
+              action: "/api/blade-resource/oss/endpoint/put-file-attach",
+              propsHttp: {
+                res: "data",
+                name: 'name',
+                url: "link",
+              },
+              span: 24,
+              hide: true,
+              rules: [{
+                required: true,
+                message: "请上传文件",
+                trigger: "blur",
+              }],
+            },
+            {
+
+              label: "维修项目决算、造价机构出具的决算审价报告",
+              offset: 2,
+              labelPosition: "top",
+              prop: "file10",
+              type: "upload",
+              listType: "text",
+              action: "/api/blade-resource/oss/endpoint/put-file-attach",
+              propsHttp: {
+                res: "data",
+                name: 'name',
+                url: "link",
+              },
+              span: 24,
+              hide: true,
+              rules: [{
+                required: true,
+                message: "请上传文件",
+                trigger: "blur",
+              }],
+            },
+            {
+
+              label: "业主委员会情况登记表;经办人或代理人证件(复印件),复印件上签名、联系电话",
+              offset: 2,
+              labelPosition: "top",
+              prop: "file11",
+              type: "upload",
+              listType: "text",
+              action: "/api/blade-resource/oss/endpoint/put-file-attach",
+              propsHttp: {
+                res: "data",
+                name: 'name',
+                url: "link",
+              },
+              span: 24,
+              hide: true,
+              rules: [{
+                required: true,
+                message: "请上传文件",
+                trigger: "blur",
+              }],
+            },
           ],
         },
         data: [],
+
+        optionList: {
+          header: false,
+          menu: false,
+          headerAlign: 'center',
+          align: 'center',
+          border: true,
+          addBtn: false,
+          editBtn: false,
+          delBtn: false,
+          defaultExpandAll: true,
+          rowKey: 'id',
+          rowParentKey: 'parentId',
+          column: [{
+              label: '选项内容',
+              prop: 'optionContent',
+            },
+            {
+              label: '人数',
+              prop: 'number',
+              slot: true,
+            }
+          ]
+        },
+        topictData: [],
+        topicTitle: "",
+        articleRange: ""
       }
     },
-    watch: {},
+    watch: {
+      // 'form.districtId':{
+      //   handler(newVal,oldVal){
+      //     console.log("val===>", newVal)
+      //     if(newVal){
+      //         this.showDialog = true;
+      //       }
+      //   },
+      //   deep: true,
+      // 	immediate: true
+      // }
+
+      'form.districtId': {
+        handler(newData) {
+          const column = this.findObject(this.option.column, "articleId")
+          if (newData) {
+            column.display = true;
+          } else {
+            column.display = false
+          }
+        }
+      },
+      'form.articleId': {
+        handler(newData) {
+          console.log("data===>", newData)
+          this.getDetail(this.form.articleId, this.articleRange)
+          const column = this.findObject(this.option.column, "vote")
+          if (newData) {
+            column.display = true;
+          } else {
+            column.display = false
+          }
+        }
+      },
+    },
     computed: {
       ...mapGetters(["permission", "userInfo"]),
       permissionList() {
@@ -313,29 +756,100 @@
         })
         return ids.join(",")
       },
+
+      textDispose() {
+        return (row, flag, type) => {
+          if (row[flag] || row[type] == null) {
+            return row[type]
+          } else {
+            if (type == 'principalIdCard') {
+              return row[type].replace(/^(.{6})(?:\d+)(.{4})$/, "$1******$2")
+            } else {
+              return row[type].replace(/^(.{3})(?:\d+)(.{4})$/, "$1****$2")
+            }
+          }
+        }
+      }
     },
     methods: {
+
+
+      rowView() {
+        this.showDialog = false;
+      },
+
+
+      showStringDispose(row, type) {
+        row[type] = !row[type]
+      },
+
       handleWork(row) {
         this.$router.push({
-          path: `/work/process/maintenanceFundApply/edit/${row.taskId}/${row.processInstanceId}/${row.id}`
+          path: `/property/process/maintenanceFundApply/edit/${row.taskId}/${row.processInstanceId}/${row.id}`
         })
       },
       goDetail(row) {
         this.$router.push({
-          path: `/work/process/maintenanceFundApply/detail/${row.processInstanceId}/${row.id}`
+          path: `/property/process/maintenanceFundApply/detail/${row.processInstanceId}/${row.id}`
         })
       },
-      rowSave(row, done, loading) {
-        row.constructionSchemeUrls = func.join(row.constructionSchemeUrls)
-        if (row.constructionSchemeUrls.length > 0) {
-          var urls = []
-          var split = row.constructionSchemeUrls.split(",")
-          split.forEach(url => {
-            var names = url.split("jczz/")
-            urls.push(names[1])
-          })
-          row.constructionSchemeUrls = urls.join(",")
+
+      setFile(fileObj) {
+        for (let i in fileObj) {
+          fileObj[i] = func.join(fileObj[i])
+          if (fileObj[i].length > 0) {
+            var urls = []
+            var split = fileObj[i].split(",")
+            split.forEach(url => {
+              var names = url.split("jczz/")
+              urls.push(names[1])
+            })
+            fileObj[i] = urls.join(",")
+          }
         }
+        return fileObj;
+      },
+
+      rowSave(row, done, loading) {
+        // row.constructionSchemeUrls = func.join(row.constructionSchemeUrls)
+        // if (row.constructionSchemeUrls.length > 0) {
+        //   var urls = []
+        //   var split = row.constructionSchemeUrls.split(",")
+        //   split.forEach(url => {
+        //     var names = url.split("jczz/")
+        //     urls.push(names[1])
+        //   })
+        //   row.constructionSchemeUrls = urls.join(",")
+        // }
+
+        let keys = ["file1", "file2", "file3", "file4", "file5", "file6", "file7", "file8", "file9", "file10", "file11"]
+        let files = {};
+        for (let i in row) {
+          if (keys.indexOf(i) != -1) {
+
+            files[i] = row[i];
+          }
+        }
+        for (let k in files) {
+          files[k] = func.join(files[k])
+          if (files[k].length) {
+            let urls = [];
+            let split = files[k].split(",");
+            split.forEach(url => {
+              let names = url.split("jczz/");
+              urls.push(names[1]);
+            })
+            files[k] = urls.join(",")
+          }
+        }
+
+        row.attachment = JSON.stringify(files);
+        for (let j in row) {
+          if (keys.indexOf(j) != -1) {
+            delete row[j];
+          }
+        }
+        console.log("提交===>", row);
         row.propertyFlag = 1
         add(row).then(
           () => {
@@ -405,6 +919,7 @@
         done()
       },
       selectionChange(list) {
+        console.log(111);
         this.selectionList = list
       },
       selectionClear() {
@@ -482,20 +997,42 @@
           this.page.total = data.total
           this.data = data.records
           this.data.forEach(item => {
-            if (item.constructionSchemeUrls.length > 0) {
-              var urls = []
-              var names = item.constructionSchemeUrls.split(",")
-              names.forEach(name => {
-                urls.push(website.minioUrl + name)
-              })
-              item.constructionSchemeUrls = urls.join(",")
-            }
+            this.$set(item, 'linkPhoneflag', false)
+            // if (item.constructionSchemeUrls.length > 0) {
+            //   var urls = []
+            //   var names = item.constructionSchemeUrls.split(",")
+            //   names.forEach(name => {
+            //     urls.push(website.minioUrl + name)
+            //   })
+            //   item.constructionSchemeUrls = urls.join(",")
+            // }
           })
           this.loading = false
           this.selectionClear()
         })
-      }
+      },
+
+      getDetail(articleId, districtId) {
+        let params = {
+          level: 1,
+          articleId: articleId,
+          districtId: districtId
+        }
+        getLists(1, 10, params).then(res => {
+          const data = res.data.data
+          if (data.length) {
+            this.topictData = data[0].children;
+            this.topicTitle = data[0].discussContent;
+          }
+        })
+      },
+
+      openUserPopup(row) {
+        this.$refs.DeitDiscussion.openUser(row, 1, [this.form.districtId])
+      },
+
     }
+
   }
 </script>
 
@@ -503,4 +1040,8 @@
   .avue-upload__icon {
     line-height: 6;
   }
-</style>
\ No newline at end of file
+
+  .workOrderStyle {
+    font-weight: normal;
+  }
+</style>

--
Gitblit v1.9.3