Kaynağa Gözat

'权益卡刷卡记录'

gcz 3 ay önce
ebeveyn
işleme
7052c70155

+ 381 - 0
src/views/tourism/membershipManagement/equityCard/usageRecord.vue

@@ -0,0 +1,381 @@
+<!--
+ * @Description: 
+ * @Author: gcz
+ * @Date: 2025-02-19 15:50:54
+ * @LastEditors: gcz
+ * @LastEditTime: 2025-02-20 16:06:55
+ * @FilePath: \tourism_merchant_ui\src\views\tourism\membershipManagement\equityCard\usageRecord.vue
+ * @Copyright: Copyright (c) 2016~2025 by gcz, All Rights Reserved. 
+-->
+<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="68px">
+            <el-form-item label="卡号" prop="cardNo">
+              <el-input
+                v-model="queryParams.cardNo"
+                placeholder="请输入卡号"
+                clearable
+                style="width: 240px"
+                @keyup.enter.native="handleQuery"
+              />
+            </el-form-item>
+            <el-form-item label="持卡人" prop="name">
+              <el-input
+                v-model="queryParams.name"
+                placeholder="请输入持卡人"
+                clearable
+                style="width: 240px"
+                @keyup.enter.native="handleQuery"
+              />
+            </el-form-item>
+            <!-- <el-form-item label="手机号" prop="mobile">
+              <el-input
+                v-model="queryParams.mobile"
+                placeholder="请输入手机号"
+                clearable
+                style="width: 240px"
+                @keyup.enter.native="handleQuery"
+              />
+            </el-form-item> -->
+            <el-form-item label="刷卡时间" prop="time">
+              <el-date-picker
+                v-model="dateRange"
+                type="daterange"
+                range-separator="至"
+                start-placeholder="开始日期"
+                end-placeholder="结束日期"
+                value-format="yyyy-MM-dd"
+                style="width: 240px"
+              />
+            </el-form-item>
+            <el-form-item label="消费项目" prop="projectId">
+              <el-select v-model="queryParams.projectId" clearable placeholder="请选择消费项目">
+                <el-option
+                  v-for="item in projectList"
+                  :key="item.id"
+                  :label="item.projectName"
+                  :value="item.id"
+                />
+              </el-select>
+            </el-form-item>
+            <!-- <el-form-item label="卡种" prop="cardType">
+              <el-select v-model="queryParams.cardType" clearable placeholder="请选择卡种">
+                <el-option
+                  v-for="dict in dict.type.equity_card_type"
+                  :key="dict.value"
+                  :label="dict.label"
+                  :value="dict.value"
+                />
+              </el-select>
+            </el-form-item> -->
+            <el-form-item label="卡种" prop="cardType" label-width="50px">
+                <el-select v-model="queryParams.cardType" clearable placeholder="请选择卡种">
+                <el-option
+                    v-for="dict in tableListCopy"
+                    :key="dict.id"
+                    :label="dict.name"
+                    :value="dict.id">
+                </el-option>
+                </el-select>
+            </el-form-item>
+            <el-form-item label="刷卡设备" prop="deviceName">
+              <el-input
+                v-model="queryParams.deviceName"
+                placeholder="请输入刷卡设备"
+                clearable
+                style="width: 240px"
+                @keyup.enter.native="handleQuery"
+              />
+            </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="cardNo" prop="cardNo" v-if="columns[0].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="持卡人" align="center" key="name" prop="name" v-if="columns[1].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="手机号" align="center" key="mobile" prop="mobile" v-if="columns[2].visible" :show-overflow-tooltip="true" />
+            <el-table-column label="卡种" align="center" key="cardType" prop="cardType" v-if="columns[3].visible">
+              <template slot-scope="scope">
+                <span>{{scope.row.cardType}}</span>
+                <!-- <dict-tag :options="dict.type.equity_card_type" :value="scope.row.cardType"/> -->
+              </template>
+            </el-table-column>
+            <el-table-column label="消费项目" align="center" key="projectName" prop="projectName" 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="deviceName" prop="deviceName" v-if="columns[6].visible" :show-overflow-tooltip="true" />
+          </el-table>
+  
+          <pagination
+            v-show="total>0"
+            :total="total"
+            :page.sync="queryParams.pageNum"
+            :limit.sync="queryParams.pageSize"
+            @pagination="getList"
+          />
+        </el-col>
+      </el-row>
+    </div>
+  </template>
+  
+  <script>
+  import { 
+    listTableApi, 
+    delTableParamsApi,
+    updateTableApi,
+    addTableApi
+  } from "@/api/CURD";
+  import { checkPermi } from "@/utils/permission"
+  export default {
+    name: "UsageRecord",
+    dicts: ['equity_card_type'],
+    components: {},
+    data() {
+      return {
+        title: "权益卡管理",// 通用标题
+        configPermi: {
+          add: ['equityCard:equityCardManagement:add'], // 新增权限
+          details: ['equityCard:equityCardManagement:details'], // 详情权限
+          delect: [], // 删除权限
+          edit: [], // 编辑权限
+          upload: [''],// 导入权限
+          export: ['equityCard:usageRecord:export'],// 导出权限
+          AuthRole: ['equityCard:equityCardManagement:AuthRole'],// 设置审核
+          Password: ['equityCard:equityCardManagement:Password'], // 重置密码
+          useList: ['equityCard:equityCardManagement:uselist'], // 重置密码
+          sellingCards: ['equityCard:equityCardManagement:sellingCards'] // 强制退卡
+        },
+        configUrl: {
+          list: '/merchant/equityCard/cardWipeRecordList',
+          delect: '', // 删除地址
+          upload: '',// 导入地址
+          download:'', // 下载模板地址
+          export: '',// 导出地址
+          updateStatus: '/merchant/memberEquityCard/updateStatus', // 禁用/启用
+          resetPassword: '/merchant/memberEquityCard/resetPwd', //重置密码
+          listCopy: '/merchant/equityCard', // 卡种
+          sellingCards: '/merchant/memberEquityCard/deleteById',
+          projectList: '/merchant/equityCard/projectList'
+        },
+        // 遮罩层
+        loading: true,
+        // 选中数组
+        ids: [],
+        // 非单个禁用
+        single: true,
+        // 非多个禁用
+        multiple: true,
+        // 显示搜索条件
+        showSearch: true,
+        // 总条数
+        total: 0,
+        // 用户表格数据
+        tableList: null,
+        // 查询参数
+        queryParams: {
+          pageNum: 1,
+          pageSize: 10,
+          cardNo: undefined,
+          name: undefined,
+          mobile: undefined,
+          projectId: undefined,
+          cardType: undefined,
+          deviceName: undefined
+        },
+        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: 5, label: `刷卡时间`, visible: true },
+          { key: 6, label: `刷卡设备`, visible: true },
+        ],
+        tableListCopy: [],
+        projectList: []
+      };
+    },
+    created() {
+      this.getListCopy()
+      this.getList();
+      this.getProjectList();
+    },
+    methods: {
+      checkPermi,
+      /** 查询权益卡类型列表 */
+      getListCopy() {
+        listTableApi(
+          this.configUrl.listCopy,
+          this.addDateRange(
+            {
+              pageNum: 1,
+              pageSize: 9999,
+            }, 
+            this.dateRange)).then(response => {
+              this.tableListCopy = response.rows;
+          }
+        ).catch (error=>{
+          console.error('获取列表失败!!!!',error)
+          this.tableListCopy = [];
+        }) 
+      },
+      /** 查询用户列表 */
+      getList() {
+        this.loading = true;
+        // 处理时间范围参数
+        const params = {
+          ...this.queryParams
+        }
+        if (this.dateRange && this.dateRange.length > 0) {
+          params.startTime = this.dateRange[0]
+          params.endTime = this.dateRange[1]
+        }
+        
+        listTableApi(
+          this.configUrl.list,
+          params
+        ).then(response => {
+          this.tableList = response.rows;
+          this.total = response.total;
+          this.loading = false;
+        }).catch (error => {
+          console.error('获取列表失败!!!!',error)
+          this.tableList = [];
+          this.total = 0;
+          this.loading = false
+        }) 
+      },
+      /** 查询项目列表 */
+      getProjectList() {
+        listTableApi(this.configUrl.projectList).then(response => {
+          this.projectList = response.data;
+        }).catch(error => {
+          console.error('获取项目列表失败!!!!', error);
+          this.projectList = [];
+        });
+      },
+      /** 搜索按钮操作 */
+      handleQuery() {
+        console.log('handleQuery');
+        
+        this.queryParams.pageNum = 1;
+        this.getList();
+      },
+      /** 重置按钮操作 */
+      resetQuery() {
+        this.dateRange = [];
+        this.queryParams = {
+          pageNum: 1,
+          pageSize: 10,
+          cardNo: undefined,
+          name: undefined, 
+          mobile: undefined,
+          projectId: undefined,
+          cardType: undefined,
+          deviceName: undefined,
+          startTime: undefined,
+          endTime: undefined
+        }
+        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 + '详情', "EDITInit",{...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() {
+        this.download(this.configUrl.export, {
+          ...this.queryParams
+        }, `刷卡记录_${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
+          })
+        }
+      },
+        // 更多操作触发
+        handleCommand(command, row) {
+          switch (command) {
+              case "handleAuthRole":
+              this.handleAuthRole(row);
+              break;
+              case "handleEdit":
+              this.handleUpdate(row);
+              break;
+              case "handleResetPassword":
+              this.handleResetPassword(row);
+              break;
+              case "handletUseList": this.handletUseList(row); break;
+              case "handletSellingCards": this.handletSellingCards(row); break;
+              default:
+              break;
+          }
+        },
+    }
+  };
+  </script>
+