choosePerson.vue 9.81 KB
<template>
  <el-dialog
    v-model="show" class="dialog" width="1150px" align-center
    title="选择考生" append-to-body :close-on-click-modal="true"
  >
    <h4 style="margin:0;text-align: center;padding: 10px 0;"> <el-icon style="vertical-align:top;color:#c00;"><WarningFilled /></el-icon>温馨提示:
      <span v-if="queryParams.examType==1" style="color:#c00">正在办理级位考试、会员状态异常及目前级位为一级的数据不显示</span>
      <span v-else style="color:#c00">正在办理段位考试、会员状态异常及目前段位为九段的数据不显示</span>
    </h4>
    <el-form ref="dialogQueryRef" :inline="true" :model="queryParams" label-position="top">
      <el-form-item label="姓名">
        <el-input v-model="queryParams.name" style="width: 150px;" placeholder="考生姓名" clearable @keyup.enter="handleQuery" />
      </el-form-item>
      <el-form-item label="证件类型">
        <el-select v-model="queryParams.idcType" style="width: 150px" clearable @change="handleQuery">
          <el-option label="身份证" value="0" />
          <el-option label="港澳台通行证" value="1" />
          <el-option label="外国护照" value="3" />
          <el-option label="其它" value="4" />
        </el-select>
      </el-form-item>
      <el-form-item label="证件号码">
        <el-input v-model="queryParams.idcCode" placeholder="证件号码" style="width: 150px" clearable @keyup.enter="handleQuery" />
      </el-form-item>
      <el-form-item label="所属协会">
        <el-input v-model="queryParams.memName" style="width: 150px;" placeholder="所属协会" clearable @keyup.enter="handleQuery" />
      </el-form-item>
      <el-form-item v-if="queryParams.examType == '1'" label="级位" prop="levelStart">
        <el-select v-model="queryParams.levelStart" style="width: 150px" clearable @change="handleQuery">
          <el-option label="十级" value="10" />
          <el-option label="九级" value="9" />
          <el-option label="八级" value="8" />
          <el-option label="七级" value="7" />
          <el-option label="六级" value="6" />
          <el-option label="五级" value="5" />
          <el-option label="四级" value="4" />
          <el-option label="三级" value="3" />
          <el-option label="二级" value="2" />
          <el-option label="一级" value="1" />
        </el-select>
        <label style="margin-left: 5px"></label>
        <el-select v-model="queryParams.levelEnd" style="margin-left: 5px; width: 150px" clearable @change="handleQuery">
          <el-option label="十级" value="10" />
          <el-option label="九级" value="9" />
          <el-option label="八级" value="8" />
          <el-option label="七级" value="7" />
          <el-option label="六级" value="6" />
          <el-option label="五级" value="5" />
          <el-option label="四级" value="4" />
          <el-option label="三级" value="3" />
          <el-option label="二级" value="2" />
          <el-option label="一级" value="1" />
        </el-select>
      </el-form-item>
      <el-form-item v-if="queryParams.examType != '1'" label="段位" prop="levelStart">
        <el-select v-model="queryParams.levelStart" style="width: 150px" clearable @change="handleQuery">
          <el-option label="无段/品" value="0" />
          <el-option label="一段/品" value="1" />
          <el-option label="二段/品" value="2" />
          <el-option label="三段/品" value="3" />
          <el-option label="四段/品" value="4" />
          <el-option label="五段/品" value="5" />
          <el-option label="六段/品" value="6" />
          <el-option label="七段/品" value="7" />
          <el-option label="八段/品" value="8" />
          <el-option label="九段/品" value="9" />
        </el-select>
        <label style="margin-left: 5px"></label>
        <el-select v-model="queryParams.levelEnd" style="margin-left: 5px; width: 150px" clearable @change="handleQuery">
          <el-option label="无段/品" value="0" />
          <el-option label="一段/品" value="1" />
          <el-option label="二段/品" value="2" />
          <el-option label="三段/品" value="3" />
          <el-option label="四段/品" value="4" />
          <el-option label="五段/品" value="5" />
          <el-option label="六段/品" value="6" />
          <el-option label="七段/品" value="7" />
          <el-option label="八段/品" value="8" />
          <el-option label="九段/品" value="9" />
        </el-select>
      </el-form-item>
    </el-form>
    <el-row justify="space-between">
      <div />
      <div>
        <el-button type="primary" icon="Search" @click="handleQuery">查 询</el-button>
        <el-button type="" icon="Refresh" @click="resetQuery">重 置</el-button>
        <el-button :disabled="ids.length<=0" :loading="buttonLoading" type="primary" @click="submitForm">批量添加</el-button>
      </div>
    </el-row>
    <br>
    <el-table v-loading="loading" :row-class-name="tableRowClassName" border :data="infoList" @selection-change="handleSelectionChange">
      <!--      :selectable="selectable"-->
      <el-table-column type="selection" width="55" align="center" />
      <el-table-column type="index" width="55" align="center" label="序号" />
      <el-table-column label="姓名" align="center" prop="name" min-width="100" />
      <el-table-column label="头像" align="center">
        <template #default="props">
          <!-- <el-image style="width: 70px; height: 70px" :src="fillImgUrl(props.row.photo)" /> -->
          <div style="display: flex; justify-content: center;">
            <el-image v-if="props.row.photo" style="width: 46px; height: 65px;" :src="fillImgUrl(props.row.photo)">
              <template #error>
                <div class="image-slot">
                  <img style="width: 46px;" src="@/assets/admin/tx.jpg">
                </div>
              </template>
              <template #placeholder>
                <div class="image-slot"> <img style="width: 46px;" src="@/assets/admin/tx.jpg"></div>
              </template>
            </el-image>
            <img v-else style="width: 46px; height: 65px;" src="@/assets/admin/tx.jpg" alt="">
          </div>
        </template>
      </el-table-column>
      <el-table-column label="会员号" align="center" prop="perCode" min-width="120" />
      <el-table-column label="证件号码" align="center" prop="idcCode" min-width="170" :show-overflow-tooltip="true" />
      <el-table-column label="有效期" align="center" prop="validityDate" min-width="100">
        <template #default="scope">
          <span>{{ parseTime(scope.row.validityDate, '{y}-{m}-{d}') }}</span>
        </template>
      </el-table-column>
      <el-table-column label="所属单位(团体会员)" align="center" prop="memName" min-width="160" :show-overflow-tooltip="true" />
      <el-table-column label="级位" align="center" prop="levelJi" min-width="100">
        <template #default="scope">
          <ji :level="scope.row.levelJi" />
        </template>
      </el-table-column>
      <el-table-column label="段位" align="center" prop="levelDuan" min-width="100">
        <template #default="scope">
          <span v-if="scope.row.levelDuan && '0' != scope.row.levelDuan">
            {{ szToHz(scope.row.levelDuan) }}/
          </span>
          <span v-else>--</span>
        </template>
      </el-table-column>
    </el-table>

    <pagination
      v-show="total > 0"
      v-model:page="queryParams.pageNum"
      v-model:limit="queryParams.pageSize"
      :total="total"
      @pagination="getList"
    />
  </el-dialog>
