index.vue 7.35 KB
<template>
  <div class="NCC-common-layout">
    <div class="NCC-common-layout-center">
      <el-row class="NCC-common-search-box" :gutter="16">
        <el-form @submit.native.prevent>
          <el-col :span="6">
            <el-form-item label="会员编号">
              <el-input v-model="query.memberNo" placeholder="会员编号" clearable />
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item label="会员手机号">
              <el-input v-model="query.memberPhone" placeholder="会员手机号" clearable />
            </el-form-item>
          </el-col>
          <el-col :span="6">
            <el-form-item>
              <el-button type="primary" icon="el-icon-search" @click="search()">查询</el-button>
              <el-button icon="el-icon-refresh-right" @click="reset()">重置</el-button>
            </el-form-item>
          </el-col>
        </el-form>
      </el-row>
      <div class="NCC-common-layout-main NCC-flex-main">
        <div class="NCC-common-head">
          <div class="NCC-common-head-right">
            <el-tooltip effect="dark" content="刷新" placement="top">
              <el-link icon="icon-ym icon-ym-Refresh NCC-common-head-icon" :underline="false" @click="reset()" />
            </el-tooltip>
            <screenfull isContainer />
          </div>
        </div>
        <NCC-table v-loading="listLoading" :data="list" :header-cell-style="{ background: '#f5f7fa', color: '#606266' }">
          <el-table-column prop="id" label="ID" width="100" align="left">
            <template slot-scope="scope">
              <i class="el-icon-document item-icon"></i>
              <span>{{ scope.row.id || '无' }}</span>
            </template>
          </el-table-column>
          <el-table-column prop="orderNo" label="开单号" width="180" align="left">
            <template slot-scope="scope">
              <i class="el-icon-tickets item-icon"></i>
              <span>{{ scope.row.orderNo || '无' }}</span>
            </template>
          </el-table-column>
          <el-table-column prop="memberNo" label="会员编号" width="180" align="left">
            <template slot-scope="scope">
              <i class="el-icon-user item-icon"></i>
              <span>{{ scope.row.memberNo || '无' }}</span>
            </template>
          </el-table-column>
          <el-table-column prop="memberPhone" label="会员手机号" width="150" align="left">
            <template slot-scope="scope">
              <i class="el-icon-phone item-icon"></i>
              <span>{{ scope.row.memberPhone || '无' }}</span>
            </template>
          </el-table-column>
          <el-table-column prop="memberName" label="会员名称" width="150" align="left">
            <template slot-scope="scope">
              <i class="el-icon-user-solid item-icon"></i>
              <span>{{ scope.row.memberName || '无' }}</span>
            </template>
          </el-table-column>
          <el-table-column prop="remarks" label="备注" min-width="200" align="left" show-overflow-tooltip>
            <template slot-scope="scope">
              <span>{{ scope.row.remarks || '无' }}</span>
            </template>
          </el-table-column>
          <el-table-column prop="createdAt" label="创建时间" width="180" align="left" :formatter="formatDate">
            <template slot-scope="scope">
              <i class="el-icon-time item-icon"></i>
              <span>{{ formatDateTime(scope.row.createdAt) || '无' }}</span>
            </template>
          </el-table-column>
          <el-table-column prop="updatedAt" label="更新时间" width="180" align="left" :formatter="formatDate">
            <template slot-scope="scope">
              <i class="el-icon-time item-icon"></i>
              <span>{{ formatDateTime(scope.row.updatedAt) || '无' }}</span>
            </template>
          </el-table-column>
          <el-table-column label="操作" fixed="right" width="100" align="left">
            <template slot-scope="scope">
              <el-button type="text" @click="showDetail(scope.row.id)">查看</el-button>
            </template>
          </el-table-column>
        </NCC-table>
        <pagination :total="total" :page.sync="listQuery.currentPage" :limit.sync="listQuery.pageSize" @pagination="initData" />
      </div>
    </div>
    <DetailDialog v-if="detailVisible" ref="DetailDialog" />
  </div>
</template>

<script>
import request from '@/utils/request'
import DetailDialog from './detail'

export default {
  components: { DetailDialog },
  data() {
    return {
      query: {
        memberNo: undefined,
        memberPhone: undefined
      },
      list: [],
      listLoading: false,
      total: 0,
      listQuery: {
        currentPage: 1,
        pageSize: 20,
        sort: 'desc',
        sidx: 'id'
      },
      detailVisible: false
    }
  },
  created() {
    this.initData()
  },
  methods: {
    // 获取列表数据
    initData() {
      this.listLoading = true
      const _query = {
        ...this.listQuery,
        ...this.query
      }
      const query = {}
      for (let key in _query) {
        // 过滤掉 undefined、null 和空字符串
        if (_query[key] === undefined || _query[key] === null || _query[key] === '') {
          continue
        }
        query[key] = _query[key]
      }
      request({
        url: '/api/Extend/LqOrderRecords',
        method: 'GET',
        data: query
      }).then(res => {
        if (res.code === 200) {
          this.list = res.data.list || []
          this.total = (res.data.pagination && res.data.pagination.total) || 0
        } else {
          this.$message.error(res.msg || '获取列表失败')
          this.list = []
          this.total = 0
        }
        this.listLoading = false
      }).catch(error => {
        console.error('获取历史开单记录列表失败:', error)
        this.$message.error('获取列表失败')
        this.list = []
        this.total = 0
        this.listLoading = false
      })
    },
    // 查询
    search() {
      this.listQuery = {
        currentPage: 1,
        pageSize: 20,
        sort: 'desc',
        sidx: 'id'
      }
      this.initData()
    },
    // 重置
    reset() {
      for (let key in this.query) {
        this.query[key] = undefined
      }
      this.listQuery = {
        currentPage: 1,
        pageSize: 20,
        sort: 'desc',
        sidx: 'id'
      }
      this.initData()
    },
    // 显示详情
    showDetail(id) {
      this.detailVisible = true
      this.$nextTick(() => {
        this.$refs.DetailDialog.init(id)
      })
    },
    // 格式化日期时间
    formatDateTime(dateTime) {
      if (!dateTime) return '无'
      const date = new Date(dateTime)
      if (isNaN(date.getTime())) return '无'
      const year = date.getFullYear()
      const month = String(date.getMonth() + 1).padStart(2, '0')
      const day = String(date.getDate()).padStart(2, '0')
      const hours = String(date.getHours()).padStart(2, '0')
      const minutes = String(date.getMinutes()).padStart(2, '0')
      const seconds = String(date.getSeconds()).padStart(2, '0')
      return `${year}-${month}-${day} ${hours}:${minutes}:${seconds}`
    },
    // 格式化日期(表格formatter)
    formatDate(row, column, cellValue) {
      return this.formatDateTime(cellValue)
    }
  }
}
</script>

<style lang="scss" scoped>
.item-icon {
  margin-right: 5px;
  color: #409EFF;
}
</style>