From 089bf5d2378b3c4a61d795b2a92bede2c193b771 Mon Sep 17 00:00:00 2001
From: admin <344137771@qq.com>
Date: Tue, 06 Jan 2026 11:22:58 +0800
Subject: [PATCH] 1
---
src/views/modules/order/totalWithdrawalStatement.vue | 584 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 584 insertions(+), 0 deletions(-)
diff --git a/src/views/modules/order/totalWithdrawalStatement.vue b/src/views/modules/order/totalWithdrawalStatement.vue
new file mode 100644
index 0000000..f87893a
--- /dev/null
+++ b/src/views/modules/order/totalWithdrawalStatement.vue
@@ -0,0 +1,584 @@
+<template>
+ <div class="mod-totalWithdrawalStatement">
+ <el-form
+ :inline="true"
+ :model="dataForm"
+ @keyup.enter.native="getDataList(this.page)"
+ >
+ <el-form-item label="支付方式类型:">
+ <template>
+ <el-select v-model="dataForm.status" clearable placeholder="请选择">
+ <el-option
+ v-for="item in options"
+ :key="item.value"
+ :label="item.label"
+ :value="item.value"
+ >
+ </el-option>
+ </el-select>
+ </template>
+ </el-form-item>
+ <el-form-item label="支付方式名称:">
+ <el-input
+ v-model="dataForm.orderNumber"
+ placeholder="支付方式名称"
+ clearable
+ ></el-input>
+ </el-form-item>
+ <el-form-item>
+ <el-button
+ type="primary"
+ icon="el-icon-search"
+ size="small"
+ @click="getDataList()"
+ >查询</el-button
+ >
+ <el-button type="primary" size="small" @click="showConsignmentInfo()"
+ >+新增支付方式模板</el-button
+ >
+ <el-button type="primary" size="small" @click="showConsignmentInfo()"
+ >+支付方式类型 多语言配置</el-button
+ >
+ <el-button @click="clearDatas()" size="small">清空</el-button>
+ </el-form-item>
+ </el-form>
+ <div class="main">
+ <div class="content">
+ <!-- <div class="tit">
+ <el-row style="width:100%">
+ <el-col :span="6"><span class="item product">支付方式类型</span></el-col>
+ <el-col :span="6"><span class="item">支付方式名称</span></el-col>
+ <el-col :span="6"><span class="item">支付方式图片</span></el-col>
+ <el-col :span="6"><span class="item">参数1</span></el-col>
+
+ </el-row>
+ </div> -->
+ <el-table :data="tableData" style="width: 100%;text-align: center;">
+ <el-table-column prop="date" label="充提" width="150">
+ <el-table-column prop="name" label="充值" width="120">
+ <el-table-column prop="name" label="USDT" width="120">
+ </el-table-column>
+ <el-table-column prop="name" label="BTC" width="120">
+ </el-table-column>
+ <el-table-column prop="name" label="ETH" width="120">
+ </el-table-column>
+ </el-table-column>
+ <el-table-column prop="name" label="提现" width="120">
+ <el-table-column prop="name" label="USDT" width="120">
+ </el-table-column>
+ <el-table-column prop="name" label="BTC" width="120">
+ </el-table-column>
+ <el-table-column prop="name" label="ETH" width="120">
+ </el-table-column>
+ </el-table-column>
+ </el-table-column>
+ <el-table-column label="交易盈亏">
+ </el-table-column>
+ <el-table-column label="手续费">
+ </el-table-column>
+ <el-table-column label="总收益">
+ </el-table-column>
+ </el-table>
+ <div class="prod" v-for="order in dataList" :key="order.orderId">
+ <div class="prod-tit">
+ <span>订单编号:{{ order.orderNumber }}</span>
+ <span>下单时间:{{ order.createTime }}</span>
+ <!-- <span>买家:19999999999</span>
+ <span >联系电话:19999999999</span> -->
+ </div>
+ <div class="prod-cont">
+ <el-row style="width: 100%">
+ <el-col :span="12">
+ <div class="prod-item">
+ <div
+ class="items name"
+ v-for="orderItem in order.orderItems"
+ :key="orderItem.orderItemId"
+ >
+ <div class="prod-image">
+ <img
+ :src="resourcesUrl + orderItem.pic"
+ style="height: 100px; width: 100px"
+ />
+ </div>
+ <div class="prod-name">
+ <span>{{ orderItem.prodName }}</span>
+ <span class="prod-info">{{ orderItem.skuName }}</span>
+ </div>
+ <div class="prod-price">
+ <span>¥{{ orderItem.price }}</span>
+ <span>×{{ orderItem.prodCount }}</span>
+ </div>
+ </div>
+ </div>
+ </el-col>
+ <el-col :span="3" style="height: 100%">
+ <div class="item">
+ <div>
+ <span class="totalprice">¥{{ order.actualTotal }}</span>
+ <span v-if="order.freightAmount"
+ >(含运费:¥{{ order.freightAmount }})</span
+ >
+ <span>共{{ order.productNums }}件</span>
+ </div>
+ </div>
+ </el-col>
+ <el-col :span="3" style="height: 100%">
+ <div class="item">
+ <div>
+ <span v-if="order.payType === 1">微信支付</span>
+ <span v-else-if="order.payType === 2">支付宝</span>
+ <span v-else>手动代付</span>
+ </div>
+ </div>
+ </el-col>
+ <el-col :span="3" style="height: 100%">
+ <div class="item">
+ <span v-if="order.status === 1" size="small" type="danger"
+ >待付款</span
+ >
+ <span
+ v-else-if="order.status === 2"
+ size="small"
+ type="danger"
+ >待发货</span
+ >
+ <span
+ v-else-if="order.status === 3"
+ size="small"
+ type="danger"
+ >待收货</span
+ >
+ <span
+ v-else-if="order.status === 4"
+ size="small"
+ type="danger"
+ >待评价</span
+ >
+ <span
+ v-else-if="order.status === 5"
+ size="small"
+ type="danger"
+ >成功</span
+ >
+ <span v-else size="small">失败</span>
+ </div>
+ </el-col>
+ <el-col :span="3" style="height: 100%">
+ <div class="item">
+ <div class="operate">
+ <!-- <button onclick="">打印订单</button><br> -->
+ <el-button
+ v-if="isAuth('order:order:update')"
+ type="text"
+ size="small"
+ @click="addOrUpdateHandle(order.orderNumber)"
+ >查看</el-button
+ >
+ </div>
+ </div>
+ </el-col>
+ </el-row>
+ </div>
+ <div class="remark">
+ <div class="buyer-remark">
+ <span>备注:{{ order.remarks }}</span>
+ </div>
+ </div>
+ </div>
+ </div>
+ </div>
+ <!-- 空 -->
+ <div class="empty-tips">暂无数据</div>
+ <el-pagination
+ @size-change="sizeChangeHandle"
+ @current-change="currentChangeHandle"
+ :current-page="page.pageIndex"
+ :page-sizes="[10, 20, 50, 100]"
+ :page-size="page.pageSize"
+ :total="page.total"
+ layout="total, sizes, prev, pager, next, jumper"
+ >
+ </el-pagination>
+ <!-- 弹窗, 新增 / 修改 -->
+ <add-or-update
+ v-if="addOrUpdateVisible"
+ ref="addOrUpdate"
+ @refreshDataList="getDataList"
+ ></add-or-update>
+ <consignment-info
+ v-if="consignmentInfoVisible"
+ ref="consignmentInfo"
+ @inputCallback="getWaitingConsignmentExcel"
+ ></consignment-info>
+ </div>
+</template>
+
+<script>
+import AddOrUpdate from "./orderInfo";
+import ConsignmentInfo from "./consignment-info";
+export default {
+ data() {
+ return {
+ tableData:[],
+ dataForm: {},
+ dateRange: [],
+ activeName: "1",
+ options: [
+ {
+ value: 1,
+ label: "所有支付方式类型",
+ },
+ {
+ value: 2,
+ label: "银行卡",
+ },
+ {
+ value: 3,
+ label: "虚拟货币",
+ },
+ {
+ value: 4,
+ label: "微信",
+ },
+ {
+ value: 5,
+ label: "支付宝",
+ },
+ {
+ value: 6,
+ label: "PayPal",
+ },
+ {
+ value: 7,
+ label: "西联汇款",
+ },
+ {
+ value: 8,
+ label: "SWIFT国际汇款",
+ },
+ {
+ value: 9,
+ label: "其他",
+ },
+ ],
+ resourcesUrl: process.env.VUE_APP_RESOURCES_URL,
+ dataList: [],
+ page: {
+ total: 0, // 总页数
+ currentPage: 1, // 当前页数
+ pageSize: 10, // 每页显示多少条
+ },
+ dataListLoading: false,
+ dataListSelections: [],
+ addOrUpdateVisible: false,
+ consignmentInfoVisible: false,
+ };
+ },
+ components: {
+ AddOrUpdate,
+ ConsignmentInfo,
+ },
+ activated() {
+ this.getDataList(this.page);
+ },
+ methods: {
+ // 获取数据列表
+ getDataList(page, params, done) {
+ page = page === undefined ? this.page : page;
+ this.dataListLoading = true;
+ this.$http({
+ url: this.$http.adornUrl("/order/order/page"),
+ method: "get",
+ params: this.$http.adornParams(
+ Object.assign(
+ {
+ current: page == null ? this.page.currentPage : page.currentPage,
+ size: page == null ? this.page.pageSize : page.pageSize,
+ orderNumber: this.dataForm.orderNumber,
+ status: this.dataForm.status,
+ startTime: this.dateRange === null ? null : this.dateRange[0], // 开始时间
+ endTime: this.dateRange === null ? null : this.dateRange[1], // 结束时间
+ },
+ params
+ ),
+ false
+ ),
+ }).then(({ data }) => {
+ this.dataList = data.records;
+ this.page.total = data.total;
+ this.dataListLoading = false;
+ if (done) {
+ done();
+ }
+ });
+ },
+ // 清除数据
+ clearDatas() {
+ this.dataForm = {};
+ this.dateRange = [];
+ },
+ // 每页数
+ sizeChangeHandle(val) {
+ this.page.pageSize = val;
+ this.page.currentPage = 1;
+ this.getDataList(this.page);
+ },
+ // 当前页
+ currentChangeHandle(val) {
+ this.page.currentPage = val;
+ this.getDataList(this.page);
+ },
+ // 多选
+ selectionChangeHandle(val) {
+ this.dataListSelections = val;
+ },
+ orderStatus() {},
+ // 新增 / 修改
+ addOrUpdateHandle(val) {
+ this.addOrUpdateVisible = true;
+ this.$nextTick(() => {
+ this.$refs.addOrUpdate.init(val);
+ });
+ },
+ // 删除
+ deleteHandle(id) {
+ var ids = id
+ ? [id]
+ : this.dataListSelections.map((item) => {
+ return item.orderId;
+ });
+ this.$confirm(`确定进行[${id ? "删除" : "批量删除"}]操作?`, "提示", {
+ confirmButtonText: "确定",
+ cancelButtonText: "取消",
+ type: "warning",
+ })
+ .then(() => {
+ this.$http({
+ url: this.$http.adornUrl(`/prod/spec/${ids}`),
+ method: "delete",
+ data: this.$http.adornData(ids, false),
+ }).then(({ data }) => {
+ this.$message({
+ message: "操作成功",
+ type: "success",
+ duration: 1500,
+ onClose: () => {
+ this.getDataList(this.page);
+ },
+ });
+ });
+ })
+ .catch(() => {});
+ },
+ showConsignmentInfo() {
+ this.consignmentInfoVisible = true;
+ this.$nextTick(() => {
+ this.$refs.consignmentInfo.init();
+ });
+ },
+ getWaitingConsignmentExcel(consignmentInfo) {
+ this.$http({
+ url: this.$http.adornUrl("/order/order/waitingConsignmentExcel"),
+ method: "get",
+ params: this.$http.adornParams({
+ consignmentName: consignmentInfo.consignmentName,
+ consignmentMobile: consignmentInfo.consignmentMobile,
+ consignmentAddr: consignmentInfo.consignmentAddr,
+ startTime: this.dateRange === null ? null : this.dateRange[0], // 开始时间
+ endTime: this.dateRange === null ? null : this.dateRange[1], // 结束时间
+ }),
+ responseType: "blob", // 解决文件下载乱码问题
+ }).then(({ data }) => {
+ var blob = new Blob([data], {
+ type: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8",
+ });
+ const fileName = "待发货信息整理.xls";
+ const elink = document.createElement("a");
+ if ("download" in elink) {
+ // 非IE下载
+ elink.download = fileName;
+ elink.style.display = "none";
+ elink.href = URL.createObjectURL(blob);
+ document.body.appendChild(elink);
+ elink.click();
+ URL.revokeObjectURL(elink.href); // 释放URL 对象
+ document.body.removeChild(elink);
+ } else {
+ // IE10+下载
+ navigator.msSaveBlob(blob, fileName);
+ }
+ });
+ },
+ getSoldExcel() {
+ this.$http({
+ url: this.$http.adornUrl("/order/order/soldExcel"),
+ method: "get",
+ params: this.$http.adornParams({
+ startTime: this.dateRange === null ? null : this.dateRange[0], // 开始时间
+ endTime: this.dateRange === null ? null : this.dateRange[1], // 结束时间
+ }),
+ responseType: "blob", // 解决文件下载乱码问题
+ }).then(({ data }) => {
+ var blob = new Blob([data], {
+ type: "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8",
+ });
+ const fileName = "销售信息整理.xls";
+ const elink = document.createElement("a");
+ if ("download" in elink) {
+ // 非IE下载
+ elink.download = fileName;
+ elink.style.display = "none";
+ elink.href = URL.createObjectURL(blob);
+ document.body.appendChild(elink);
+ elink.click();
+ URL.revokeObjectURL(elink.href); // 释放URL 对象
+ document.body.removeChild(elink);
+ } else {
+ // IE10+下载
+ navigator.msSaveBlob(blob, fileName);
+ }
+ });
+ },
+ },
+};
+</script>
+<style lang="scss" scoped>
+.mod-totalWithdrawalStatement {
+ .tit {
+ display: flex;
+ height: 45px;
+ align-items: center;
+ background: #323338;
+ color: #ffffff;
+ }
+ .tit .item {
+ padding: 0 10px;
+ width: 10%;
+ text-align: center;
+ }
+ .tit .product {
+ width: 25%;
+ }
+ .prod-tit {
+ padding: 10px;
+ background: #f8f8f9;
+ border-left: 1px solid #dddee1;
+ border-top: 1px solid #dddee1;
+ border-right: 1px solid #dddee1;
+ }
+ .prod-tit span {
+ margin-right: 15px;
+ }
+ .prod-cont {
+ display: flex;
+ border-top: 1px solid #dddee1;
+ border-bottom: 1px solid #dddee1;
+ border-left: 1px solid #dddee1;
+ color: #495060;
+ }
+ .prod-cont .item {
+ display: flex;
+ display: -webkit-flex;
+ align-items: center;
+ justify-content: center;
+ padding: 10px;
+ // width: 10%;
+ border-right: 1px solid #dddee1;
+ text-align: center;
+ height: 100%;
+ }
+ .prod-cont .item span {
+ display: block;
+ }
+ .prod-cont .prod-item {
+ // width: 38%;
+ display: flex;
+ flex-direction: column;
+ border-right: 1px solid #dddee1;
+ }
+ .prod-name {
+ width: 55%;
+ text-align: left;
+ }
+ .prod-price {
+ position: absolute;
+ right: 40px;
+ text-align: right;
+ }
+ .prod-price span {
+ display: block;
+ margin-bottom: 10px;
+ }
+ .prod-name .prod-info {
+ display: block;
+ color: #80848f;
+ margin-top: 30px;
+ }
+ .prod-cont .items.name {
+ display: flex;
+ position: relative;
+ padding: 20px;
+ // height: 100px;
+ border-bottom: 1px solid #dddee1;
+ }
+ .prod-cont .items.name:last-child {
+ border-bottom: none;
+ }
+ .prod-image {
+ margin-right: 20px;
+ width: 100px;
+ height: 100px;
+ }
+ .prod-image img {
+ width: 100px;
+ height: 100px;
+ }
+ .item span {
+ display: block;
+ margin-bottom: 10px;
+ }
+ .item .operate {
+ color: #2d8cf0;
+ }
+ .item .totalprice {
+ color: #c00;
+ }
+ .prod .remark {
+ width: 100%;
+ height: 50px;
+ line-height: 50px;
+ background-color: #e8f7f6;
+ border-left: 1px solid #dddee1;
+ border-right: 1px solid #dddee1;
+ border-bottom: 1px solid #dddee1;
+ margin-bottom: 20px;
+ }
+ .buyer-remark {
+ padding: 0 20px;
+ overflow: hidden;
+ white-space: nowrap;
+ text-overflow: ellipsis;
+ }
+
+ .empty-tips {
+ display: block;
+ width: 100%;
+ text-align: center;
+ margin: 50px 0;
+ color: #999;
+ }
+ .el-col {
+ height: 48px;
+ border-right: 1px solid #d8d9de;
+ line-height: 48px;
+ text-align: center;
+}
+ .el-table{
+ thead{
+ background: #0c0c0c !important;
+ text-align: center !important;
+ }
+}
+}
+</style>
--
Gitblit v1.9.3