From a48fa4a7469b87f830251161f812a19dc9729ee9 Mon Sep 17 00:00:00 2001
From: fuliqi <fuliqi@qq.com>
Date: 星期日, 28 四月 2024 14:18:41 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 src/views/system/contract/index.vue |  590 ++++++++++++++++++++++++++++------------------------------
 1 files changed, 286 insertions(+), 304 deletions(-)

diff --git a/src/views/system/contract/index.vue b/src/views/system/contract/index.vue
index 0e76e36..61ac223 100644
--- a/src/views/system/contract/index.vue
+++ b/src/views/system/contract/index.vue
@@ -1,13 +1,15 @@
 <template>
   <div class="app-container">
 
-    <el-row>
-      <el-col :span="8" v-for="(item) in tableData" :key="o" style="margin: 10px;width: 30%;">
+    <el-row v-loading="loading">
+      <el-col :span="8" v-for="(item, index) in contractList" :key="index" style="margin: 10px;width: 30%;">
         <el-card :body-style="{ padding: '0px' }">
-          <img src="https://img2.baidu.com/it/u=68398439,1553004927&fm=253&fmt=auto&app=138&f=JPEG?w=800&h=357" class="image">
+          <ImagePreview style="width: 100%;height: 187px;"
+            fit="cover" :src="item.attachment"
+            class="image" />
           <div style="padding: 14px;">
-            <span>{{ item.companyName }}</span>
-            <span class="time" style="margin-left: 10px;">{{ item.deptName }}</span>
+            <span>{{ item.name }}</span>
+            <span class="time" style="margin-left: 10px;">{{ item.unitName }}</span>
             <div class="bottom clearfix">
               <time class="time">{{ item.startTime }} 鈥� {{ item.endTime }}</time>
               <el-button type="text" class="button" @click="handleDetail(item)">鏌ョ湅璇︽儏</el-button>
@@ -19,215 +21,162 @@
 
     <el-row :gutter="10" class="mb8" style="margin-top: 40px;">
       <el-col :span="1.5">
-        <el-button
-          type="primary"
-          plain
-          icon="el-icon-plus"
-          size="mini"
-          @click="handleAdd"
-        >鏂板</el-button>
+        <el-button type="primary" plain icon="el-icon-plus" size="mini" v-hasPermi="['system:contract:import']"
+          @click="handleImport">鏂板</el-button>
       </el-col>
-      <!-- <el-col :span="1.5">
-        <el-button
-          type="success"
-          plain
-          icon="el-icon-edit"
-          size="mini"
-          :disabled="single"
-          @click="handleUpdate"
-        >淇敼</el-button>
-      </el-col> -->
-      <!-- <el-col :span="1.5">
-        <el-button
-          type="danger"
-          plain
-          icon="el-icon-delete"
-          size="mini"
-          :disabled="multiple"
-          @click="handleDelete"
-        >鍒犻櫎</el-button>
-      </el-col> -->
     </el-row>
 
-
-    <!-- 娣诲姞鎴栦慨鏀广�愯濉啓鍔熻兘鍚嶇О銆戝璇濇 -->
-    <el-dialog :title="detailName" :visible.sync="open" width="500px" append-to-body>
-      <el-form ref="form" :model="form" :rules="rules" label-width="80px">
-        <el-form-item label="鍏徃鍚�" prop="companyName">
-          <el-select v-model="form.companyName" placeholder="璇烽�夋嫨">
-            <el-option
-              v-for="item in unitList"
-              :key="item.id"
-              :label="item.value"
-              :value="item.id">
-            </el-option>
-          </el-select>
-        </el-form-item>
-        <el-form-item label="閮ㄩ棬鍚嶇О" prop="deptName">
-          <el-select v-model="form.deptName" placeholder="璇烽�夋嫨">
-            <el-option
-              v-for="item in deptList"
-              :key="item.id"
-              :label="item.value"
-              :value="item.id">
-            </el-option>
-          </el-select>
-        </el-form-item>
-        <el-form-item label="鍚堝悓鏃堕棿" prop="timezone">
-          <el-date-picker
-            :disabled="title === '淇敼鍚堝悓鏃堕棿'"
-            @change="dateChange"
-            v-model="form.timezone"
-            type="daterange"
-            align="right"
-            unlink-panels
-            range-separator="鑷�"
-            start-placeholder="寮�濮嬫棩鏈�"
-            end-placeholder="缁撴潫鏃ユ湡"
-          >
-          </el-date-picker>
-        </el-form-item>
-      </el-form>
-      <div slot="footer" class="dialog-footer">
-        <el-button type="primary" @click="submitForm">纭� 瀹�</el-button>
-        <el-button @click="cancel">鍙� 娑�</el-button>
-      </div>
-    </el-dialog>
-    
     <!-- 鍚堝悓璇︽儏 -->
