203 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
		
		
			
		
	
	
			203 lines
		
	
	
		
			4.8 KiB
		
	
	
	
		
			Vue
		
	
	
	
	
	
|   | <template> | ||
|  |   <view class="container"> | ||
|  |     <!-- 时间选择器 --> | ||
|  |     <view class="date-picker"> | ||
|  |       <view @click="show = true" class="date-picker-button">选择月份</view> | ||
|  |       <span class="selected-date" v-if="rescueStartMonth">已选时间: {{ rescueStartMonth }}</span> | ||
|  |       <view @click="clearDate" class="clear-date-button" v-if="rescueStartMonth">清除时间</view> | ||
|  |     </view> | ||
|  |     <u-datetime-picker | ||
|  |         :show="show" | ||
|  |         v-model="value1" | ||
|  |         mode="year-month" | ||
|  |         @input="selectDate" | ||
|  |     ></u-datetime-picker> | ||
|  | 
 | ||
|  |     <!-- 总提成金额 --> | ||
|  |     <view class="total-royalty"> | ||
|  |       总提成金额: ¥{{ totalRoyalty.toFixed(2) }} | ||
|  |     </view> | ||
|  | 
 | ||
|  |     <!-- 提成记录列表 --> | ||
|  |     <view v-for="item in list" :key="item.node_id" class="list-item"> | ||
|  |       <view class="row"> | ||
|  |         <span class="label">项目名称:</span> | ||
|  |         <span class="project-name">{{ item.projectName }}</span> | ||
|  |       </view> | ||
|  |       <!--      <view class="row">--> | ||
|  |       <!--        <span class="label">处理人:</span>--> | ||
|  |       <!--        <span class="handler-name">{{ item.handlerName }}</span>--> | ||
|  |       <!--      </view>--> | ||
|  |       <view class="row"> | ||
|  |         <span class="label">提成金额:</span> | ||
|  |         <span class="royalty-amount">¥{{ item.royaltyAmount.toFixed(2) }}</span> | ||
|  |       </view> | ||
|  |       <view class="row"> | ||
|  |         <span class="label">完成时间:</span> | ||
|  |         <span class="create-time">{{ formatDate(item.node_create_time) }}</span> | ||
|  |       </view> | ||
|  |     </view> | ||
|  |   </view> | ||
|  | </template> | ||
|  | 
 | ||
|  | <script> | ||
|  | import request from "@/utils/request"; | ||
|  | 
 | ||
|  | export default { | ||
|  |   data() { | ||
|  |     return { | ||
|  |       list: [], | ||
|  |       page: 1, | ||
|  |       size: 10, | ||
|  |       total: 0, | ||
|  |       pages: 2, | ||
|  |       totalRoyalty: 0, | ||
|  |       value1: Number(new Date()), | ||
|  |       rescueStartMonth: null, | ||
|  |       show: false, | ||
|  |     }; | ||
|  |   }, | ||
|  |   onLoad() { | ||
|  |     this.getRoyalty(); | ||
|  |   }, | ||
|  |   onReachBottom() { | ||
|  |     if (this.page < this.pages) { | ||
|  |       this.page++; | ||
|  |       this.getRoyalty(); | ||
|  |     } | ||
|  |   }, | ||
|  |   methods: { | ||
|  |     getRoyalty() { | ||
|  |       request({ | ||
|  |         url: '/system/info/getRoyaltyListApp', | ||
|  |         method: 'get', | ||
|  |         params: { | ||
|  |           pageNo: this.page, | ||
|  |           pageSize: this.size, | ||
|  |           rescueStartMonth: this.rescueStartMonth | ||
|  |         } | ||
|  |       }).then(res => { | ||
|  |         this.total = res.data.total; | ||
|  |         this.page = res.data.current; | ||
|  |         this.pages = res.data.pages; | ||
|  |         this.list = [...this.list, ...res.data.records]; | ||
|  | 
 | ||
|  |         request({ | ||
|  |           url: '/system/info/getRoyaltySumApp', | ||
|  |           method: 'get', | ||
|  |           params: { | ||
|  |             rescueStartMonth: this.rescueStartMonth | ||
|  |           } | ||
|  |         }).then(res => { | ||
|  |           this.totalRoyalty = res.data.royaltyAmountSum; | ||
|  |         }) | ||
|  |       }); | ||
|  |     }, | ||
|  |     selectDate() { | ||
|  |       this.show = false; | ||
|  |       const date = new Date(this.value1); | ||
|  |       const year = date.getFullYear(); | ||
|  |       const month = (date.getMonth() + 1).toString().padStart(2, '0'); | ||
|  |       this.rescueStartMonth = `${year}-${month}`; | ||
|  |       this.list = []; | ||
|  |       this.getRoyalty(); | ||
|  |     }, | ||
|  |     clearDate() { | ||
|  |       this.rescueStartMonth = null; | ||
|  |       this.value1 = Number(new Date()); | ||
|  |       this.list = []; | ||
|  |       this.totalRoyalty = 0; | ||
|  |       this.getRoyalty(); | ||
|  |     }, | ||
|  |     formatDate(timestamp) { | ||
|  |       const date = new Date(timestamp); | ||
|  |       const year = date.getFullYear(); | ||
|  |       const month = (date.getMonth() + 1).toString().padStart(2, '0'); | ||
|  |       const day = date.getDate().toString().padStart(2, '0'); | ||
|  |       const hours = date.getHours().toString().padStart(2, '0'); | ||
|  |       const minutes = date.getMinutes().toString().padStart(2, '0'); | ||
|  |       return `${year}-${month}-${day} ${hours}:${minutes}`; | ||
|  |     } | ||
|  |   }, | ||
|  | }; | ||
|  | </script> | ||
|  | 
 | ||
