金币钻石暂存
This commit is contained in:
		
							
								
								
									
										297
									
								
								src/views/refund/goldDiamondOperationRecord.vue
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										297
									
								
								src/views/refund/goldDiamondOperationRecord.vue
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,297 @@ | ||||
| <template> | ||||
|   <div class="box"> | ||||
|     <!-- 分区 --> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">分区</span> | ||||
|         <el-select | ||||
|           v-model="inquire.partitionId" | ||||
|           style="width: 75%" | ||||
|           placeholder="请选择" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in inquire.partitionArr" | ||||
|             :key="item.id" | ||||
|             :label="item.desc" | ||||
|             :value="item.id" | ||||
|           ></el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 平台ID --> | ||||
|     <div class="inquire"> | ||||
|       <span>平台ID</span> | ||||
|       <el-input | ||||
|         v-model="inquire.userId" | ||||
|         placeholder="" | ||||
|         class="input" | ||||
|       ></el-input> | ||||
|     </div> | ||||
|     <!-- 赠送类型 --> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">赠送类型</span> | ||||
|         <el-select | ||||
|           v-model="inquire.platform" | ||||
|           style="width: 75%" | ||||
|           placeholder="请选择" | ||||
|         > | ||||
|           <el-option | ||||
|             v-for="item in inquire.platformArr" | ||||
|             :key="item.id" | ||||
|             :label="item.desc" | ||||
|             :value="item.id" | ||||
|           ></el-option> | ||||
|         </el-select> | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 时间选择器 --> | ||||
|     <div class="inquire"> | ||||
|       <div class="block"> | ||||
|         <span class="demonstration">时间</span> | ||||
|         <el-date-picker | ||||
|           v-model="inquire.time" | ||||
|           type="daterange" | ||||
|           range-separator="至" | ||||
|           start-placeholder="开始日期" | ||||
|           end-placeholder="结束日期" | ||||
|         > | ||||
|         </el-date-picker> | ||||
|       </div> | ||||
|     </div> | ||||
|     <!-- 查询按钮 --> | ||||
|     <el-button class="primary" type="primary" @click="getData()" | ||||
|       >搜索</el-button | ||||
|     > | ||||
|     <el-button | ||||
|       class="primary" | ||||
|       type="primary" | ||||
|       @click=" | ||||
|         inquire.partitionId = inquire.partitionArr[0].id; | ||||
|         inquire.userId = ''; | ||||
|         inquire.platform = ''; | ||||
|         inquire.time = ''; | ||||
|         getData(); | ||||
|       " | ||||
|       >重置搜索</el-button | ||||
|     > | ||||
|     <el-button class="primary" type="primary" @click="exportInfoFun()" | ||||
|       >导出</el-button | ||||
|     > | ||||
|     <div> | ||||
|       <el-button v-for="(value, key) in sortedMapObj" :key="key" type="text" | ||||
|         >{{ key }}: {{ value }}, | ||||
|       </el-button> | ||||
|     </div> | ||||
|     <!-- 表格 --> | ||||
|     <el-table | ||||
|       v-loading="loading" | ||||
|       :data="tableData" | ||||
|       border | ||||
|       style="width: 100%; margin-top: 25px" | ||||
|     > | ||||
|       <el-table-column prop="chargeStatusDesc" align="center" label="操作时间"> | ||||
|       </el-table-column> | ||||
|       <el-table-column prop="chargeRecordId" align="center" label="用户ID" /> | ||||
|       <el-table-column prop="channel" align="center" label="用户昵称" /> | ||||
|       <el-table-column prop="erbanNo" align="center" label="区域" /> | ||||
|       <el-table-column prop="nick" align="center" label="实时金币余额" /> | ||||
|       <el-table-column | ||||
|         prop="partitionDesc" | ||||
|         align="center" | ||||
|         label="赠送金币数量" | ||||
|       /> | ||||
|       <el-table-column prop="phone" align="center" label="赠送钻石数量" /> | ||||
|       <el-table-column prop="os" align="center" label="赠送类型" /> | ||||
|       <el-table-column prop="genderDesc" align="center" label="赠送分类" /> | ||||
|       <el-table-column prop="chargeIp" align="center" label="打款金额" /> | ||||
|       <el-table-column prop="totalGold" align="center" label="备注" /> | ||||
|       <el-table-column prop="amount" align="center" label="操作人" /> | ||||
|     </el-table> | ||||
|     <!-- 分页 --> | ||||
|     <el-pagination | ||||
|       style="margin-top: 10px" | ||||
|       class="paginationClass" | ||||
|       v-model:current-page="currentPage" | ||||
|       v-model:page-size="pageSize" | ||||
|       :page-sizes="[10, 20, 30, 40, 50, 100, 200, 300, 400, 500, 999999999]" | ||||
|       layout="sizes, prev, pager, next" | ||||
|       :total="total" | ||||
|       @size-change="handleSizeChange" | ||||
|       @current-change="handleCurrentChange" | ||||
|     /> | ||||
|   </div> | ||||
| </template> | ||||
| <script> | ||||
| import { | ||||
|   listPartitionInfo, | ||||
|   refundList, | ||||
|   regionInfoList, | ||||
|   refundExport, | ||||
| } from "@/api/refund/refund"; | ||||
| // @ts-ignore | ||||
| import { dateFormat } from "@/utils/system-helper"; | ||||
| // @ts-ignore | ||||
| import { ElMessage } from "element-plus"; | ||||
| export default { | ||||
|   name: "goldDiamondOperationRecord", | ||||
|   computed: { | ||||
|     sortedMapObj() { | ||||
|       const entries = Object.entries(this.mapObj); | ||||
|       // 将 "总充值{USD}" 的键排到第一位 | ||||
|       entries.sort(([keyA], [keyB]) => | ||||
|         keyA === "总充值{USD}" ? -1 : keyB === "总充值{USD}" ? 1 : 0 | ||||
|       ); | ||||
|       return Object.fromEntries(entries); | ||||
|     }, | ||||
|   }, | ||||
|   data() { | ||||
|     return { | ||||
|       loading: false, | ||||
|       delDialog: false, | ||||
|       delDialogData: null, | ||||
|       mapObj: {}, | ||||
|       //查询所需条件对象 | ||||
|       inquire: { | ||||
|         partitionId: 0, | ||||
|         partitionArr: [], | ||||
|         userId: "", | ||||
|         platform: "", | ||||
|         platformArr: [ | ||||
|           { desc: "全部", id: "" }, | ||||
|           { desc: "官方赠送金币", id: "OFFICAL_DIAMOND" }, | ||||
|           { desc: "官方赠送水晶", id: "OFFICAL_RADISH" }, | ||||
|           { desc: "活动奖励钻石", id: "ACTIVITY_GOLD" }, | ||||
|           { desc: "公款充值金币", id: "COMPANY_ACCOUNT_DIAMOND" }, | ||||
|           { desc: "官方金币消除", id: "OFFICAL_REDUCE_DIAMONDS" }, | ||||
|           { desc: "官方赠送钻石", id: "OFFICAL_GOLD" }, | ||||
|           { desc: "用户钻石清除", id: "CLEAR_USER_GOLD" }, | ||||
|         ], | ||||
|         time: "", | ||||
|       }, | ||||
|       // 表格 | ||||
|       tableData: [], | ||||
|       // 分页 | ||||
|       total: 10, //总页数 | ||||
|       currentPage: 1, //页码 | ||||
|       pageSize: 10, //条数 | ||||
|     }; | ||||
|   }, | ||||
|   created() { | ||||
|     listPartitionInfo().then((res) => { | ||||
|       this.inquire.partitionArr = res.data; | ||||
|       this.inquire.partitionId = this.inquire.partitionArr[0].id; | ||||
|     }); | ||||
|     regionInfoList().then((res) => { | ||||
|       this.inquire.countryArr = res.data; | ||||
|     }); | ||||
|   }, | ||||
|   methods: { | ||||
|     // 查询接口 | ||||
|     getData() { | ||||
|       this.loading = true; | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd 00:00:00"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd 23:59:59"); | ||||
|       } | ||||
|       refundList({ | ||||
|         partitionId: this.inquire.partitionId, | ||||
|         channel: this.inquire.paymentChannels, | ||||
|         chargeRecordId: this.inquire.rechargeNumber, | ||||
|         pingxxChargeId: this.inquire.partyNumber, | ||||
|         refundStatus: this.inquire.status, | ||||
|         regionId: this.inquire.country, | ||||
|         os: this.inquire.platform, | ||||
|         erbanNo: this.inquire.userId, | ||||
|         pageNo: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|         beginDate: startTime, | ||||
|         endDate: endTime, | ||||
|       }).then((res) => { | ||||
|         if (res.code == 200) { | ||||
|           this.total = res.data.total; | ||||
|           this.tableData = res.data.rows; | ||||
|           this.mapObj = res.data.totalMap; | ||||
|         } else { | ||||
|           ElMessage({ | ||||
|             showClose: true, | ||||
|             message: res.message, | ||||
|             type: "error", | ||||
|           }); | ||||
|         } | ||||
|         this.loading = false; | ||||
|       }); | ||||
|     }, | ||||
|     jsonFun(val) { | ||||
|       return JSON.parse(val); | ||||
|     }, | ||||
|     exportInfoFun() { | ||||
|       let time = this.inquire.time; | ||||
|       let startTime = ""; | ||||
|       let endTime = ""; | ||||
|       if (time && time.length > 0) { | ||||
|         startTime = dateFormat(this.inquire.time[0], "yyyy-MM-dd 00:00:00"); | ||||
|         endTime = dateFormat(this.inquire.time[1], "yyyy-MM-dd 23:59:59"); | ||||
|       } | ||||
|       refundExport({ | ||||
|         partitionId: this.inquire.partitionId, | ||||
|         channel: this.inquire.paymentChannels, | ||||
|         chargeRecordId: this.inquire.rechargeNumber, | ||||
|         pingxxChargeId: this.inquire.partyNumber, | ||||
|         refundStatus: this.inquire.status, | ||||
|         regionId: this.inquire.country, | ||||
|         os: this.inquire.platform, | ||||
|         erbanNo: this.inquire.userId, | ||||
|         pageNo: this.currentPage, | ||||
|         pageSize: this.pageSize, | ||||
|         beginDate: startTime, | ||||
|         endDate: endTime, | ||||
|       }).then(); | ||||
|     }, | ||||
|     // 分页导航 | ||||
|     handleSizeChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|     handleCurrentChange() { | ||||
|       this.getData(); | ||||
|     }, | ||||
|   }, | ||||
| }; | ||||
| </script> | ||||
| <style lang="less" scoped> | ||||
| .box { | ||||
|   padding-top: 20px; | ||||
|   background: #ecf0f5; | ||||
|   .inquire { | ||||
|     display: inline-block; | ||||
|     margin-right: 20px; | ||||
|     margin-bottom: 10px; | ||||
|     span { | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|     .input { | ||||
|       width: 180px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|   } | ||||
|   .dialogTableVisibleBut { | ||||
|     display: block; | ||||
|     margin: 30px 0 0 830px; | ||||
|   } | ||||
|   .paginationClass { | ||||
|     margin: 15px 0 5px 0px; | ||||
|   } | ||||
| } | ||||
| .selectBox { | ||||
|   display: flex; | ||||
|   height: 35px; | ||||
|   line-height: 35px; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| .selectBoxImg { | ||||
|   height: 150px; | ||||
| } | ||||
| </style> | ||||
		Reference in New Issue
	
	Block a user
	 dragon
					dragon