-    <el-dialog :title="detailName" :visible.sync="detail" width="500px" append-to-body>
+    <el-dialog :title="detailName" :visible.sync="detail" width="800px" append-to-body>
       <el-form label-position="left" inline class="table-expand">
-        <el-collapse v-model="activeNames" @change="handleChange">
-          <el-collapse-item title="瑙嗛骞冲潎鍦ㄧ嚎鐜�" name="1">
-            <div>鈮�98%锛氫笉鎵e垎</div>
-            <div class="inline-input-container">
-              95%鈮よ棰戝钩鍧囧湪绾跨巼锛�98%锛� <el-input v-model="props.row.score95to98" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>
-            </div>
-            <div class="inline-input-container">
-              90%鈮よ棰戝钩鍧囧湪绾跨巼锛�95%锛�<el-input v-model="props.row.score90to95" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>
-            </div>
-            <div class="inline-input-container">
-              锛�90%锛� <el-input v-model="props.row.scoreBelow90" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>锛�
-              鑻ユ湁杩炵画涓ゆ鐪佸巺鑰冩牳鍦ㄧ嚎鐜囦綆浜�90%锛屾嫑鏍囦汉鏈夋潈瑙i櫎鍚堝悓銆�
+        <el-collapse v-model="activeNames">
+          <el-collapse-item  v-for="(item, index) in ruleData" :key="index" :title="item.ruleName" :name="index">
+            <div class="inline-input-container" v-for="(item, index) in item.children" :key="index">
+              <b>{{ item.ruleDesc }}</b> <br v-if="item.ruleDesc"/>
+              <el-tooltip class="item" v-for="(item, index) in item.children" :key="index" effect="dark" :content="item.deductCategory == '鍒嗘暟涔樹互鏁伴噺' ? '鎵�' + item.calcFraction  + '涔樹互鏁伴噺 ' : item.deductCategory == '闄や互鏁伴噺鍚庝箻浠ュ垎鏁�' ? '鎵�' + item.calcFraction + '鍒�/' +  item.calcUnit + '灏忔椂' : item.deductCategory + ' ' + item.calcFraction" placement="top">
+                <span>{{ item.ruleCondition }}<br/></span>
+                <!-- {{ item.deductCategory }} {{ item.calcFraction }}{{ item.calcUnit ? "/" + item.calcUnit : ''  }} -->
+            </el-tooltip>
             </div>
           </el-collapse-item>
-          <el-collapse-item title="鍓嶇鎰熺煡婧愭不鐞嗗伐浣�" name="2">
+          <el-collapse-item title="鑰冩牳缁撴灉搴旂敤瑙勫垯" :name="ruleData.length">
             <div class="inline-input-container">