|  | <style lang="scss"> | ||
|  | .container { | ||
|  |   padding: 10px; | ||
|  |   background-color: #f9f9f9; | ||
|  | } | ||
|  | 
 | ||
|  | .date-picker { | ||
|  |   display: flex; | ||
|  |   align-items: center; | ||
|  |   margin-bottom: 15px; | ||
|  |   justify-content: space-between; | ||
|  | } | ||
|  | 
 | ||
|  | .date-picker-button { | ||
|  |   background-color: #4CAF50; | ||
|  |   color: #fff; | ||
|  |   padding: 10px 20px; | ||
|  |   border-radius: 5px; | ||
|  |   text-align: center; | ||
|  |   font-weight: bold; | ||
|  |   cursor: pointer; | ||
|  |   box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); | ||
|  | } | ||
|  | 
 | ||
|  | .selected-date { | ||
|  |   color: #666; | ||
|  |   font-size: 14px; | ||
|  |   margin-left: 10px; | ||
|  | } | ||
|  | 
 | ||
|  | .clear-date-button { | ||
|  |   background-color: #ff4d4d; | ||
|  |   color: #fff; | ||
|  |   padding: 10px 20px; | ||
|  |   border-radius: 5px; | ||
|  |   text-align: center; | ||
|  |   font-weight: bold; | ||
|  |   cursor: pointer; | ||
|  |   box-shadow: 0 4px 8px rgba(0, 0, 0, 0.2); | ||
|  |   margin-left: 10px; | ||
|  | } | ||
|  | 
 | ||
|  | .total-royalty { | ||
|  |   font-size: 16px; | ||
|  |   font-weight: bold; | ||
|  |   color: #333; | ||
|  |   padding: 15px; | ||
|  |   margin-bottom: 10px; | ||
|  |   background-color: #ffffff; | ||
|  |   border-radius: 8px; | ||
|  |   box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); | ||
|  |   text-align: center; | ||
|  | } | ||
|  | 
 | ||
|  | .list-item { | ||
|  |   padding: 15px; | ||
|  |   margin-bottom: 10px; | ||
|  |   background-color: #ffffff; | ||
|  |   border-radius: 8px; | ||
|  |   box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); | ||
|  | } | ||
|  | 
 | ||
|  | .row { | ||
|  |   display: flex; | ||
|  |   align-items: center; | ||
|  |   margin: 5px 0; | ||
|  | } | ||
|  | 
 | ||
|  | .label { | ||
|  |   font-weight: bold; | ||
|  |   color: #333; | ||
|  |   min-width: 80px; | ||
|  | } | ||
|  | 
 | ||
|  | .project-name, .handler-name, .royalty-amount, .create-time { | ||
|  |   color: #666; | ||
|  | } | ||
|  | </style> |