Browse Source

1. 新增

MONSTER-ygh 9 months ago
parent
commit
357717c39d

+ 14 - 14
src/views/tourism/financialManagement/cateringRefundManagement.vue

@@ -81,18 +81,20 @@
             <el-table-column label="退款单号" align="center" key="refundNo" prop="refundNo" v-if="columns[0].visible" :show-overflow-tooltip="true" />
             <el-table-column label="原订单号" align="center" key="orderId" prop="orderId" v-if="columns[1].visible" :show-overflow-tooltip="true" />
             <el-table-column label="支付单号" align="center" key="transactionId" prop="transactionId" v-if="columns[2].visible" :show-overflow-tooltip="true" />
-            <el-table-column label="下单人手机号" align="center" key="refundMobile" prop="refundMobile" v-if="columns[3].visible" :show-overflow-tooltip="true" />
-            <el-table-column label="商品名称" align="center" key="goodsName" prop="goodsName" v-if="columns[4].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="联系电话" align="center" key="refundMobile" prop="refundMobile" v-if="columns[3].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="订单来源" align="center" key="source" prop="source" v-if="columns[4].visible">
+              <template slot-scope="scope">
+                <dict-tag :options="dict.type.tourism_ticketOrders_source" :value="scope.row.source"/>
+              </template>
+            </el-table-column>
             <el-table-column label="退款申请时间" align="center" key="createTime" prop="createTime" v-if="columns[5].visible" :show-overflow-tooltip="true" />
-            <el-table-column label="退款金额" align="center" key="refundAmount" prop="refundAmount" v-if="columns[6].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="退款金额(元)" align="center" key="refundAmount" prop="refundAmount" v-if="columns[6].visible" :show-overflow-tooltip="true" />
             <el-table-column label="申请原因" align="center" key="refundReason" prop="refundReason" v-if="columns[7].visible" :show-overflow-tooltip="true" />
             <el-table-column label="退款状态" align="center" key="status" prop="status" v-if="columns[8].visible" :show-overflow-tooltip="true">
                 <template slot-scope="scope">
                     <dict-tag :options="dict.type.tourism_orderRefund_status" :value="scope.row.status"/>
                 </template>
             </el-table-column>
-            <el-table-column label="审核人" align="center" key="auditName" prop="auditName" v-if="columns[9].visible" :show-overflow-tooltip="true" />
-            <el-table-column label="审核时间" align="center" key="auditTime" prop="auditTime" v-if="columns[10].visible" :show-overflow-tooltip="true" />
             <el-table-column
               label="操作"
               align="center"