</template>

<script setup>

import { getCurrentInstance, ref, toRefs } from 'vue'
import { reactive } from '@vue/runtime-core'
import { batchChoose, chooseStudentsList } from '@/api/exam/person'
import { szToHz } from '@/utils/ruoyi'
import Ji from '@/views/exam/level/apply/components/ji'

const { proxy } = getCurrentInstance()
const emit = defineEmits(['submit'])

const show = ref(false)
const infoList = ref([])
const loading = ref(true)
const total = ref(0)
const buttonLoading = ref(false)
const ids = ref([])

const data = reactive({
  queryParams: {
    pageNum: 1,
    pageSize: 10,
    memId: null,
    examId: null,
    examType: null,
    name: null,
    idcType: null,
    idcCode: null,
    levelStart: null,
    levelEnd: null,
    memName: null
  }
})
const { queryParams } = toRefs(data)


function getList() {
  loading.value = true
  chooseStudentsList(queryParams.value).then(response => {
    infoList.value = response.rows
    total.value = response.total
    loading.value = false
  })
}

function handleSelectionChange(selection) {
  ids.value = selection.map((item) => item.perId)
  console.log(ids.value)
}

function handleQuery() {
  queryParams.value.pageNum = 1
  getList()
}

function resetQuery() {
  queryParams.value.name = null
  queryParams.value.idcType = null
  queryParams.value.idcCode = null
  queryParams.value.levelStart = null
  queryParams.value.levelEnd = null
  queryParams.value.memName = null
  handleQuery()
}

function submitForm() {
  if (ids.value.length === 0) {
    proxy.$modal.msgWarning('请选择考生')
    return
  }

  batchChoose({
    examId: queryParams.value.examId,
    perIds: ids.value
  }).then(() => {
    proxy.$modal.msgSuccess('添加成功')
    emit('submit')
    show.value = false
  })
}

// 背景颜色
function tableRowClassName({ row }) {
  if (!row.canChoose == '0') {
    return 'disabled-row'
  }
}

function open(params) {
  queryParams.value.memId = params.memId
  queryParams.value.examId = params.examId
  queryParams.value.examType = params.examType
  queryParams.value.pageSize = 10
  queryParams.value.pageNum = 1
  resetQuery()
  show.value = true
}

function selectable(row) {
  if (row.canChoose == '0') {
    return false
  } else {
    return true
  }
}
defineExpose({
  open
})

</script>

<style scoped>
</style>