-              鏃堕挓鍚屾锛堣秴杩嚶�3绉掍负涓嶅悎鏍硷級24灏忔椂鍐呮湭淇鐨勶細鎵i櫎鐩稿叧闀滃ご鏁伴噺* <el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�
-            </div>
-            <div class="inline-input-container">
-              OSD鏍囪瘑涓嶆弧瓒炽�奊AT 751-2008 瑙嗛鍥惧儚鏂囧瓧鏍囨敞瑙勮寖銆嬶紝24灏忔椂鍐呮湭淇鐨勶細鏍囨墸闄ょ浉鍏抽暅澶存暟閲�* <el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�
-            </div>
-            <div class="inline-input-container">
-              鐢ㄦ埛鎶芥锛屼竴鏈轰竴妗f暟鎹」涓嶅悎鏍硷紙鎻愪緵铏氬亣鏁版嵁鎴栭敊璇暟鎹负涓嶅悎鏍硷級锛�24灏忔椂鍐呮湭淇鐨勶細鎵i櫎鐩稿叧闀滃ご鏁伴噺* <el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�
-            </div>
-          </el-collapse-item>
-          <el-collapse-item title="鍚庡彴绯荤粺鐨勪繚闅�" name="3">
-            <div class="inline-input-container">
-              涓埆璁惧鏁呴殰浣嗕笉褰卞搷璇ュ姛鑳芥ā鍧楁暣浣撳簲鐢ㄦ儏鍐典笅,瓒呭嚭72灏忔椂涓嶈冻144灏忔椂鐨勶紱鎵� <el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�/12灏忔椂
-            </div>
-            <div class="inline-input-container">
-              涓埆璁惧鏁呴殰浣嗕笉褰卞搷璇ュ姛鑳芥ā鍧楁暣浣撳簲鐢ㄦ儏鍐典笅,瓒呭嚭144灏忔椂浠ュ悗锛屾瘡瓒呭嚭12灏忔椂锛氭墸 <el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�/12灏忔椂
-            </div>
-            <div class="inline-input-container">
-              涓埆璁惧鏁呴殰浣嗕笉褰卞搷璇ュ姛鑳芥ā鍧楁暣浣撳簲鐢ㄦ儏鍐典笅,鍚屼竴鍔熻兘妯″潡鐨勭浉鍚屾垨涓嶅悓璁惧绱涓�涓湀鍐呮晠闅滆秴杩�3娆★細鎵� <el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�/12灏忔椂
-            </div>
-            <div class="inline-input-container">
-              鍚庡彴鍔熻兘妯″潡涓嶈兘姝e父杩愯褰卞搷姝e父浣跨敤鐨�,瓒呭嚭24灏忔椂涓嶈冻48灏忔椂鐨勶細鎵� <el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�/娆�
-            </div>
-            <div class="inline-input-container">
-              涓埆璁惧鏁呴殰浣嗕笉褰卞搷璇ュ姛鑳芥ā鍧楁暣浣撳簲鐢ㄦ儏鍐典笅,瓒呭嚭72灏忔椂涓嶈冻144灏忔椂鐨勶紱鎵� <el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�/12灏忔椂
-            </div>
-            <div class="inline-input-container">
-              鍚庡彴鍔熻兘妯″潡涓嶈兘姝e父杩愯褰卞搷姝e父浣跨敤鐨�,瓒呭嚭48灏忔椂浠ュ悗锛氭墸 <el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�/12灏忔椂
-            </div>
-            <div class="inline-input-container">
-              鍚庡彴鍔熻兘妯″潡涓嶈兘姝e父杩愯褰卞搷姝e父浣跨敤鐨�,鍚屼竴鍔熻兘妯″潡鐨勭浉鍚屾垨涓嶅悓璁惧绱涓�涓湀鍐呮晠闅滆秴杩�2娆★細鎵� <el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�/娆�
-            </div>
-          </el-collapse-item>
-          <el-collapse-item title="瀛樺偍鏁呴殰" name="4">
-            <div class="inline-input-container">
-              鍥犲瓨鍌ㄨ澶囥�佷簯瀛樺偍杞欢绛夊紩璧峰钩鍙颁笉鑳芥甯告煡鐪嬪巻鍙插浘鍍�,鍗曟鏁呴殰鏃堕暱鍦�24灏忔椂浠ュ唴鐨勶細鎵�<el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�/灏忔椂
-            </div>
-            <div class="inline-input-container">
-              鍥犲瓨鍌ㄨ澶囥�佷簯瀛樺偍杞欢绛夊紩璧峰钩鍙颁笉鑳芥甯告煡鐪嬪巻鍙插浘鍍�,鍗曟鏁呴殰鏃堕暱鍦�24灏忔椂浠ュ唴鐨勶細鎵�<el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�/灏忔椂
-            </div>
-            <div class="inline-input-container">
-              鍥犺棰戞垨鑰呭浘鐗囦涪澶卞鑷撮噸瑕佹浜嬩欢涓嶈兘鍥炴斁鎴栨煡鐪�,鍚屼竴鐐逛綅瑙嗛鍥惧儚鍚屼竴妗堜欢涓嶇疮璁¤绠楋細鎵�<el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�/娆�
-            </div>
-          </el-collapse-item>
-          <el-collapse-item title="瀵逛簬鍓嶇鐐逛綅寮傚父鎯呭喌鐨勫鐞�" name="5">
-            <div class="inline-input-container">
-              24灏忔椂鍚庢湭淇鐨勶細鎵�<el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�*闀滃ご鏁伴噺
-            </div>
-            <div class="inline-input-container">
-              48灏忔椂鍚庢湭淇锛岀疮璁℃墸鍒嗭細鎵�<el-input v-model="props.row.time24" type="number" min="0" max="100" placeholder="璇疯緭鍏ユ墸鍒�"></el-input>鍒�*闀滃ご鏁伴噺*澶�
-            </div>
-          </el-collapse-item>
-          <el-upload
-            action="#"
-            list-type="picture-card"
-            :auto-upload="false">
-              <i slot="default" class="el-icon-plus"></i>
-              <div slot="file" slot-scope="{file}">
-                <img
-                  class="el-upload-list__item-thumbnail"
-                  :src="file.url" alt=""
-                >
-                <span class="el-upload-list__item-actions">
-                  <span
-                    class="el-upload-list__item-preview"
-                    @click="handlePictureCardPreview(file)"
-                  >
-                    <i class="el-icon-zoom-in"></i>
-                  </span>
-                  <span
-                    v-if="!disabled"
-                    class="el-upload-list__item-delete"
-                    @click="handleDownload(file)"
-                  >
-                    <i class="el-icon-download"></i>
-                  </span>
-                  <span
-                    v-if="!disabled"
-                    class="el-upload-list__item-delete"
-                    @click="handleRemove(file)"
-                  >
-                    <i class="el-icon-delete"></i>
-                  </span>
+                <span v-for="(item, index) in moneyRules" :key="index">
+                    <div>
+                      <span>{{ item.scoreCondition }}</span>
+                      <el-tooltip class="item" effect="dark" :content="item.description" placement="top">
+                        <span style="margin-left: 20px;">{{ item.description }}</span>
+                      </el-tooltip>
+                    </div>
                 </span>
