From 199b0b166e158f4606a71278dd5f532e2b87224c Mon Sep 17 00:00:00 2001
From: jiangping <jp@doumee.com>
Date: 星期二, 26 十一月 2024 16:28:28 +0800
Subject: [PATCH] 开发更新

---
 server/system_service/src/main/java/com/doumee/core/utils/Constants.java                                |   39 +++++
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/AreasServiceImpl.java      |    2 
 server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/admin/YwContractCloudController.java         |    9 +
 server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/YwContract.java               |   21 +++
 admin/src/components/business/OperaInternalCompanyWindow.vue                                            |    4 
 admin/package-lock.json                                                                                 |   18 +-
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/InitServiceImpl.java       |    2 
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/YwContractServiceImpl.java |  227 ++++++++++++++++++++++++--------
 admin/src/views/business/internalCompany.vue                                                            |   14 -
 server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/admin/AreasCloudController.java              |   20 +-
 admin/src/views/business/areas.vue                                                                      |   16 +
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java    |    4 
 admin/src/views/business/internalMember.vue                                                             |   10 
 server/visits/dmvisit_service/src/main/java/com/doumee/service/business/YwContractService.java          |    6 
 14 files changed, 293 insertions(+), 99 deletions(-)

diff --git a/admin/package-lock.json b/admin/package-lock.json
index 70ff946..4adea74 100644
--- a/admin/package-lock.json
+++ b/admin/package-lock.json
@@ -6,7 +6,7 @@
   "dependencies": {
     "@amap/amap-jsapi-loader": {
       "version": "1.0.1",
-      "resolved": "https://registry.npmjs.org/@amap/amap-jsapi-loader/-/amap-jsapi-loader-1.0.1.tgz",
+      "resolved": "https://registry.npmmirror.com/@amap/amap-jsapi-loader/-/amap-jsapi-loader-1.0.1.tgz",
       "integrity": "sha512-nPyLKt7Ow/ThHLkSvn2etQlUzqxmTVgK7bIgwdBRTg2HK5668oN7xVxkaiRe3YZEzGzfV2XgH5Jmu2T73ljejw=="
     },
     "@babel/code-frame": {
@@ -2917,7 +2917,7 @@
         },
         "ansi-styles": {
           "version": "4.3.0",
-          "resolved": "https://registry.npmjs.org/ansi-styles/-/ansi-styles-4.3.0.tgz",
+          "resolved": "https://registry.npmmirror.com/ansi-styles/-/ansi-styles-4.3.0.tgz",
           "integrity": "sha512-zbB9rCJAT1rbjiVDb2hqKFHNYLxgtk8NURxZ3IZwD3F6NtxbXZQCnnSi1Lkx+IDohdPlFp222wVALIheZJQSEg==",
           "dev": true,
           "optional": true,
@@ -2927,7 +2927,7 @@
         },
         "chalk": {
           "version": "4.1.2",
-          "resolved": "https://registry.npmjs.org/chalk/-/chalk-4.1.2.tgz",
+          "resolved": "https://registry.npmmirror.com/chalk/-/chalk-4.1.2.tgz",
           "integrity": "sha512-oKnbhFyRIXpUuez8iBMmyEa4nbj4IOQyuhc/wy9kY7/WVPcwIO9VA668Pu8RkO7+0G76SLROeyw9CpQ061i4mA==",
           "dev": true,
           "optional": true,
@@ -2938,7 +2938,7 @@
         },
         "color-convert": {
           "version": "2.0.1",
-          "resolved": "https://registry.npmjs.org/color-convert/-/color-convert-2.0.1.tgz",
+          "resolved": "https://registry.npmmirror.com/color-convert/-/color-convert-2.0.1.tgz",
           "integrity": "sha512-RRECPsj7iu/xb5oKYcsFHSppFNnsj/52OVTRKb4zP5onXwVF3zVmmToNcOfGC+CRDpfK/U584fMg38ZHCaElKQ==",
           "dev": true,
           "optional": true,
@@ -2948,21 +2948,21 @@
         },
         "color-name": {
           "version": "1.1.4",
-          "resolved": "https://registry.npmjs.org/color-name/-/color-name-1.1.4.tgz",
+          "resolved": "https://registry.npmmirror.com/color-name/-/color-name-1.1.4.tgz",
           "integrity": "sha512-dOy+3AuW3a2wNbZHIuMZpTcgjGuLU/uBL/ubcZF9OXbDo8ff4O8yVp5Bf0efS8uEoYo5q4Fx7dY9OgQGXgAsQA==",
           "dev": true,
           "optional": true
         },
         "has-flag": {
           "version": "4.0.0",
-          "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-4.0.0.tgz",
+          "resolved": "https://registry.npmmirror.com/has-flag/-/has-flag-4.0.0.tgz",
           "integrity": "sha512-EykJT/Q1KjTWctppgIAgfSO0tKVuZUjhgMr17kqTumMl6Afv3EISleU7qZUzoXDFTAHTDC4NOoG/ZxU3EvlMPQ==",
           "dev": true,
           "optional": true
         },
         "loader-utils": {
           "version": "2.0.4",
-          "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-2.0.4.tgz",
+          "resolved": "https://registry.npmmirror.com/loader-utils/-/loader-utils-2.0.4.tgz",
           "integrity": "sha512-xXqpXoINfFhgua9xiqD8fPFHgkoq1mmmpE92WlDbm9rNRd/EbRb+Gqf908T2DMfuHjjJlksiK2RbHVOdD/MqSw==",
           "dev": true,
           "optional": true,
@@ -2983,7 +2983,7 @@
         },
         "supports-color": {
           "version": "7.2.0",
-          "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-7.2.0.tgz",
+          "resolved": "https://registry.npmmirror.com/supports-color/-/supports-color-7.2.0.tgz",
           "integrity": "sha512-qpCAvRl9stuOHveKsn7HncJRvv501qIacKzQlO/+Lwxc9+0q2wLyv4Dfvt80/DPn2pqOBsJdDiogXGR9+OvwRw==",
           "dev": true,
           "optional": true,
@@ -2993,7 +2993,7 @@
         },
         "vue-loader-v16": {
           "version": "npm:vue-loader@16.8.3",
-          "resolved": "https://registry.npmjs.org/vue-loader/-/vue-loader-16.8.3.tgz",
+          "resolved": "https://registry.npmmirror.com/vue-loader/-/vue-loader-16.8.3.tgz",
           "integrity": "sha512-7vKN45IxsKxe5GcVCbc2qFU5aWzyiLrYJyUuMz4BQLKctCj/fmCa0w6fGiiQ2cLFetNcek1ppGJQDCup0c1hpA==",
           "dev": true,
           "optional": true,
diff --git a/admin/src/components/business/OperaInternalCompanyWindow.vue b/admin/src/components/business/OperaInternalCompanyWindow.vue
index ad001b2..9198f65 100644
--- a/admin/src/components/business/OperaInternalCompanyWindow.vue
+++ b/admin/src/components/business/OperaInternalCompanyWindow.vue
@@ -17,7 +17,7 @@
             </el-form-item>
           <el-form-item label="缁勭粐绫诲瀷" prop="type">
             <el-radio-group v-model="form.type" :disabled="form.parentType == 0">
-              <el-radio :label="0">鐩稿叧鏂圭粍缁�</el-radio>
+<!--              <el-radio :label="0">鐩稿叧鏂圭粍缁�</el-radio>-->
               <el-radio :label="1">鍐呴儴缁勭粐</el-radio>
             </el-radio-group>
           </el-form-item>
@@ -74,7 +74,7 @@
       console.log(target)
       this.form= {
         id: null,
-        type: 0,
+        type: 1,
         name: '',
         parentId: null,
         disable: false,
diff --git a/admin/src/views/business/areas.vue b/admin/src/views/business/areas.vue
index 3d05d52..0908620 100644
--- a/admin/src/views/business/areas.vue
+++ b/admin/src/views/business/areas.vue
@@ -80,13 +80,17 @@
           this.tableData.list = this.dataAddBool(data)
         })
         .catch(e => {
-          this.$message.error(e)
+          console.log(e)
+          this.$tip.error('鎿嶄綔澶辫触')
         })
         .finally(() => {
           this.isWorking.search = false
         })
     },
     dataAddBool(array) {
+      if(array==null){
+        return  []
+      }
       array.forEach(item => {
         item.hasChildren = item.type != 2
         // item.childList = item.childList && this.dataAddBool(item.childList)
@@ -97,10 +101,11 @@
       this.treeMaps.set(tree.id, { tree, treeNode, resolve })
       listByParentId({ parentId: tree.id, type: tree.type + 1 })
         .then(data => {
-          resolve(this.dataAddBool(data||[]))
+          resolve(this.dataAddBool(data || []))
         })
         .catch(e => {
-          this.$message.error(e)
+          console.log(e)
+          this.$tip.error('鎿嶄綔澶辫触')
         })
         .finally(() => {
           this.isWorking.search = false
@@ -133,11 +138,12 @@
           this.isWorking.delete = true
           this.api.deleteById(row[this.configData['field.id']])
             .then(() => {
-              this.$message.success('鍒犻櫎鎴愬姛')
+              this.$tip.apiSuccess('鍒犻櫎鎴愬姛')
               this.refreshLoadTree(row.parentId)
             })
             .catch(e => {
-              this.$message.error(e)
+              console.log(e)
+              this.$tip.error('鎿嶄綔澶辫触')
             })
             .finally(() => {
               this.isWorking.delete = false
diff --git a/admin/src/views/business/internalCompany.vue b/admin/src/views/business/internalCompany.vue
index 60279db..82e522b 100644
--- a/admin/src/views/business/internalCompany.vue
+++ b/admin/src/views/business/internalCompany.vue
@@ -17,8 +17,8 @@
         <!-- 琛ㄦ牸鍜屽垎椤� -->
         <template v-slot:table-wrap>
             <ul class="toolbar" v-permissions="['business:company:create', 'business:company:sync']">
-               <li><el-button type="primary" v-permissions="['business:company:create']" @click="$refs.OperaInternalCompanyWindow.open('鏂板缓浼佷笟',null,null)">鏂板缓</el-button></li>
-              <li><el-button @click="sort('top')" :loading="sorting" icon="el-icon-sort-up" v-permissions="['business:company:sort']">涓婄Щ</el-button></li>
+               <li><el-button type="primary" v-permissions="['business:company:create']" @click="$refs.OperaInternalCompanyWindow.open('鏂板缓缁勭粐',null,null)">鏂板缓</el-button></li>
+              <li><el-button @click="sort('top')" :loaing="sorting" icon="el-icon-sort-up" v-permissions="['business:company:sort']">涓婄Щ</el-button></li>
               <li><el-button @click="sort('bottom')" :loading="sorting" icon="el-icon-sort-down" v-permissions="['business:company:sort']">涓嬬Щ</el-button></li>
               <li><el-button type="primary"  v-permissions="['business:company:sync']" :loading="loading" @click="synchronous()">鍚屾</el-button></li>
             </ul>
@@ -29,8 +29,7 @@
                 :tree-props="{children: 'childList',hasChildren: 'hasChildren'}"
                 row-key="id"
                 @selection-change="handleSelectionChange"
-                default-expand-all
-            >
+                default-expand-all>
                 <el-table-column type="selection" width="55"></el-table-column>
                 <el-table-column prop="name" label="缁勭粐鍚嶇О" min-width="100px"></el-table-column>
                 <el-table-column prop="name" label="缁勭粐绫诲瀷" min-width="80px">
@@ -45,10 +44,9 @@
                 <el-table-column
                     label="鎿嶄綔"
                     width="230"
-                    fixed="right"
-                >
+                    fixed="right">
                     <template slot-scope="{row}">
-                        <el-button type="text" @click="$refs.OperaInternalCompanyWindow.open('缂栬緫浼佷笟淇℃伅',{  id: row.parentId,name:row.parentName,type:row.parentType, companyPath:row.parentCompanyPath}, row)" icon="el-icon-edit" v-permissions="['business:company:update']">缂栬緫</el-button>
+                        <el-button type="text" @click="$refs.OperaInternalCompanyWindow.open('缂栬緫缁勭粐淇℃伅',{  id: row.parentId,name:row.parentName,type:row.parentType, companyPath:row.parentCompanyPath}, row)" icon="el-icon-edit" v-permissions="['business:company:update']">缂栬緫</el-button>
                         <el-button type="text" @click="$refs.OperaInternalCompanyWindow.open('鏂板缓瀛愮骇',  row,null)" icon="el-icon-plus">鏂板缓瀛愮骇</el-button>
                         <el-button type="text" @click="deleteById(row)" style="color: red" icon="el-icon-delete" v-permissions="['business:company:delete']">鍒犻櫎</el-button>
                     </template>
@@ -83,7 +81,7 @@
   },
   created () {
     this.config({
-      module: '浼佷笟淇℃伅琛�',
+      module: '缁勭粐淇℃伅琛�',
       api: '/business/company',
       'field.id': 'id',
       'field.main': 'id'
diff --git a/admin/src/views/business/internalMember.vue b/admin/src/views/business/internalMember.vue
index 956a89c..98ae806 100644
--- a/admin/src/views/business/internalMember.vue
+++ b/admin/src/views/business/internalMember.vue
@@ -53,7 +53,7 @@
     <!-- 琛ㄦ牸鍜屽垎椤� -->
     <template v-slot:table-wrap>
       <ul class="toolbar" v-permissions="['business:member:delete', 'business:member:create,business:empower:create']">
- 
+
         <li><el-button type="primary"
             @click="$refs.OperaMemberWindow.open('鏂板缓鍛樺伐', null, department, searchForm.companyType)" icon="el-icon-plus"
             v-permissions="['business:member:create']">鏂板缓鍛樺伐</el-button></li>
@@ -118,7 +118,7 @@
             </el-switch>
           </template>
         </el-table-column>
-        <el-table-column label="鏄惁鍙嫓璁�">
+<!--        <el-table-column label="鏄惁鍙嫓璁�">
           <template slot-scope="{row}">
             <el-switch @change="changeCanvisit($event, row)" v-model="row.canVisit" active-color="#13ce66"
               inactive-color="#ff4949" :active-value="1" :inactive-value="0">
@@ -162,7 +162,7 @@
             <el-button @click="$refs.cardOpeningRecord.open('寮�鍗¤褰�', row.id)" type="text">{{ row.memberCardCount ||
               '0'}}</el-button>
           </template>
-        </el-table-column>
+        </el-table-column>-->
         <el-table-column prop="editorName" label="鎿嶄綔浜�" min-width="100px"></el-table-column>
         <el-table-column prop="editDate" label="鏈�鍚庢搷浣滄椂闂�" min-width="150px"></el-table-column>
         <el-table-column
@@ -171,8 +171,8 @@
           <template slot-scope="{row}">
             <el-button type="text" icon="el-icon-edit" @click="$refs.OperaMemberWindow.open('缂栬緫鍛樺伐淇℃伅', row, department)"
               v-permissions="['business:empower:update']">缂栬緫</el-button>
-            <el-button type="text" icon="el-icon-plus" @click="empower(row.id)"
-              v-permissions="['business:empower:create']">閲嶆柊鎺堟潈</el-button>
+<!--            <el-button type="text" icon="el-icon-plus" @click="empower(row.id)"
+              v-permissions="['business:empower:create']">閲嶆柊鎺堟潈</el-button>-->
             <el-button type="text" :loading="heading" style="color: red" icon="el-icon-delete"
               @click="updateHead(row, 0)" v-if="row.headStatus == 1"
               v-permissions="['business:member:head']">鍙栨秷涓荤</el-button>
diff --git a/server/system_service/src/main/java/com/doumee/core/utils/Constants.java b/server/system_service/src/main/java/com/doumee/core/utils/Constants.java
index 336d44e..960ad0d 100644
--- a/server/system_service/src/main/java/com/doumee/core/utils/Constants.java
+++ b/server/system_service/src/main/java/com/doumee/core/utils/Constants.java
@@ -184,6 +184,45 @@
     public static final String TIMEOUT_WARNING = "TIMEOUT_WARNING";
     // FTP鏂囦欢鏈嶅姟鍣ㄨ祫婧愯闂湴鍧�
 
+    /**
+     *    浠樻鍛ㄦ湡绫诲瀷 0=鍏冩瘡骞崇背澶╋紱1=鍏冩瘡骞崇背鏈堬紱2=鍏冩瘡骞崇背骞达紱3=鍏冩瘡澶╋紱4=鍏冩瘡鏈堬紱5=鍏冩瘡骞达紱6=鍏冩瘡鍦猴紱
+     * @param circleType
+     * @return
+     */
+    public static String getUnitTypeByNum(Integer circleType) {
+
+        int zlPayType = Constants.formatIntegerNum(circleType);
+        if(zlPayType == 1){
+            return "鍏�/銕÷锋湀";
+        }else   if(zlPayType == 2){
+            return "鍏�/銕÷峰ぉ";
+        }else  if(zlPayType == 3){
+            return "鍏�/澶�";
+        }else  if(zlPayType == 4){
+            return "鍏�/鏈�";
+        }else  if(zlPayType == 5){
+            return "鍏�/骞�";
+        }else  if(zlPayType == 6){
+            return "鍏�/鍦�";
+        }
+        return "鍏�/銕÷峰ぉ";
+    }
+
+    /**
+     *  鍛ㄦ湡鏀粯鏂瑰紡 0=涓�娆℃�т粯娆撅紱1=姣忎笁涓湀涓�浠橈紱2=鍏釜鏈堜竴浠橈紱3=涓�骞翠竴浠�
+     * @param zlPayType
+     * @return
+     */
+    public static String getPayTypeByNum(Integer zlPayType) {
+        if(zlPayType == 1){
+            return "3涓湀涓�浠�";
+        }else   if(zlPayType == 2){
+            return "6涓湀涓�浠�";
+        }else  if(zlPayType == 3){
+            return "1骞翠竴浠�";
+        }
+        return "涓�娆℃�т粯娆�";
+    }
 
     public static String getRandom6Num( ) {
         Random random = new Random();
diff --git a/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/admin/AreasCloudController.java b/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/admin/AreasCloudController.java
index 480b024..6c0f5a8 100644
--- a/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/admin/AreasCloudController.java
+++ b/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/admin/AreasCloudController.java
@@ -1,6 +1,7 @@
 package com.doumee.cloud.admin;
 
 import com.doumee.api.BaseController;
+import com.doumee.config.annotation.CloudRequiredPermission;
 import com.doumee.core.annotation.excel.ExcelExporter;
 import com.doumee.core.annotation.pr.PreventRepeat;
 import com.doumee.core.model.ApiResponse;
@@ -12,7 +13,6 @@
 import com.doumee.service.business.AreasService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
-import org.apache.shiro.authz.annotation.RequiresPermissions;
 import org.springframework.beans.BeanUtils;
 import org.springframework.beans.factory.annotation.Autowired;
 import org.springframework.web.bind.annotation.*;
@@ -36,7 +36,7 @@
     @PreventRepeat
     @ApiOperation("鏂板缓")
     @PostMapping("/create")
-    @RequiresPermissions("business:areas:create")
+    @CloudRequiredPermission("business:areas:create")
     public ApiResponse create(@RequestBody Areas areas,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
         areas.setLoginUserInfo(getLoginUser(token));
         return ApiResponse.success(areasService.create(areas));
@@ -44,7 +44,7 @@
 
     @ApiOperation("鏍规嵁ID鍒犻櫎")
     @GetMapping("/delete/{id}")
-    @RequiresPermissions("business:areas:delete")
+    @CloudRequiredPermission("business:areas:delete")
     public ApiResponse deleteById(@PathVariable Integer id,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
         areasService.deleteById(id);
         return ApiResponse.success(null);
@@ -52,7 +52,7 @@
 
     @ApiOperation("鎵归噺鍒犻櫎")
     @GetMapping("/delete/batch")
-    @RequiresPermissions("business:areas:delete")
+    @CloudRequiredPermission("business:areas:delete")
     public ApiResponse deleteByIdInBatch(@RequestParam String ids,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
         String [] idArray = ids.split(",");
         List<Integer> idList = new ArrayList<>();
@@ -65,7 +65,7 @@
 
     @ApiOperation("鏍规嵁ID淇敼")
     @PostMapping("/updateById")
-    @RequiresPermissions("business:areas:update")
+    @CloudRequiredPermission("business:areas:update")
     public ApiResponse updateById(@RequestBody Areas areas,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
         areas.setLoginUserInfo(getLoginUser(token));
         areasService.updateById(areas);
@@ -74,14 +74,14 @@
 
     @ApiOperation("鍒嗛〉鏌ヨ")
     @PostMapping("/page")
-//    @RequiresPermissions("business:areas:query")
+//    @CloudRequiredPermission("business:areas:query")
     public ApiResponse<PageData<Areas>> findPage (@RequestBody PageWrap<Areas> pageWrap,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
         return ApiResponse.success(areasService.findPage(pageWrap));
     }
 
     @ApiOperation("鍏ㄩ儴鏍戝舰鏌ヨ")
     @PostMapping("/treeList")
-//    @RequiresPermissions("business:areas:query")
+//    @CloudRequiredPermission("business:areas:query")
     public ApiResponse<List<Areas>> treeList (@RequestBody AreasDto pageWrap,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
         Areas a = new Areas();
         BeanUtils.copyProperties(pageWrap,a);
@@ -89,7 +89,7 @@
     }
     @ApiOperation("鏍规嵁鐖惰妭鐐规煡涓�")
     @PostMapping("/listByParentId")
-//    @RequiresPermissions("business:areas:query")
+//    @CloudRequiredPermission("business:areas:query")
     public ApiResponse<List<Areas>> listByParentId (@RequestBody AreasDto pageWrap,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
         Areas a = new Areas();
         BeanUtils.copyProperties(pageWrap,a);
@@ -101,14 +101,14 @@
     }
     @ApiOperation("瀵煎嚭Excel")
     @PostMapping("/exportExcel")
-    @RequiresPermissions("business:areas:exportExcel")
+    @CloudRequiredPermission("business:areas:exportExcel")
     public void exportExcel (@RequestBody PageWrap<Areas> pageWrap, HttpServletResponse response,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
         ExcelExporter.build(Areas.class).export(areasService.findPage(pageWrap).getRecords(), "鐪佸競鍖轰俊鎭〃", response);
     }
 
     @ApiOperation("鏍规嵁ID鏌ヨ")
     @GetMapping("/{id}")
-    @RequiresPermissions("business:areas:query")
+    @CloudRequiredPermission("business:areas:query")
     public ApiResponse findById(@PathVariable Integer id,@RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
         return ApiResponse.success(areasService.findById(id));
     }
diff --git a/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/admin/YwContractCloudController.java b/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/admin/YwContractCloudController.java
index 73abf9f..9825d27 100644
--- a/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/admin/YwContractCloudController.java
+++ b/server/visits/dmvisit_admin/src/main/java/com/doumee/cloud/admin/YwContractCloudController.java
@@ -9,6 +9,7 @@
 import com.doumee.core.model.PageWrap;
 import com.doumee.core.utils.Constants;
 import com.doumee.dao.business.model.YwContract;
+import com.doumee.dao.business.model.YwContractBill;
 import com.doumee.service.business.YwContractService;
 import io.swagger.annotations.Api;
 import io.swagger.annotations.ApiOperation;
@@ -41,6 +42,14 @@
         return ApiResponse.success(ywContractService.create(ywContract));
     }
     @PreventRepeat
+    @ApiOperation("鏍规嵁鍙傛暟棰勭敓鎴愯处鍗曚俊鎭�")
+    @PostMapping("/getBillList")
+    @CloudRequiredPermission("business:ywcontract:create")
+    public ApiResponse< List<YwContractBill> > getBillList(@RequestBody YwContract ywContract, @RequestHeader(Constants.HEADER_USER_TOKEN) String token) {
+        ywContract.setLoginUserInfo(this.getLoginUser(token));
+        return ApiResponse.success(ywContractService.getBillList(ywContract));
+    }
+    @PreventRepeat
     @ApiOperation("閫�绉�")
     @PostMapping("/backRent")
     @CloudRequiredPermission("business:ywcontract:update")
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/YwContract.java b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/YwContract.java
index 7247bdf..e7ecb22 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/YwContract.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/dao/business/model/YwContract.java
@@ -142,6 +142,18 @@
     @ApiModelProperty(value = "绉熻祦鏉℃鎶奸噾锛堝厓锛�", example = "1")
     @ExcelColumn(name="绉熻祦鏉℃鎶奸噾锛堝厓锛�")
     private BigDecimal zlDeposit;
+    @ApiModelProperty(value = "棣栨湡绉熻祦鏉℃鍗曚环锛堝厓锛�", example = "1")
+    @ExcelColumn(name="棣栨湡绉熻祦鏉℃鍗曚环锛堝厓锛�")
+    private BigDecimal zlFirstPrice;
+    @ApiModelProperty(value = "棣栨湡绉熻祦鏉℃浠锋牸鍗曚綅", example = "1")
+    @ExcelColumn(name="棣栨湡绉熻祦鏉℃浠锋牸鍗曚綅")
+    private Integer zlFirstCircle;
+    @ApiModelProperty(value = "鐗╀笟绉熻祦鏉℃鍗曚环锛堝厓锛�", example = "1")
+    @ExcelColumn(name="鐗╀笟绉熻祦鏉℃鍗曚环锛堝厓锛�")
+    private BigDecimal wyFirstPrice;
+    @ApiModelProperty(value = "鐗╀笟绉熻祦鏉℃浠锋牸鍗曚綅", example = "1")
+    @ExcelColumn(name="鐗╀笟绉熻祦鏉℃浠锋牸鍗曚綅")
+    private Integer wyFirstCircle;
 
     @ApiModelProperty(value = "绉熻祦鏀粯鏂瑰紡 0=涓�娆℃�т粯娆撅紱1=姣忎笁涓湀涓�浠橈紱2=鍏釜鏈堜竴浠橈紱3=涓�骞翠竴浠�", example = "1")
     @ExcelColumn(name="绉熻祦鏀粯鏂瑰紡 0=涓�娆℃�т粯娆撅紱1=姣忎笁涓湀涓�浠橈紱2=鍏釜鏈堜竴浠橈紱3=涓�骞翠竴浠�")
@@ -232,7 +244,16 @@
     @ApiModelProperty(value = "閫�娆炬湭缁撴竻璐﹀崟鏁�")
     @TableField(exist = false)
     private int btWaitBill;
+    @ApiModelProperty(value = "鐢熸垚璐﹀崟绫诲瀷 0绉熻祦璐﹀崟  1鐗╀笟璐﹀崟")
+    @TableField(exist = false)
+    private int billType;
 
+    @ApiModelProperty(value = "绉熻祦绉熻祦鏉℃浠锋牸鍗曚綅锛屾蹇靛悕绉�", example = "1")
+    @TableField(exist = false)
+    private String zlFirstCircleStr;
+    @ApiModelProperty(value = "鐗╀笟绉熻祦鏉℃浠锋牸鍗曚綅锛屾蹇靛悕绉�", example = "1")
+    @TableField(exist = false)
+    private String wyFirstCircleStr;
     @ApiModelProperty(value = "閫�绉熸椂鏂板鐨勬敹浠樻璐﹀崟")
     @TableField(exist = false)
     private List<YwContractBill> addBillList;
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/YwContractService.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/YwContractService.java
index 58af13f..819febd 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/YwContractService.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/YwContractService.java
@@ -4,6 +4,8 @@
 import com.doumee.core.model.PageData;
 import com.doumee.core.model.PageWrap;
 import com.doumee.dao.business.model.YwContract;
+import com.doumee.dao.business.model.YwContractBill;
+
 import java.util.List;
 
 /**
@@ -20,7 +22,7 @@
      * @return Integer
      */
     Integer create(YwContract ywContract);
-
+    List<YwContractBill> getBillList(YwContract ywContract);
     /**
      * 涓婚敭鍒犻櫎
      *
@@ -97,4 +99,6 @@
     long count(YwContract ywContract);
 
     Integer backRent(YwContract ywContract);
+
+
 }
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/AreasServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/AreasServiceImpl.java
index 1b2ed39..2416bac 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/AreasServiceImpl.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/AreasServiceImpl.java
@@ -21,6 +21,7 @@
 import org.springframework.stereotype.Service;
 import org.springframework.util.CollectionUtils;
 
+import javax.annotation.PostConstruct;
 import java.util.ArrayList;
 import java.util.Date;
 import java.util.List;
@@ -316,6 +317,7 @@
         return result;
     }
     @Override
+    @PostConstruct
     public  void cacheData() {
        Areas a = new Areas();
        a.setIsdeleted(Constants.ZERO);
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java
index 4cdd677..ca0ccf9 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/CompanyServiceImpl.java
@@ -340,7 +340,7 @@
                         .setSql("hk_company_path=REPLACE(hk_company_path,'"+ model.getCompanyNamePath()+"','"+newName+"')")
                 .likeRight(Company::getCompanyPath,model.getCompanyPath()));
         //涓嬪彂娴峰悍瀹夐槻骞冲彴
-        if(StringUtils.isNotBlank(model.getHkId())){
+      /*  if(StringUtils.isNotBlank(model.getHkId())){
              if(!editHkOrg(company)){
                  throw  new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"瀵逛笉璧凤紝缁勭粐鍚屾涓嬪彂澶辫触锛岃绋嶅悗閲嶈瘯");
              }
@@ -348,7 +348,7 @@
             if(!addHkOrg(company)){
                 throw  new BusinessException(ResponseStatus.SERVER_ERROR.getCode(),"瀵逛笉璧凤紝缁勭粐鍚屾涓嬪彂澶辫触锛岃绋嶅悗閲嶈瘯");
             }
-        }
+        }*/
 
     }
 
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/InitServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/InitServiceImpl.java
index 918b813..50529ff 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/InitServiceImpl.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/InitServiceImpl.java
@@ -26,7 +26,7 @@
     @Autowired
     private InterfaceLogService interfaceLogService;
 
-    @PostConstruct
+//    @PostConstruct
     public  int  initHkConfig(){
             ArtemisConfig.host = systemDictDataBiz.queryByCode(Constants.HK_PARAM, Constants.HK_HOST).getCode();
             ArtemisConfig.appKey = systemDictDataBiz.queryByCode(Constants.HK_PARAM, Constants.HK_APPKEY).getCode();
diff --git a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/YwContractServiceImpl.java b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/YwContractServiceImpl.java
index e8e6bbc..5b5b311 100644
--- a/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/YwContractServiceImpl.java
+++ b/server/visits/dmvisit_service/src/main/java/com/doumee/service/business/impl/YwContractServiceImpl.java
@@ -85,6 +85,124 @@
         dealLogBiz(model,Constants.YwLogType.CONTRACT_CREATE,null,null);//璁板綍鏂板缓鏃ュ織
         return model.getId();
     }
+    @Override
+    public   List<YwContractBill> getBillList(YwContract model){
+        isParamValidForBill(model);
+        model.setCreateDate(new Date());
+        model.setEditDate(model.getCreateDate());
+        dealDetailListBiz(model);//澶勭悊鏉℃淇℃伅
+        return model.getBillList();
+    }
+
+    private void isParamValidForBill(YwContract model) {
+        if(model.getStartDate() == null
+                ||model.getEndDate() == null
+                ||model.getProjectId() == null
+                ||model.getCompanyId() == null
+                ||model.getRoundedUp() == null
+                ||model.getRoomIds() == null
+                ||model.getRoomIds().size() == 0
+        ){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝璇锋寜椤甸潰瑕佹眰濉啓鍚堝悓淇℃伅");
+        }
+        if(model.getEndDate().getTime()<= model.getStartDate().getTime()){
+
+            throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝鍚堝悓鏈夋晥鏈熺粨鏉熸椂闂翠笉寰楁棭浜庡紑濮嬫椂闂达紒");
+        }
+
+        if(model.getBillType() ==0 ){
+            //濡傛灉鐢熸垚绉熻祦鏉℃
+            if(  model.getZlDeposit() == null
+                    ||model.getZlPayType() == null
+                    || model.getZlPayType()>3
+                    || model.getZlPayType()<0
+                    ||model.getZlDetailList()==null
+                    ||model.getZlDetailList().size() ==0){
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝璇锋寜椤甸潰瑕佹眰濉啓绉熻祦鏉℃淇℃伅");
+            }
+            if(!(model.getZlFreeEndDate()==null &&  model.getZlFreeStartDate()==null) && (
+                    (model.getZlFreeEndDate()!=null &&  model.getZlFreeStartDate()==null)
+                            ||(model.getZlFreeEndDate()==null &&  model.getZlFreeStartDate()!=null)
+                            ||model.getZlFreeEndDate().getTime()<= model.getZlFreeStartDate().getTime())
+            ){
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝璇烽�夋嫨姝g‘鐨勭璧佹潯娆惧厤绉熸湡淇℃伅锛�");
+            }
+            for(YwContractDetail d :model.getZlDetailList()){
+                if(  d.getStartDate() == null
+                        ||d.getEndDate() == null
+                        ||d.getPrice() == null
+                        ||d.getCircleType() == null
+                        || d.getCircleType()>6
+                        || d.getCircleType()<0
+                ){
+                    throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝璇锋寜椤甸潰瑕佹眰濉啓绉熻祦鏉℃淇℃伅!");
+                }
+                if(d.getEndDate().getTime()<= d.getStartDate().getTime()){
+
+                    throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝绉熻祦鏉℃鏈夋晥鏈熺粨鏉熸椂闂翠笉寰楁棭浜庡紑濮嬫椂闂达紒");
+                }
+                if(!Constants.equalsInteger(model.getWyPayType(),Constants.ZERO) &&
+                        Constants.equalsInteger(d.getCircleType(),Constants.SIX)){
+                    throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝绉熻祦鏉℃鍙湁閫夋嫨涓�娆℃�т粯娆炬椂锛屾墠鑳介�夋嫨璇ユ寜姣忓満鏀惰垂锛�");
+                }
+            }
+        }
+        if(model.getBillType() == 1 ){
+            //濡傛灉鐢熸垚鐗╀笟鏉℃
+            if(  model.getWyDeposit() == null
+                    ||model.getWyPayType() == null
+                    || model.getWyPayType()>3
+                    || model.getWyPayType()<0
+                    ||model.getWyDetailList()==null
+                    ||model.getWyDetailList().size() ==0
+            ){
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝璇锋寜椤甸潰瑕佹眰濉啓鐗╀笟鏉℃淇℃伅");
+            }
+            if(!(model.getWyFreeEndDate()==null &&  model.getWyFreeStartDate()==null) && (
+                    (model.getWyFreeEndDate()!=null &&  model.getWyFreeStartDate()==null)
+                            ||(model.getWyFreeEndDate()==null &&  model.getWyFreeStartDate()!=null)
+                            ||model.getWyFreeEndDate().getTime()<= model.getWyFreeStartDate().getTime())){
+                throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝璇烽�夋嫨姝g‘鐨勭墿涓氭潯娆惧厤绉熸湡淇℃伅锛�");
+            }
+            for(YwContractDetail d :model.getWyDetailList()){
+                if(  d.getStartDate() == null
+                        ||d.getEditDate() == null
+                        ||d.getPrice() == null
+                        ||d.getCircleType() == null
+                        || d.getCircleType()>6
+                        || d.getCircleType()<0
+                ){
+                    throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝璇锋寜椤甸潰瑕佹眰濉啓鐗╀笟鏉℃淇℃伅!");
+                }
+                if(d.getEndDate().getTime()<= d.getStartDate().getTime()){
+                    throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝鐗╀笟鏉℃鏈夋晥鏈熺粨鏉熸椂闂翠笉寰楁棭浜庡紑濮嬫椂闂达紒");
+                }
+                if(!Constants.equalsInteger(model.getWyPayType(),Constants.ZERO) &&
+                        Constants.equalsInteger(d.getCircleType(),Constants.SIX)){
+                    throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝鐗╀笟鏉℃鍙湁閫夋嫨涓�娆℃�т粯娆炬椂锛屾墠鑳介�夋嫨璇ユ寜姣忓満鏀惰垂锛�");
+                }
+            }
+        }
+
+        YwProject project = projectMapper.selectById(model.getCompanyId());
+        if(project ==null || Constants.equalsInteger(project.getIsdeleted(),Constants.ONE)){
+            throw new BusinessException(ResponseStatus.DATA_EMPTY.getCode(),"瀵逛笉璧凤紝璇烽�夋嫨姝g‘鐨勯」鐩俊鎭紒");
+        }
+        List<YwRoom> rooms = roomMapper.selectList(new QueryWrapper<YwRoom>().lambda()
+                .eq(YwRoom::getIsdeleted,Constants.ZERO)
+                .in(YwRoom::getId,model.getRoomIds())
+                .eq(YwRoom::getProjectId,model.getProjectId())  );
+        if(rooms ==null || rooms.size()==0){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝璇烽�夋嫨瀵瑰簲椤圭洰涓嬫纭殑鎴挎簮淇℃伅");
+        }
+        if(rooms.size() != rooms.size()){
+            throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝瀛樺湪鏃犳晥鐨勬埧婧愪俊鎭紒");
+        }
+        model.setTotalArea(new BigDecimal(0));
+        for(YwRoom r : rooms){
+            model.setTotalArea(model.getTotalArea().add(Constants.formatBigdecimal(r.getArea())));
+        }
+    }
 
     private String getRemarlByParam(YwContract model) {
 
@@ -106,12 +224,12 @@
         }
         str = str.replace("{param1}",DateUtil.getDateLongSlash(model.getStartDate()))
                 .replace("{param2}",model.getTotalArea().intValue()+"")
-                .replace("{param3}",getPayTypeByNum(model.getZlPayType()))
+                .replace("{param3}",Constants.getPayTypeByNum(model.getZlPayType()))
                 .replace("{param4}",zl!=null&&zl.getPrice()!=null?(zl.getPrice().intValue()+""):"0")
-                .replace("{param5}",getPayTypeByNum(model.getWyPayType()))
-                .replace("{param6}",getUnitTypeByNum(zl))
+                .replace("{param5}",Constants.getPayTypeByNum(model.getWyPayType()))
+                .replace("{param6}",Constants.getUnitTypeByNum(zl!=null?zl.getCircleType():null))
                 .replace("{param7}",zl!=null&&yw.getPrice()!=null?(zl.getPrice().intValue()+""):"0")
-                .replace("{param8}",getUnitTypeByNum(yw));
+                .replace("{param8}",Constants.getUnitTypeByNum(yw!=null?yw.getCircleType():null));
         return  str;
     }
     private String getbackRentRemarkByParam(YwContract model) {
@@ -126,39 +244,6 @@
         return  str;
     }
 
-    private CharSequence getUnitTypeByNum(YwContractDetail zl) {
-        if(zl==null){
-            return "";
-        }
-     //   浠樻鍛ㄦ湡绫诲瀷 0=鍏冩瘡骞崇背澶╋紱1=鍏冩瘡骞崇背鏈堬紱2=鍏冩瘡骞崇背骞达紱3=鍏冩瘡澶╋紱4=鍏冩瘡鏈堬紱5=鍏冩瘡骞达紱6=鍏冩瘡鍦猴紱
-        int zlPayType = Constants.formatIntegerNum(zl.getCircleType());
-        if(zlPayType == 1){
-            return "鍏�/銕÷锋湀";
-        }else   if(zlPayType == 2){
-            return "鍏�/銕÷峰ぉ";
-        }else  if(zlPayType == 3){
-            return "鍏�/澶�";
-        }else  if(zlPayType == 4){
-            return "鍏�/鏈�";
-        }else  if(zlPayType == 5){
-            return "鍏�/骞�";
-        }else  if(zlPayType == 6){
-            return "鍏�/鍦�";
-        }
-        return "鍏�/銕÷峰ぉ";
-    }
-
-    private CharSequence getPayTypeByNum(Integer zlPayType) {
-        //绉熻祦鏀粯鏂瑰紡 0=涓�娆℃�т粯娆撅紱1=姣忎笁涓湀涓�浠橈紱2=鍏釜鏈堜竴浠橈紱3=涓�骞翠竴浠�
-        if(zlPayType == 1){
-            return "3涓湀涓�浠�";
-        }else   if(zlPayType == 2){
-            return "6涓湀涓�浠�";
-        }else  if(zlPayType == 3){
-            return "1骞翠竴浠�";
-        }
-        return "涓�娆℃�т粯娆�";
-    }
 
 
     /**
@@ -399,7 +484,9 @@
                 details.add(d);
             }
         }
-        ywContractDetailMapper.insert(details);//鎵归噺鎻掑叆鏉℃淇℃伅淇℃伅
+        if(model.getId()!=null){
+            ywContractDetailMapper.insert(details);//鎵归噺鎻掑叆鏉℃淇℃伅淇℃伅
+        }
         //澶勭悊璐﹀崟淇℃伅
         dealBillListBiz(model,details);
     }
@@ -410,26 +497,27 @@
      * @param details
      */
     private void dealBillListBiz(YwContract model, List<YwContractDetail> details) {
-        List<YwContractBill> billList = new ArrayList<>();
+        List<YwContractBill> billList1 = new ArrayList<>();
+        List<YwContractBill> billList2 = new ArrayList<>();
         if(Constants.equalsInteger(model.getType(),Constants.ZERO )
                 || Constants.equalsInteger(model.getType(),Constants.ONE)){
             //濡傛灉鏈夌璧佹潯娆�
             if(Constants.formatBigdecimal(model.getZlDeposit()).compareTo(new BigDecimal(0))>0){
                     //濡傛灉鏈夌璧佹娂閲�
-                billList.add(initDepoistBill(Constants.THREE,model));
+                billList1.add(initDepoistBill(Constants.THREE,model));
             }
             if(Constants.equalsInteger(model.getZlPayType(), Constants.ZERO)){
                 //濡傛灉鏄竴娆℃�т粯娓�
-                billList.addAll(getBillsByParamOnce(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate()));
+                billList1.addAll(getBillsByParamOnce(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate()));
             }else if(Constants.equalsInteger(model.getZlPayType(), Constants.ONE)){
                 //濡傛灉姣忎笁涓湀涓�浠�
-                billList.addAll(getBillsByParam3Months(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate()));
+                billList1.addAll(getBillsByParam3Months(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate()));
             }else if(Constants.equalsInteger(model.getZlPayType(), Constants.TWO)){
                 //濡傛灉鍏釜鏈堜竴浠�
-                billList.addAll(getBillsByParam6Months(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate()));
+                billList1.addAll(getBillsByParam6Months(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate()));
             }else if(Constants.equalsInteger(model.getZlPayType(), Constants.THREE)){
                 //濡傛灉涓�骞翠竴浠�
-                billList.addAll(getBillsByParam1Year(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate()));
+                billList1.addAll(getBillsByParam1Year(model,details,model.getZlFreeStartDate(),model.getZlFreeEndDate()));
             }
         }
         if(Constants.equalsInteger(model.getType(),Constants.ZERO )
@@ -437,27 +525,38 @@
             //濡傛灉鐗╀笟鏉℃
             if(Constants.formatBigdecimal(model.getWyDeposit()).compareTo(new BigDecimal(0))>0){
                 //濡傛灉鏈夌璧佹娂閲�
-                billList.add(initDepoistBill(Constants.FOUR,model));
+                billList2.add(initDepoistBill(Constants.FOUR,model));
             }
             if(Constants.equalsInteger(model.getWyPayType(), Constants.ZERO)){
                 //濡傛灉鏄竴娆℃�т粯娓�
-                billList.addAll(getBillsByParamOnce(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate()));
+                billList2.addAll(getBillsByParamOnce(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate()));
             }else if(Constants.equalsInteger(model.getWyPayType(), Constants.ONE)){
                 //濡傛灉姣忎笁涓湀涓�浠�
-                billList.addAll(getBillsByParam3Months(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate()));
+                billList2.addAll(getBillsByParam3Months(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate()));
             }else if(Constants.equalsInteger(model.getWyPayType(), Constants.TWO)){
                 //濡傛灉鍏釜鏈堜竴浠�
-                billList.addAll(getBillsByParam6Months(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate()));
+                billList2.addAll(getBillsByParam6Months(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate()));
             }else if(Constants.equalsInteger(model.getWyPayType(), Constants.THREE)){
                 //濡傛灉涓�骞翠竴浠�
-                billList.addAll(getBillsByParam1Year(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate()));
+                billList2.addAll(getBillsByParam1Year(model,details,model.getWyFreeStartDate(),model.getWyFreeEndDate()));
             }
         }
-        for(int i=0;i<billList.size();i++){
-            billList.get(i).setSortnum(i+1);
-        }
-        ywContractBillMapper.insert(billList);
 
+        if(model.getBillType() == 0){
+            model.setBillList(billList1);
+        }else  if(model.getBillType() == 0){
+            model.setBillList(billList2);
+        }
+        if(model.getId()!=null){
+            for(int i=0;i<billList1.size();i++){
+                billList1.get(i).setSortnum(i+1);
+            }
+            for(int i=0;i<billList2.size();i++){
+                billList2.get(i).setSortnum(i+1);
+            }
+            ywContractBillMapper.insert(billList1);
+            ywContractBillMapper.insert(billList2);
+        }
     }
 
     private YwContractBill initDepoistBill(int type,  YwContract model) {
@@ -787,12 +886,15 @@
                     throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝璇锋寜椤甸潰瑕佹眰濉啓绉熻祦鏉℃淇℃伅!");
                 }
                 if(d.getEndDate().getTime()<= d.getStartDate().getTime()){
-
                     throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝绉熻祦鏉℃鏈夋晥鏈熺粨鏉熸椂闂翠笉寰楁棭浜庡紑濮嬫椂闂达紒");
                 }
                 if(!Constants.equalsInteger(model.getWyPayType(),Constants.ZERO) &&
                         Constants.equalsInteger(d.getCircleType(),Constants.SIX)){
                     throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝绉熻祦鏉℃鍙湁閫夋嫨涓�娆℃�т粯娆炬椂锛屾墠鑳介�夋嫨璇ユ寜姣忓満鏀惰垂锛�");
+                }
+                if(model.getZlFirstCircle() == null){//棣栨湡淇℃伅
+                    model.setZlFirstPrice(d.getPrice());
+                    model.setZlFirstCircle(d.getCircleType());
                 }
             }
         }
@@ -829,6 +931,11 @@
                 if(!Constants.equalsInteger(model.getWyPayType(),Constants.ZERO) &&
                         Constants.equalsInteger(d.getCircleType(),Constants.SIX)){
                     throw new BusinessException(ResponseStatus.BAD_REQUEST.getCode(),"瀵逛笉璧凤紝鐗╀笟鏉℃鍙湁閫夋嫨涓�娆℃�т粯娆炬椂锛屾墠鑳介�夋嫨璇ユ寜姣忓満鏀惰垂锛�");
+                }
+                if(model.getWyFirstCircle() == null){
+                    //棣栨湡淇℃伅
+                    model.setWyFirstPrice(d.getPrice());
+                    model.setWyFirstCircle(d.getCircleType());
                 }
             }
         }
@@ -952,7 +1059,8 @@
                     .eq(YwRoom::getIsdeleted,Constants.ZERO)
                     .exists("(select a.id from yw_contract_room a where a.isdeleted=1 and a.room_id=t.id and a.contract_id="+model.getId()+")");
             model.setRoomList(roomMapper.selectJoinList(YwRoom.class,rw));
-
+            model.setWyFirstCircleStr(Constants.getUnitTypeByNum(model.getWyFirstCircle()));
+            model.setZlFirstCircleStr(Constants.getUnitTypeByNum(model.getZlFirstCircle()));
             //鏌ヨ绉熻硟鏉℃淇℃伅
             MPJLambdaWrapper<YwContractDetail> dw = new MPJLambdaWrapper<>();
             dw.selectAll(YwContractDetail.class )
@@ -1142,7 +1250,14 @@
         queryWrapper.ge(Objects.nonNull(pageWrap.getModel().getQueryStartTime()), YwContract::getStartDate, pageWrap.getModel().getQueryStartTime())
                         .le(Objects.nonNull(pageWrap.getModel().getQueryEndTime()), YwContract::getEndDate, pageWrap.getModel().getQueryEndTime());
         queryWrapper.orderByDesc(YwContract::getCreateDate );
-        return PageData.from(ywContractMapper.selectJoinPage(page, YwContract.class,queryWrapper));
+        PageData<YwContract> data = PageData.from(ywContractMapper.selectJoinPage(page, YwContract.class,queryWrapper));
+        if(data!=null && data.getRecords()!=null){
+            for(YwContract model : data.getRecords()){
+                model.setWyFirstCircleStr(Constants.getUnitTypeByNum(model.getWyFirstCircle()));
+                model.setZlFirstCircleStr(Constants.getUnitTypeByNum(model.getZlFirstCircle()));
+            }
+        }
+        return data;
     }
 
     @Override

--
Gitblit v1.9.3