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/prod/prodTag.vue |  457 +++++++++++++++++++++++++++++++++++++++++++++++++++++++++
 1 files changed, 457 insertions(+), 0 deletions(-)

diff --git a/src/views/modules/prod/prodTag.vue b/src/views/modules/prod/prodTag.vue
new file mode 100644
index 0000000..0195bd5
--- /dev/null
+++ b/src/views/modules/prod/prodTag.vue
@@ -0,0 +1,457 @@
+<template>
+  <div class="mod-prod-prodTag">
+    <el-form :inline="true"
+             :model="dataForm"
+             @keyup.enter.native="getDataList(this.page)">
+      <el-form-item label="订单号:">
+        <el-input v-model="dataForm.orderNumber"
+                  placeholder="订单号(完整)"
+                  clearable></el-input>
+      </el-form-item>
+      <el-form-item label="用户名/UID:">
+        <el-input v-model="dataForm.orderNumber2"
+                  placeholder="用户名、UID"
+                  clearable></el-input>
+      </el-form-item>
+      <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>
+        <el-button type="primary"
+                   icon="el-icon-search"
+                   size="small"
+                   @click="getDataList()">查询</el-button>
+        <el-button @click="clearDatas()"
+                   size="small">清空</el-button>
+      </el-form-item>
+    </el-form>
+    <el-form :inline="true"
+             :model="dataForm2"
+             @keyup.enter.native="getDataList(this.page)">
+       <el-form-item label="系统时间:">
+        <el-date-picker v-model="dateRange"
+                        type="datetimerange"
+                        range-separator="至"
+                        value-format="yyyy-MM-dd HH:mm:ss"
+                        start-placeholder="开始日期"
+                        end-placeholder="结束日期">
+        </el-date-picker>
+      </el-form-item>
+      <el-form-item>
+        <el-button type="primary"
+                   size="small"
+                   @click="getDataList()">利息重计</el-button>
+      </el-form-item>
+    </el-form>
+    <div class="main">
+      <el-tabs v-model="activeName" @tab-click="handleClick">
+        <el-tab-pane label="全部" name="1"></el-tab-pane>
+        <el-tab-pane label="赎回" name="2"></el-tab-pane>
+        <el-tab-pane label="托管中" name="3"></el-tab-pane>
+        <el-tab-pane label="违约" name="4"></el-tab-pane>
+      </el-tabs>
+      <div class="content">
+        <div class="tit">
+          <el-row style="width:100%">
+            <el-col :span="2"><span class="item product">用户</span></el-col>
+            <el-col :span="2"><span class="item">UID</span></el-col>
+            <el-col :span="3"><span class="item">账户类型</span></el-col>
+            <el-col :span="3"><span class="item">产品名称</span></el-col>
+            <el-col :span="3"><span class="item">产品名称(英文)</span></el-col>
+            <el-col :span="1"><span class="item">金额 </span></el-col>
+            <el-col :span="2"><span class="item">收益</span></el-col>
+            <el-col :span="3"><span class="item">买入时间</span></el-col>
+            <el-col :span="3"><span class="item">赎回时间</span></el-col>
+            <el-col :span="2"><span class="item">状态</span></el-col>
+          </el-row>
+        </div>
+        <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 { tableOption } from '@/crud/prod/prodTag'
+import AddOrUpdate from './prodTag-add-or-update'
+export default {
+  data () {
+    return {
+      dataForm: {},
+      dataForm2:{},
+      dataList: [],
+      dateRange: [],
+      activeName:'1',
+      options: [{
+        value: 1,
+        label: '所有账号'
+      },
+      {
+        value: 2,
+        label: '正式账号'
+      },
+      {
+        value: 3,
+        label: '演示账号'
+      },
+      {
+        value: 4,
+        label: '试用账号'
+      }],
+      page: {
+        total: 0, // 总页数
+        currentPage: 1, // 当前页数
+        pageSize: 10 // 每页显示多少条
+      },
+      dataListLoading: false,
+      consignmentInfoVisible: false,
+      tableOption: tableOption,
+      permission: {
+        delBtn: this.isAuth('prod:prodTag:delete')
+      },
+      addOrUpdateVisible: false
+    }
+  },
+  components: {
+    AddOrUpdate
+  },
+  created () {
+  },
+  mounted () {
+  },
+  methods: {
+    getDataList (page, params, done) {
+      this.dataListLoading = true
+      this.$http({
+        url: this.$http.adornUrl('/prod/prodTag/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
+        }, params))
+      }).then(({ data }) => {
+        this.dataList = data.records
+        this.page.total = data.total
+        this.dataListLoading = false
+        if (done) {
+          done()
+        }
+      })
+    },
+    // 新增 / 修改
+    addOrUpdateHandle (id) {
+      this.addOrUpdateVisible = true
+      this.$nextTick(() => {
+        this.$refs.addOrUpdate.init(id)
+      })
+    },
+    deleteHandle (id) {
+      this.$confirm('确定进行删除操作?', '提示', {
+        confirmButtonText: '确定',
+        cancelButtonText: '取消',
+        type: 'warning'
+      }).then(() => {
+        this.$http({
+          url: this.$http.adornUrl('/prod/prodTag/' + id),
+          method: 'delete',
+          data: this.$http.adornData({})
+        }).then(({ data }) => {
+          this.$message({
+            message: '操作成功',
+            type: 'success',
+            duration: 1500,
+            onClose: () => {
+              this.getDataList(this.page)
+            }
+          })
+        })
+      }).catch(() => { })
+    },
+    handleClick(tab, event) {
+        console.log(tab, event)
+    },
+    // 清除数据
+    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)
+    },      
+    /**
+     * 刷新回调
+     */
+    refreshChange () {
+      this.getDataList(this.page)
+    },
+    searchChange (params, done) {
+      this.getDataList(this.page, params, done)
+    }
+  }
+}
+</script>
+
+<style lang="scss" scoped>
+.mod-prod-prodTag{
+  .tit {
+    display: flex;
+    height: 45px;
+    align-items: center;
+    background: #323338;
+    color: #FFFFFF;
+  }
+  .el-form:nth-child(1){
+    margin-bottom: 50px;
+  }
+  .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;
+}
+}
+
+</style>

--
Gitblit v1.9.3