@@ -142,19 +144,19 @@
   import detailsBox from "./detailsBox/cateringRefundManagementDetails.vue"
   export default {
     name: "User",
-    dicts: ['tourism_orderRefund_status'],
+    dicts: ['tourism_orderRefund_status','tourism_ticketOrders_source'],
     components: {detailsBox},
     data() {
       return {
-        title: "商品退款管理",// 通用标题
+        title: "餐饮退款管理",// 通用标题
         configPermi: {
           add: [''], // 新增权限
-          details: ['financialManagement:productRefundManagement:details'], // 详情权限
+          details: ['financialManagement:cateringRefundManagement:details'], // 详情权限
           delect: [], // 删除权限
           edit: [], // 编辑权限
           upload: [],// 导入权限
-          export: ['financialManagement:productRefundManagement:export'],// 导出权限
-          refundAudit: ['financialManagement:productRefundManagement:refundAudit'], //审核
+          export: ['financialManagement:cateringRefundManagement:export'],// 导出权限
+          refundAudit: ['financialManagement:cateringRefundManagement:refundAudit'], //审核
         },
         configUrl: {
           list: '/merchant/merchantOrder/orderRefundList', // 列表地址
@@ -189,14 +191,12 @@
           { key: 0, label: `退款单号`, visible: true },
           { key: 1, label: `原订单号`, visible: true },
           { key: 2, label: `支付单号`, visible: true },
-          { key: 3, label: `下单人手机号`, visible: true },
-          { key: 4, label: `商品名称`, visible: true },
+          { key: 3, label: `联系电话`, visible: true },
+          { key: 4, label: `订单来源`, visible: true },
           { key: 5, label: `退款申请时间`, visible: true },
           { key: 6, label: `退款金额`, visible: true },
           { key: 7, label: `申请原因`, visible: true },
           { key: 8, label: `退款状态`, visible: true },
-          { key: 9, label: `审核人`, visible: true },
-          { key: 10, label: `审核时间`, visible: true },
         ],
       };
     },

+ 441 - 0
src/views/tourism/financialManagement/detailsBox/hotelsRefundManagementDetails.vue

@@ -0,0 +1,441 @@
+<template>
+  <el-dialog
+    :title="title"
+    :visible.sync="open"
+    width="70%"
+    append-to-body
+    :close-on-click-modal="false"
+    @close="cancel"
+  >
+    <div class="form-dialog-box"
+    v-loading="loading"
+    :element-loading-text="loadingText"
+    element-loading-spinner="el-icon-loading"
+    element-loading-background="rgba(0, 0, 0, 0)">
+      <div
+        v-loading="loading"
+        :element-loading-text="''"
+        element-loading-spinner="''"
+        element-loading-background="rgba(0, 0, 0, 0.8)"
+        >
+        <el-form :model="form" ref="form" :rules="rules" label-width="120px">
+          <div class="form-title"><span>订单信息</span></div>
+          <div style="display: flex;">
+            <el-form-item label="订单号:">
+              <span style="display: block; min-width: 250px;">{{ form.orderId }}</span>
+            </el-form-item>
+            
+            <el-form-item label="支付单号:">
+              <span style="display: block; min-width: 250px;">{{ form.transactionId }}</span>
+            </el-form-item>
+            <el-form-item label="应付金额:">
+              <span style="display: block; min-width: 250px;">{{ form.orderPrice }}</span>
+            </el-form-item>
+          </div>
+
+          <!-- <div style="display: flex;">
+            <el-form-item label="商品名称:">
+              <span style="display: block; min-width: 250px;">{{ form.goodsName }}</span>
+            </el-form-item>
+            <el-form-item label="商品单价:">
+              <span style="display: block; min-width: 250px;">{{ form.salePrice }}</span>
+            </el-form-item>
+            <el-form-item label="购买数量:">
+              <span style="display: block; min-width: 250px;">{{ form.saleNum }}</span>
+            </el-form-item>
+            
+          </div> -->
+
+          <div style="display: flex;">
+            <el-form-item label="实付金额:">
+              <span style="display: block; min-width: 250px;">{{ form.realPrice }}</span>
+            </el-form-item>
+            <el-form-item label="下单时间:">
+              <span style="display: block; min-width: 250px;">{{ form.orderCreateTime }}</span>
+            </el-form-item>
+            <el-form-item label="支付时间:">
+              <span style="display: block; min-width: 250px;">{{ form.payTime }}</span>
+            </el-form-item>
+          </div>
+          <div class="form-title"><span>商品信息</span></div>
+          <div style="display: flex;padding: 10px 0 15px;">
+            <el-table :data="tableList">
+              <el-table-column type="index" label="编号" align="center"  />
+              <el-table-column label="商品名称" align="center" key="goodsName" prop="goodsName" :show-overflow-tooltip="true" />
+              <el-table-column label="分类" align="center" key="classifyName" prop="classifyName" :show-overflow-tooltip="true" />
+              <el-table-column label="单价(元)" align="center" key="salePrice" prop="salePrice" :show-overflow-tooltip="true" />
+              <el-table-column label="数量" align="center" key="saleNum" prop="saleNum" :show-overflow-tooltip="true" />
+              <el-table-column label="实付金额(元)" align="center" key="priceSubtotal" prop="priceSubtotal" :show-overflow-tooltip="true" />
+            </el-table>
+          </div>
+          <div class="form-title"><span>下单人信息</span></div>
+          <div style="display: flex;">
+            <el-form-item label="姓名:">
+              <span style="display: block;min-width: 250px;">{{ form.refundName }}</span>
+            </el-form-item>
+            <el-form-item label="手机号:">
+              <span style="display: block;min-width: 250px;">{{ form.refundMobile }}</span>
+            </el-form-item>
+          </div>
+          <div class="form-title"><span>退款信息</span></div>
+          <div style="display: flex;">
+            <el-form-item label="退款单号:">
+              <span style="display: block; min-width: 250px;">{{ form.refundNo }}</span>
+            </el-form-item>
+            <el-form-item label="退款金额:">
+              <span style="display: block; min-width: 250px;">{{ form.refundAmount }}</span>
+            </el-form-item>
+            <!-- <el-form-item label="申请类型:">
+              <span style="display: block; min-width: 250px;">{{ form.memberName }}</span>
+            </el-form-item> -->
+          </div>
+          <div style="display: flex;">
+            <el-form-item label="退款原因:">
+              <span style="display: block; min-width: 250px;">{{ form.refundReason }}</span>
+            </el-form-item>
+            <el-form-item label="申请时间:">
+              <span style="display: block; min-width: 250px;">{{ form.createTime }}</span>
+            </el-form-item>
+            <el-form-item label="退款状态:">
+              <dict-tag :options="dict.type.tourism_orderRefund_status" :value="form.status"/>
+            </el-form-item>
+          </div>
+          <div style="display: flex;" v-if="form.errReason">
+            <el-form-item label="退款驳回原因:">
+              <span style="display: block; min-width: 250px;">{{ form.errReason }}</span>
+            </el-form-item>
+          </div>
+          <div style="display: flex;" v-if="form.remark">
+            <el-form-item label="审核备注:">
+              <span style="display: block; min-width: 250px;">{{ form.remark }}</span>
+            </el-form-item>
+          </div>
+          <div>
+            <el-form-item label="凭证:" prop="imags">
+              <div style="display: flex;flex-wrap: wrap;">
+                <div 
+                v-for="(item,index) in form.imags" 
+                :key="index"
+                style="width: 100px; height: 100px;position: relative;border: 1px solid #999;border-radius: 5px;margin-right: 20px;">
+                  <el-image 
+                    style="width: 100%; height: 100%"
+                    :src="item" 
+                    :preview-src-list="form.imags">
+                  </el-image>
+                </div>
+              </div>
+            </el-form-item>
+          </div>
+          <div v-if="model=='DEATILSADD'">
+            <div class="form-title" style="display: flex;align-items: flex-end;"><span>审核操作</span><i>(注意:驳回时需填写驳回原因)</i></div>
+              <div>
+                <el-form-item label="审核备注:" :error="errReasonText" label-width="100px"></el-form-item>
+                <div>
+                  <el-input
+                    type="textarea"
+                    :rows="2"
+                    placeholder="请输入审核备注"
+                    v-model="form.errReason1">
+                  </el-input>
+                </div>
+              </div>
+              <div style="display: flex;margin-top: 10px;justify-content: center;">
+                <el-button 
+                type="danger" 
+                @click="refundAudit(2)"
+                :loading="loading"
+                >驳回</el-button>
+                <el-button type="primary" :loading="loading" @click="refundAudit(1)">同意</el-button>
+              </div>
+          </div>
+        </el-form>
+      </div>
+    </div>
+    <!-- <span slot="footer" class="dialog-footer" v-if="formStatus==1">
+      <el-button @click="cancel">关闭</el-button>
+    </span> -->
+    <!-- 添加或修改对话框 End -->
+  </el-dialog>
+</template>
+
+<script>
+import { 
+  getTableDeatilsByIdApi,
+  addTableApi
+ } from '@/api/CURD'
+
+export default {
+  name: "addAndEdit",
+  dicts: ['tourism_orderRefund_status'],
+  data() {
+    return {
+      title: "",
+      model: "", // EDIT: 编辑模式 ADD : 新增模式  EDITInit : 编辑模式(需要请求详情)
+      open: false,
+      loading: false,
+      loadingText: "拼命加载数据中...",
+      formStatus: null, // 0/null : 加载中 1 : 获取详情成功 2  : 获取详情失败 
+      configUrl: {
+        add: '', // 新增地址
+        details: '/merchant/merchantOrder/orderRefundById', // 详情地址
+        edit: '', // 编辑地址
+        refundAudit: '/merchant/merchantOrder/refundAudit',// 审核接口
+      },
+      form: {
+        id: undefined,
+      },
+      rules: {},
+      scenicAreaProducts: [],// 景点产品关联
+      errReasonText: '',
+      tableList: []
+    };
+  },
+  methods: {
+    async initData(title , model, row){
+      this.title = title
+      this.open = true
+      this.loadingText = "拼命加载数据中..."
+      this.loading = true
+      this.actionUrlLoading = false
+      this.model = model
+      this.formStatus = 0
+      this.tableList = []
+      if(model=='DEATILSADD') { // 新增
+        await this.getTableDeatilsFun(row)
+        this.formStatus = 1
+      }else if(model=='DEATILS') { // 新增
+        let obj = {
+          ...row
+        }
+        this.$set(this,'form',obj)
+        this.formStatus = 1
+      }else if(model=='DEATILSInit') { // 新增
+        await this.getTableDeatilsFun(row)
+      }
+      this.loading = false
+      this.$nextTick(()=>{
+        if(this.$refs["form"]) {
+          this.$refs["form"].clearValidate();
+        }
+      })
+    },
+    /** 获取详情 */
+    async getTableDeatilsFun(row) {
+      const id = row.id
+      this.loading = true
+      try {
+        let res = await getTableDeatilsByIdApi(this.configUrl.details,{id})
+        if(res.code == 200) {
+          let obj = {
+            ...res.data,
+            avatar: res.data.avatar?res.data.avatar.split(','):[],
+            vedioUrl: res.data.vedioUrl?res.data.vedioUrl.split(','):[],
+            imags: res.data.imags?res.data.imags.split(','):[]
+        }
+        if(obj.goodsList) {
+            this.tableList = obj.goodsList
+          }
+          this.$set(this,'form',JSON.parse(JSON.stringify(obj)))
+          this.errReasonText = ''
+          this.formStatus = 1
+        }else {
+          this.$message.error('获取详情失败!!!');
+          this.formStatus = 2
+          this.loading = false
+          this.open = false;
+        }
+        this.loading = false
+      } catch (error) {
+        console.error('获取详情失败!!!!',error)
+        this.formStatus = 2
+        this.loading = false
+        this.open = false;
+      }
+    },
+    /**
+     * 重置
+     * @date 2023-11-22
+     * @returns {any}
+     */
+    reset() {
+      if(this.$refs["form"]) {
+        this.$refs["form"].clearValidate();
+      }
+    },
+    /**
+     * 关闭弹框
+     * @date 2023-11-22
+     * @returns {any}
+     */
+    cancel() {
+      this.reset();
+      this.open = false;
+    },
+    /**  审核操作  */
+    refundAudit(type){
+      if(type == 2 && !this.form.errReason1) {
+        this.errReasonText = "请输入驳回原因"
+        return
+      } 
+      this.loading = true
+      let params = {
+        refundId: this.form.id,// 退款ID-列表ID
+        status: type,
+        errReason: this.form.errReason1,
+        remark: this.form.errReason1
+      }
+      addTableApi(
+        this.configUrl.refundAudit,{
+          ...params 
+        }).then(response => {
+          this.$modal.msgSuccess(`提交成功`);
+          this.loading = false
+          this.open = false;
+          this.$emit('refresh')
+        }).catch(()=>{
+          this.$message.error("提交失败!!!");
+          this.loading = false
+        })
+    }
+  },
+};
+</script>
+
+<style lang="scss" scoped>
+.form-dialog-box {
+  padding: 0 30px;
+  padding: 0 30px;
+  min-height: 50vh;
+  max-height: 80vh;
+  overflow-y: auto;
+  >div {
+    width: 100%;
+    min-height: 50vh;
+  }
+  .form-title {
+    padding: 0 0 10px 0;
+    span {
+      display: flex;
+      color: rgba(65,80,88,1);
+      font-size: 16px;
+      font-family: SourceHanSansSC;
+      font-weight: 700;
+      line-height: 23px;
+      border-left: 4px solid rgb(22, 132, 252);
+      padding-left: 10px;
+    }
+    
+  }
+  ::v-deep .ql-editor {
+    height: 400px;
+  }
+  .upload-btn {
+    width: 100px;
+    height: 100px;
+    background-color: #fbfdff;
+    border: dashed 1px #c0ccda;
+    border-radius: 5px;
+    i {
+      font-size: 30px;
+      margin-top: 20px;
+    }
+    &-text {
+      margin-top: -10px;
+    }
+  }
+  .avatar {
+    cursor: pointer;
+  }
+}
+.el-table{
+  .upload-btn {
+    width: 100px;
+    height: 100px;
+    background-color: #fbfdff;
+    border: dashed 1px #c0ccda;
+    border-radius: 5px;
+    i {
+      font-size: 30px;
+      margin-top: 20px;
+    }
+    &-text {
+      margin-top: -10px;
+    }
+  }
+  .avatar {
+    cursor: pointer;
+  }
+}
+
+.area-container {
+  min-height: 400px;
+}
+
+::v-deep .area-wrap-city.el-cascader {
+  line-height: normal;
+  .el-input {
+    cursor: pointer;
+    width: 100% !important;
+    height: 28px !important;
+    .el-input__inner {
+      display: none !important;
+    }
+    span.el-input__suffix {
+      position: inherit !important;
+      i.el-input__icon {
+        line-height: inherit;
+        margin-left: 5px;
+      }
+    }
+
+    .el-input__wrapper {
+      box-shadow: none;
+      input {
+        display: none;
+      }
+    }
+  }
+
+  .el-cascader__tags {
+    display: none;
+  }
+}
+
+.area-city-popper {
+  .el-cascader-panel {
+    .el-scrollbar.el-cascader-menu {
+      .el-cascader-menu__wrap.el-scrollbar__wrap {
+        height: 315px;
+      }
+    }
+  }
+}
+::v-deep .avatar-uploader .el-upload {
+    border: 1px dashed #d9d9d9;
+    border-radius: 6px;
+    cursor: pointer;
+    position: relative;
+    overflow: hidden;
+  }
+  ::v-deep .avatar-uploader .el-upload:hover {
+    border-color: #409EFF;
+  }
+  ::v-deep .avatar-uploader-icon {
+    font-size: 28px;
+    color: #8c939d;
+    width: 100px;
+    height: 100px;
+    line-height: 100px;
+    text-align: center;
+  }
+  ::v-deep .avatar {
+    width: 100px;
+    height: 100px;
+    display: block;
+  }
+</style>
+<style>
+.custom-class-box {
+  z-index: 999999 !important;
+}
+</style>

+ 344 - 0
src/views/tourism/financialManagement/hotelsRefundManagement.vue

@@ -0,0 +1,344 @@
+<template>
+    <div class="app-container">
+      <el-row :gutter="20">
+        <!--用户数据-->
+        <el-col :span="24" :xs="24">
+          <el-form :model="queryParams" ref="queryForm" size="small" :inline="true" v-show="showSearch" label-width="100px">
+            <el-form-item label="原订单号">
+                <el-input
+                v-model="queryParams.orderId"
+                placeholder="请输入原订单号"
+                clearable
+                style="width: 240px;"
+                @keyup.enter.native="handleQuery"
+                />
+            </el-form-item>
+            <el-form-item label="退款单号">
+                <el-input
+                v-model="queryParams.refundNo"
+                placeholder="请输入退款单号"
+                clearable
+                style="width: 240px;"
+                @keyup.enter.native="handleQuery"
+                />
+            </el-form-item>
+            <el-form-item label="联系电话">
+                <el-input
+                v-model="queryParams.refundMobile"
+                placeholder="请输入联系电话"
+                clearable
+                style="width: 240px;"
+                @keyup.enter.native="handleQuery"
+                />
+            </el-form-item>
+            <el-form-item label="退款状态">
+                <el-select
+                v-model="queryParams.status"
+                placeholder="退款状态"
+                clearable
+                style="width: 100%"
+                >
+                <el-option
+                    v-for="dict in dict.type.tourism_orderRefund_status"
+                    :key="dict.value"
+                    :label="dict.label"
+                    :value="dict.value"
+                />
+                </el-select>
+            </el-form-item>
+            <el-form-item label="退款申请时间">
+              <el-date-picker
+                v-model="queryParams.time"
+                type="datetimerange"
+                range-separator="至"
+                start-placeholder="开始日期"
+                value-format="yyyy-MM-dd HH:mm:ss"
+                end-placeholder="结束日期">
+                </el-date-picker>
+            </el-form-item>
+            <el-form-item>
+              <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
+              <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
+            </el-form-item>
+          </el-form>
+  
+          <el-row :gutter="10" class="mb8">
+            <el-col :span="1.5">
+            <el-button
+              type="warning"
+              plain
+              icon="el-icon-download"
+              size="mini"
+              @click="handleExport"
+              v-hasPermi="configPermi.export"
+            >导出</el-button>
+          </el-col>
+            <right-toolbar :showSearch.sync="showSearch" @queryTable="getList" :columns="columns"></right-toolbar>
+          </el-row>
+  
+          <el-table v-loading="loading" :data="tableList" @selection-change="handleSelectionChange">
+            <el-table-column type="index" label="序号" align="center"  />
+            <el-table-column label="退款单号" align="center" key="refundNo" prop="refundNo" v-if="columns[0].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="原订单号" align="center" key="orderId" prop="orderId" v-if="columns[1].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="支付单号" align="center" key="transactionId" prop="transactionId" v-if="columns[2].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="联系电话" align="center" key="refundMobile" prop="refundMobile" v-if="columns[3].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="所属酒店" align="center" key="goodsName" prop="goodsName" v-if="columns[4].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="预定数量" align="center" key="goodsName" prop="goodsName" v-if="columns[5].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="订单来源" align="center" key="goodsName" prop="goodsName" v-if="columns[6].visible" :show-overflow-tooltip="true">
+              <template slot-scope="scope">
+                <dict-tag :options="dict.type.tourism_ticketOrders_source" :value="scope.row.source"/>
+              </template>
+            </el-table-column>
+            <el-table-column label="退款申请时间" align="center" key="createTime" prop="createTime" v-if="columns[7].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="退款金额(元)" align="center" key="refundAmount" prop="refundAmount" v-if="columns[8].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="申请原因" align="center" key="refundReason" prop="refundReason" v-if="columns[9].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="退款状态" align="center" key="status" prop="status" v-if="columns[10].visible" :show-overflow-tooltip="true">
+                <template slot-scope="scope">
+                    <dict-tag :options="dict.type.tourism_orderRefund_status" :value="scope.row.status"/>
+                </template>
+            </el-table-column>
+            <el-table-column
+              label="操作"
+              align="center"
+              width="160"
+              class-name="small-padding fixed-width"
+            >
+              <template slot-scope="scope" >
+                <el-button
+                size="mini"
+                type="text"
+                icon="el-icon-document"
+                @click="handleDetails(scope.row)"
+                v-hasPermi="configPermi.details"
+                >详情</el-button>
+                <el-button
+                size="mini"
+                type="text"
+                icon="el-icon-coordinate"
+                v-if="scope.row.status == 0"
+                @click="refundAuditFun(scope.row)"
+                v-hasPermi="configPermi.refundAudit"
+                >审核</el-button>
+              </template>
+            </el-table-column>
+          </el-table>
+  
+          <pagination
+            v-show="total>0"
+            :total="total"
+            :page.sync="queryParams.pageNum"
+            :limit.sync="queryParams.pageSize"
+            @pagination="getList"
+          />
+        </el-col>
+      </el-row>
+      <!--  详情  -->
+      <detailsBox ref="detailsBox" @refresh="getList" />
+    </div>
+  </template>
+  
+  <script>
+  import { 
+    listTableApi, 
+    delTableParamsApi, 
+    updateTableApi
+  } from "@/api/CURD";
+  import detailsBox from "./detailsBox/hotelsRefundManagementDetails.vue"
+  export default {
+    name: "User",
+    dicts: ['tourism_orderRefund_status','tourism_ticketOrders_source'],
+    components: {detailsBox},
+    data() {
+      return {
+        title: "酒店退款管理",// 通用标题
+        configPermi: {
+          add: [''], // 新增权限
+          details: ['financialManagement:hotelsRefundManagementDetails:details'], // 详情权限
+          delect: [], // 删除权限
+          edit: [], // 编辑权限
+          upload: [],// 导入权限
+          export: ['financialManagement:hotelsRefundManagementDetails:export'],// 导出权限
+          refundAudit: ['financialManagement:hotelsRefundManagementDetails:refundAudit'], //审核
+        },
+        configUrl: {
+          list: '/merchant/merchantOrder/orderRefundList', // 列表地址
+          delect: '', // 删除地址
+          upload: '',// 导入地址
+          download:'', // 下载模板地址
+          export: '/merchant/merchantOrder/exportFoodExcel',// 导出地址
+          edit: '', // 编辑地址
+        },
+        // 遮罩层
+        loading: true,
+        // 选中数组
+        ids: [],
+        // 非单个禁用
+        single: true,
+        // 非多个禁用
+        multiple: true,
+        // 显示搜索条件
+        showSearch: true,
+        // 总条数
+        total: 0,
+        // 用户表格数据
+        tableList: null,
+        // 查询参数
+        queryParams: {
+          pageNum: 1,
+          pageSize: 10,
+        },
+        dateRange: [],
+        // 控制列表是否显示
+        columns: [
+          { key: 0, label: `退款单号`, visible: true },
+          { key: 1, label: `原订单号`, visible: true },
+          { key: 2, label: `支付单号`, visible: true },
+          { key: 3, label: `联系电话`, visible: true },
+          { key: 4, label: `所属酒店`, visible: true },
+          { key: 4.5, label: `预定数量`, visible: true },
+          { key: 4.6, label: `订单来源`, visible: true },
+          { key: 5, label: `退款申请时间`, visible: true },
+          { key: 6, label: `退款金额`, visible: true },
+          { key: 7, label: `申请原因`, visible: true },
+          { key: 8, label: `退款状态`, visible: true },
+        ],
+      };
+    },
+    created() {
+      this.getList();
+    },
+    methods: {
+      /** 查询用户列表 */
+      getList() {
+        this.loading = true;
+        let params = JSON.parse(JSON.stringify({
+            ...this.queryParams,
+            orderType: 5,
+            startCreateTime: this.queryParams.time&&this.queryParams.time[0]?this.queryParams.time[0]:null,
+            endCreateTime: this.queryParams.time&&this.queryParams.time[1]?this.queryParams.time[1]:null,
+        }))
+        delete params.time;
+        listTableApi(
+          this.configUrl.list,
+          this.addDateRange(
+            params,
+            this.dateRange)).then(response => {
+              this.tableList = response.data.rows;
+              this.total = response.data.total;
+              this.loading = false;
+          }
+        ).catch (error=>{
+          console.error('获取列表失败!!!!',error)
+          this.tableList = [];
+          this.total = 0;
+          this.loading = false
+        }) 
+      },
+      /** 搜索按钮操作 */
+      handleQuery() {
+        this.queryParams.pageNum = 1;
+        this.getList();
+      },
+      /** 重置按钮操作 */
+      resetQuery() {
+        this.dateRange = [];
+        this.queryParams = {
+          pageNum: 1,
+          pageSize: 10,
+        }
+        this.handleQuery();
+      },
+      // 多选框选中数据
+      handleSelectionChange(selection) {
+        this.ids = selection.map(item => item.id);
+        this.single = selection.length != 1;
+        this.multiple = !selection.length;
+      },
+      /** 新增按钮操作 */
+      handleAdd() {
+        if(this.$refs.addAndEdit) {
+          this.$refs.addAndEdit.initData(this.title + '新增', "ADD",{})
+        }
+      },
+      /** 修改按钮操作 */
+      handleUpdate(row) {
+        if(this.$refs.addAndEdit) {
+          this.$refs.addAndEdit.initData(this.title + '编辑', "EDITInit",{...row})
+        }
+      },
+      /**    */
+      handleDetails(row){
+        if(this.$refs.detailsBox) {
+          this.$refs.detailsBox.initData(this.title + '详情',"DEATILSInit", row)
+        }
+      },
+      /**    */
+      refundAuditFun(row){
+        if(this.$refs.detailsBox) {
+          this.$refs.detailsBox.initData(this.title + '审核',"DEATILSADD", row)
+        }
+      },
+      /** 删除按钮操作 */
+      handleDelete(row) {
+        const ids = row.id || this.ids;
+        this.$modal.confirm('是否确认删除数据项?').then( () => {
+          return delTableParamsApi(this.configUrl.delect,{
+            id: ids
+          });
+        }).then(() => {
+          this.getList();
+          this.$modal.msgSuccess("删除成功");
+        }).catch((e) => {
+          console.error("删除失败====",e)
+        });
+      },
+      /** 导出按钮操作 */
+      /** 导出按钮操作 */
+      handleExport() {
+        
+        let params = JSON.parse(JSON.stringify({
+            ...this.queryParams,
+            startCreateTime: this.queryParams.time&&this.queryParams.time[0]?this.queryParams.time[0]:null,
+            endCreateTime: this.queryParams.time&&this.queryParams.time[1]?this.queryParams.time[1]:null,
+            orderType: 5,
+        }))
+        delete params.time;
+        delete params.pageSize;
+        delete params.pageNum;
+        this.downloadGet(this.configUrl.export, {
+          ...params
+        }, `${this.title }_${new Date().getTime()}.xlsx`)
+      },
+      /** 导入按钮操作 */
+      handleImport() {
+        if(this.$refs.upload) {
+          this.$refs.upload.initData({
+            width: '400px',
+            // 弹出层标题(用户导入)
+            title: this.title + "导入",
+            // 下载模板地址
+            importTemplate: this.configUrl.download,
+            // 上传的地址
+            url: this.configUrl.upload
+          })
+        }
+      },
+      /** 开/闭 园 */
+      openAttraction(row) {
+        console.log("row======",row)
+        this.$modal.confirm(`是否确认${row.status == 1 ? '关闭' : '打开'} ${row.titleName}吗?`).then( () => {
+          return updateTableApi(this.configUrl.edit,{
+            ...row,
+            status: row.status == 1 ? 0 : 1
+          });
+        }).then(() => {
+          this.getList();
+          this.$modal.msgSuccess(`${row.status == 1 ? '打开' : '关闭'}成功`);
+        }).catch((e) => {
+          console.error("失败====",e)
+        });
+      },
+    }
+  };
+  </script>
+  

+ 1 - 1
src/views/tourism/financialManagement/productRefundManagement.vue

@@ -84,7 +84,7 @@
             <el-table-column label="下单人手机号" align="center" key="refundMobile" prop="refundMobile" v-if="columns[3].visible" :show-overflow-tooltip="true" />
             <el-table-column label="商品名称" align="center" key="goodsName" prop="goodsName" v-if="columns[4].visible" :show-overflow-tooltip="true" />
             <el-table-column label="退款申请时间" align="center" key="createTime" prop="createTime" v-if="columns[5].visible" :show-overflow-tooltip="true" />
-            <el-table-column label="退款金额" align="center" key="refundAmount" prop="refundAmount" v-if="columns[6].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="退款金额(元)" align="center" key="refundAmount" prop="refundAmount" v-if="columns[6].visible" :show-overflow-tooltip="true" />
             <el-table-column label="申请原因" align="center" key="refundReason" prop="refundReason" v-if="columns[7].visible" :show-overflow-tooltip="true" />
             <el-table-column label="退款状态" align="center" key="status" prop="status" v-if="columns[8].visible" :show-overflow-tooltip="true">
                 <template slot-scope="scope">

+ 6 - 6
src/views/tourism/orderManagement/cateringOrders/detailsBox/cateringOrdersDetails.vue

@@ -33,7 +33,7 @@
           </div>
           <div style="display: flex;">
             <el-form-item label="下单数量:">
-              <span style="display: inline-block;width: 250px;">{{ form.createTime }}</span>
+              <span style="display: inline-block;width: 250px;">{{ form.quantity }}</span>
             </el-form-item>
             <el-form-item label="订单金额(元):">
               <span style="display: inline-block;width: 250px;">{{ form.orderPrice }}</span>
@@ -89,9 +89,9 @@
             <el-table :data="tableList">
               <el-table-column type="index" label="编号" align="center"  />
               <el-table-column label="菜品名称" align="center" key="goodsName" prop="goodsName" :show-overflow-tooltip="true" />
-              <el-table-column label="价格" align="center" key="classifyName" prop="classifyName" :show-overflow-tooltip="true" />
-              <el-table-column label="下单数量" align="center" key="salePrice" prop="salePrice" :show-overflow-tooltip="true" />
-              <el-table-column label="实付金额(元)" align="center" key="priceSubtotal" prop="priceSubtotal" :show-overflow-tooltip="true" />
+              <el-table-column label="价格(元)" align="center" key="salePrice" prop="salePrice" :show-overflow-tooltip="true" />
+              <el-table-column label="下单数量" align="center" key="saleNum" prop="saleNum" :show-overflow-tooltip="true" />
+              <el-table-column label="实付金额(元)" align="center" key="realPrice" prop="realPrice" :show-overflow-tooltip="true" />
             </el-table>
           </div>
         </el-form>
@@ -181,8 +181,8 @@ export default {
           let obj = {
             ...res.data,
           }
-          if(obj.goodsList) {
-            this.tableList = obj.goodsList
+          if(obj.orderGoodsList) {
+            this.tableList = obj.orderGoodsList
           }
           if(obj.orderReceive) {
             obj = {

+ 1 - 1
src/views/tourism/orderManagement/hotelsOrders/detailsBox/hotelsOrdersDetails.vue

@@ -89,7 +89,7 @@
             <el-table :data="tableList">
               <el-table-column type="index" label="编号" align="center"  />
               <el-table-column label="菜品名称" align="center" key="goodsName" prop="goodsName" :show-overflow-tooltip="true" />
-              <el-table-column label="价格" align="center" key="classifyName" prop="classifyName" :show-overflow-tooltip="true" />
+              <el-table-column label="价格(元)" align="center" key="classifyName" prop="classifyName" :show-overflow-tooltip="true" />
               <el-table-column label="下单数量" align="center" key="salePrice" prop="salePrice" :show-overflow-tooltip="true" />
               <el-table-column label="实付金额(元)" align="center" key="priceSubtotal" prop="priceSubtotal" :show-overflow-tooltip="true" />
             </el-table>