-              </div>
-          </el-upload>
-          <el-dialog :visible.sync="dialogVisible">
-            <img width="100%" :src="dialogImageUrl" alt="">
-          </el-dialog>
+            </div>
+          </el-collapse-item>
+          <el-form-item label="鍚堝悓闄勪欢" prop="attachment" class="top">
+            <file-upload v-model="form.attachment"/>
+          </el-form-item>
+            <el-link class="top" v-for="item in contractInfo.attachment != null ? contractInfo.attachment.split(',') : contractInfo.attachment" :underline="false" :key="item" @click="handleDownload(item)">{{ item.substring(item.lastIndexOf("/") + 1) }}</el-link>
           <div style="text-align: right; margin-top: 10px;">
-            <el-button type="primary" @click="submitForm1(props.row)">鎻愪氦</el-button>
+            <el-button type="primary" @click="submitForm">鎻愪氦</el-button>
           </div>
         </el-collapse>
       </el-form>
     </el-dialog>
 
+    <!-- 鍚堝悓瀵煎叆瀵硅瘽妗� -->
+    <el-dialog :title="upload.title" :visible.sync="upload.open" width="1000px" append-to-body>
+      <el-form ref="form" :model="upload" :rules="rules" label-width="80px">
+        <el-divider content-position="left">鍚堝悓淇℃伅</el-divider>
+        <div class="row-warp">
+          <div class="row">
+            <div class="row-left">
+              <div class="block">
+                <el-form-item label="鍚堝悓鍚嶇О" prop="name">
+                  <el-input v-model="upload.name" />
+                </el-form-item>
+                <el-form-item label="鍏徃鍚嶇О" prop="unitId">
+                  <el-select v-model="upload.unitId" placeholder="璇烽�夋嫨">
+                    <el-option v-for="item in unitList" :key="item.id" :label="item.value" :value="item.id">
+                    </el-option>
+                  </el-select>
+                </el-form-item>
+                <el-form-item label="鍚堝悓鏃堕棿" prop="timezone">
+                  <el-date-picker :disabled="title === '淇敼鍚堝悓鏃堕棿'" @change="dateChange" v-model="upload.timezone"
+                    value-format="yyyy-MM-dd HH:mm:ss" type="datetimerange" align="right" unlink-panels range-separator="鑷�"
+                    start-placeholder="寮�濮嬫椂闂�" end-placeholder="缁撴潫鏃堕棿">
+                  </el-date-picker>
+                </el-form-item>
+              </div>
+            </div>
+            <div class="row-right" style="margin-left: 80px;">
+              <div class="margin-5">
+                <el-upload ref="upload" :limit="1" accept=".xlsx, .xls" :headers="upload.headers"
+                  :action="upload.url"
+                  :disabled="upload.isUploading" :on-progress="handleFileUploadProgress" :on-success="handleFileSuccess"
+                  :data="upload"
+                  :auto-upload="false" drag style="text-align: center;">
+                  <i class="el-icon-upload"></i>
+                  <div class="el-upload__text">灏嗘枃浠舵嫋鍒版澶勶紝鎴�<em>鐐瑰嚮涓婁紶</em></div>
+                  <div class="el-upload__tip text-center" slot="tip">
+                    <span>浠呭厑璁稿鍏ls銆亁lsx鏍煎紡鏂囦欢銆�</span>
+                    <el-link type="primary" :underline="false" style="font-size:12px;vertical-align: baseline;"
+                      @click="importTemplate">涓嬭浇妯℃澘</el-link>
+                  </div>
+                </el-upload>
+              </div>
+            </div>
+          </div>
+        </div>
+        <el-divider content-position="left">鑰冩牳缁撴灉搴旂敤瑙勫垯</el-divider>
+        <div class="row-warp">
+          <div class="row" v-for="(item, index) in upload.ruleList" :key="index">
+            <div class="row-left" style="flex: 0.7;">
+              <div class="block">
+                <el-form-item label="鑰冩牳鏉′欢" prop="ruleList">
+                  <el-input v-model="item.scoreCondition" style="width: 250px;" />
+                </el-form-item>
+              </div>
+            </div>
+            <div class="row-right">
+              <div class="margin-5">
+                <el-form-item label="瑙勫垯鎻忚堪" prop="ruleList">
+                  <el-input type="textarea" v-model="item.description" style="width: 300px;" />
+                  <el-button style="margin-left: 50px;" type="danger" icon="el-icon-delete" circle @click="deleteRule(index)"></el-button>
+                </el-form-item>
+              </div>
+            </div>
+          </div>
+        </div>
+        <el-button style="margin-left: 50px;" type="success" icon="el-icon-plus" circle @click="addRule"></el-button>
+    </el-form>
 
+      <div slot="footer" class="dialog-footer">
+        <el-button type="primary" @click="submitFileForm">纭� 瀹�</el-button>
+        <el-button @click="upload.open = false">鍙� 娑�</el-button>
+      </div>
+    </el-dialog>
 
   </div>
 </template>
 
 <script>
-import { listContract, getContract, delContract, addContract, updateContract } from "@/api/platform/contract";
-import {unitSelect} from "../../../api/platform/unit";
-import {deptSelect} from "../../../api/system/dept";
+import { listContract, getContract, updateContract } from "@/api/platform/contract";
+import { getRuleListByContractId } from "../../../api/platform/calculate-rule";
+import { getMoneyRulesByContractId } from "../../../api/platform/calculate-money-rule";
+import { unitSelect } from "../../../api/platform/unit";
+import { deptSelect } from "../../../api/system/dept";
+import { getToken } from "@/utils/auth";
+import { ImagePreview } from "@/components/ImagePreview";
 
 export default {
   name: "Contract",
+  comments: { ImagePreview },
   data() {
     return {
+      loading: false,
+      contractInfo: {},
+      // 鍚堝悓瀵煎叆鍙傛暟
+      upload: {
+        // 鏄惁鏄剧ず寮瑰嚭灞傦紙鍚堝悓瀵煎叆锛�
+        open: false,
+        // 寮瑰嚭灞傛爣棰橈紙鍚堝悓瀵煎叆锛�
+        title: "",
+        // 鏄惁绂佺敤涓婁紶
+        isUploading: false,
+        // 璁剧疆涓婁紶鐨勮姹傚ご閮�
+        headers: { Authorization: "Bearer " + getToken() },
+        // 涓婁紶鐨勫湴鍧�
+        url: process.env.VUE_APP_BASE_API + "/system/contract/importData",
+        ruleList: [],
+        unitId: '',
+        startTime: '',
+        endTime: ''
+      },
       dialogImageUrl: '',
       dialogVisible: false,
       disabled: false,
       props: {
         row: {
-          
+
         }
       },
       unitList: [],
@@ -255,49 +204,25 @@
       open: false,
       // 鏄惁鏄剧ず璇︽儏
       detail: false,
-      // 鏌ヨ鍙傛暟
-      queryParams: {
-        pageNum: 1,
-        pageSize: 10,
-        companyId: null,
-        companyName: null,
-        deptId: null,
-        deptName: null,
-        detail: null
-      },
-      tableData: [{
-        id: '12987122',
-        companyName: '杩愮淮鍏徃鐢�',
-        deptName: '鑷础瀵岄『鍏畨灞�',
-        startTime: '2023-12-11 10:20:20',
-        endTime: '2024-12-11 10:20:20',
-        shop: '鐜嬪皬铏庡か濡诲簵',
-        shopId: '10333'
-      }, {
-        id: '12987123',
-        companyName: '杩愮淮鍏徃涔�',
-        deptName: '鑷础澶у畨鍏畨灞�',
-        startTime: '2023-12-11 10:20:20',
-        endTime: '2023-12-11 10:20:20',
-        shop: '鐜嬪皬铏庡か濡诲簵',
-        shopId: '10333'
-      }, {
-        id: '12987125',
-        companyName: '杩愮淮鍏徃涓�',
-        deptName: '鑷础鑷祦浜曞叕瀹夊眬',
-        startTime: '2023-12-11 10:20:20',
-        endTime: '2023-12-11 10:20:20',
-        shop: '鐜嬪皬铏庡か濡诲簵',
-        shopId: '10333'
-      }],
+      ruleData: [],
+      moneyRules: [],
       // 琛ㄥ崟鍙傛暟
       form: {
       },
       // 琛ㄥ崟鏍¢獙
       rules: {
-        companyId: [
-          { required: true, message: "鍏徃id涓嶈兘涓虹┖", trigger: "blur" }
+        name: [
+          { required: true, message: "鍚堝悓鍚嶇О涓嶈兘涓虹┖", trigger: "blur" }
         ],
+        unitId: [
+          { required: true, message: "杩愮淮鍗曚綅涓嶈兘涓虹┖", trigger: "change" }
+        ],
+        timezone: [
+          { type: "array", required: true, message: "鍚堝悓鏃堕棿涓嶈兘涓虹┖", trigger: "change" }
+        ],
+        ruleList: [
+          { type: "array", required: true, message: "鑰冩牳缁撴灉搴旂敤瑙勫垯涓嶈兘涓虹┖", trigger: "submit" }
+        ]
       }
     };
   },
@@ -307,15 +232,77 @@
     this.selectDept();
   },
   methods: {
+    addRule() {
+      this.upload.ruleList.push({
+        scoreCondition: '',
+        description: ''
+      });
+    },
+    deleteRule(index) {
+      this.upload.ruleList.splice(index, 1);
+    },
+    submitForm() {
+      updateContract(this.form).then(response => {
+        this.detail = false;
+        if (response.code != 200) {
+          this.$message.error("鎿嶄綔澶辫触");
+        } else {
+          this.$message.success("鎿嶄綔鎴愬姛");
+        }
+      });
+    },
+    /** 瀵煎叆鎸夐挳鎿嶄綔 */
+    handleImport() {
+      this.upload.title = "鍚堝悓瀵煎叆";
+      this.upload.open = true;
+    },
+    /** 涓嬭浇妯℃澘鎿嶄綔 */
+    importTemplate() {
+      this.download('system/contract/importTemplate', {
+      }, `鍚堝悓瀵煎叆妯℃澘.xlsx`)
+    },
+    // 鏂囦欢涓婁紶涓鐞�
+    handleFileUploadProgress(event, file, fileList) {
+      this.upload.isUploading = true;
+    },
+    // 鏂囦欢涓婁紶鎴愬姛澶勭悊
+    handleFileSuccess(response, file, fileList) {
+      this.upload.open = false;
+      this.upload.isUploading = false;
+      this.$refs.upload.clearFiles();
+      if (response.code != 200) {
+        this.$message.warning(response.msg);
+      } else {
+        this.$message.success(response.msg);
+      }
+      this.getList();
+    },
+    // 鎻愪氦涓婁紶鏂囦欢
+    submitFileForm() {
+      let that = this;
+      this.$refs["form"].validate(valid => {
+        if (valid) {
+          that.upload.ruleList = JSON.stringify(this.upload.ruleList);
+          that.loading = true;
+          that.upload.open = false;
+          that.$refs.upload.submit().then(() => {
+            that.loading = false;
+            that.reset();
+          });
+        }
+      })
+    },
+    // 鏃堕棿閫夋嫨鍙戠敓鍙樺寲
+    dateChange() {
+      this.upload.startTime = this.upload.timezone[0];
+      this.upload.endTime = this.upload.timezone[1];
+    },
     handleRemove(file) {
       console.log(file);
     },
     handlePictureCardPreview(file) {
       this.dialogImageUrl = file.url;
       this.dialogVisible = true;
-    },
-    handleDownload(file) {
-      console.log(file);
     },
     // 杩愮淮鍏徃涓嬫媺鏁版嵁
     selectUnit() {
@@ -329,53 +316,25 @@
         this.deptList = res.data;
       })
     },
-    submitForm1() {
-      alert('鎻愪氦鎴愬姛锛�');
-      },
-    handleChange(val) {
-      console.log(val);
-    },
     /** 鏌ヨ銆愯濉啓鍔熻兘鍚嶇О銆戝垪琛� */
     getList() {
       this.loading = true;
       listContract(this.queryParams).then(response => {
-        this.contractList = response.rows;
+        this.contractList = response;
         this.total = response.total;
         this.loading = false;
       });
     },
-    // 鍙栨秷鎸夐挳
-    cancel() {
-      this.open = false;
-      this.reset();
-    },
-    // 琛ㄥ崟閲嶇疆
-    reset() {
-      this.form = {
-        id: null,
-        companyId: null,
-        companyName: null,
-        deptId: null,
-        deptName: null,
-        detail: null
-      };
-      this.resetForm("form");
-    },
-    /** 鎼滅储鎸夐挳鎿嶄綔 */
-    handleQuery() {
-      this.queryParams.pageNum = 1;
-      this.getList();
-    },
-    /** 閲嶇疆鎸夐挳鎿嶄綔 */
-    resetQuery() {
-      this.resetForm("queryForm");
-      this.handleQuery();
-    },
-    // 澶氶�夋閫変腑鏁版嵁
-    handleSelectionChange(selection) {
-      this.ids = selection.map(item => item.id)
-      this.single = selection.length!==1
-      this.multiple = !selection.length
+    /** 鑾峰彇鍚堝悓瑙勫垯 */
+    getRuleList(item) {
+      getRuleListByContractId(item.id).then(response => {
+        this.ruleData = response.data;
+        this.form.id = item.id;
+        this.contractInfo = item;
+      });
+      getMoneyRulesByContractId(item.id).then(response => {
+        this.moneyRules = response.data;
+      });
     },
     /** 鏂板鎸夐挳鎿嶄綔 */
     handleAdd() {
@@ -386,7 +345,8 @@
     /** 璇︽儏鎸夐挳鎿嶄綔 */
     handleDetail(item) {
       this.detail = true;
-      this.detailName = item.companyName
+      this.detailName = item.name;
+      this.getRuleList(item);
     },
     /** 淇敼鎸夐挳鎿嶄綔 */
     handleUpdate(row) {
@@ -398,41 +358,19 @@
         this.title = "淇敼鍚堝悓";
       });
     },
-    /** 鎻愪氦鎸夐挳 */
-    submitForm() {
-      this.$refs["form"].validate(valid => {
-        if (valid) {
-          if (this.form.id != null) {
-            updateContract(this.form).then(response => {
-              this.$modal.msgSuccess("淇敼鎴愬姛");
-              this.open = false;
-              this.getList();
-            });
-          } else {
-            addContract(this.form).then(response => {
-              this.$modal.msgSuccess("鏂板鎴愬姛");
-              this.open = false;
-              this.getList();
-            });
-          }
-        }
-      });
+    /** 涓嬭浇鎸夐挳鎿嶄綔 */
+    handleDownload (data) {
+      this.$download.resource(data);
     },
-    /** 鍒犻櫎鎸夐挳鎿嶄綔 */
-    handleDelete(row) {
-      const ids = row.id || this.ids;
-      this.$modal.confirm('鏄惁纭鍒犻櫎銆愯濉啓鍔熻兘鍚嶇О銆戠紪鍙蜂负"' + ids + '"鐨勬暟鎹」锛�').then(function() {
-        return delContract(ids);
-      }).then(() => {
-        this.getList();
-        this.$modal.msgSuccess("鍒犻櫎鎴愬姛");
-      }).catch(() => {});
-    },
-    /** 瀵煎嚭鎸夐挳鎿嶄綔 */
-    handleExport() {
-      this.download('system/contract/export', {
-        ...this.queryParams
-      }, `contract_${new Date().getTime()}.xlsx`)
+    reset () {
+      this.upload = {
+        open: false,
+        name: undefined,
+        unitId: undefined,
+        timezone: undefined,
+        ruleList: []
+      };
+      this.resetForm("form");
     }
   }
 };
@@ -442,13 +380,17 @@
 .table-expand {
   font-size: 0;
 }
-.table-expand  {
+
+.table-expand {
   width: 100%;
   color: #99a9bf;
 }
+
 .inline-input-container {
-  white-space: nowrap; /* 闃叉鍐呭鍐呴儴鐨勬崲琛� */
-  margin-right: 50px;  /* 鍙�夌殑锛岀敤浜庡湪鍏冪礌涔嬮棿娣诲姞涓�浜涢棿璺� */
+  white-space: nowrap;
+  /* 闃叉鍐呭鍐呴儴鐨勬崲琛� */
+  margin-right: 50px;
+  /* 鍙�夌殑锛岀敤浜庡湪鍏冪礌涔嬮棿娣诲姞涓�浜涢棿璺� */
   width: 7%;
 }
 
@@ -474,11 +416,51 @@
 
 .clearfix:before,
 .clearfix:after {
-    display: table;
-    content: "";
+  display: table;
+  content: "";
 }
 
 .clearfix:after {
-    clear: both
+  clear: both
 }
-</style>
\ No newline at end of file
+
+.top {
+  display: block;
+  margin-top: 10px;
+}
+</style>
+<style scoped>
+.margin-5 {
+  margin-left: 5px;
+}
+.row-warp {
+  display: flex;
+  flex-direction: column;
+}
+.row {
+  display: flex;
+  flex-direction: row;
+  align-items: center;
+  justify-content: center;
+  margin: 5px 0;
+}
+.row-left {
+  flex: 1;
+  display: flex;
+  flex-direction: row;
+}
+.row-right {
+  flex: 1;
+  display: flex;
+  flex-direction: row;
+}
+</style>
+<style>
+.el-cascader-node {
+  max-width: 300px;
+}
+.el-divider--horizontal {
+  margin-top: 50px;
+  margin-bottom: 50px;
+}
+</style>

--
Gitblit v1.8.0