index.vue 2.5 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697
  1. <template>
  2. <v-card class="pa-5 card-box">
  3. <div class="d-flex justify-space-between">
  4. <v-tabs v-model="query.status" align-tabs="start" color="primary" bg-color="#f7f8fa" @update:model-value="handleUpdateTab">
  5. <v-tab v-for="k in tabList" :value="k.value" :key="k.value">{{ k.label }}</v-tab>
  6. </v-tabs>
  7. <TextInput v-model="textItems.value" :item="textItems" @appendInnerClick="handleSearch" @enter="handleSearch"></TextInput>
  8. </div>
  9. <v-window v-model="query.status" class="mt-1">
  10. <v-window-item v-for="k in tabList" :value="k.value" :key="k.value">
  11. <TablePage :items="items" :tab="k.value" @refresh="getList"></TablePage>
  12. <CtPagination
  13. v-if="total > 0"
  14. :total="total"
  15. :page="query.pageNo"
  16. :limit="query.pageSize"
  17. @handleChange="handleChangePage"
  18. ></CtPagination>
  19. </v-window-item>
  20. </v-window>
  21. </v-card>
  22. </template>
  23. <script setup>
  24. defineOptions({ name: 'public-recruitment-deliver'})
  25. import { ref } from 'vue'
  26. import { getDict } from '@/hooks/web/useDictionaries'
  27. import { getHireJobCvPage } from '@/api/recruit/public/delivery'
  28. import { dealDictObjData } from '@/views/recruit/personal/position/components/dict'
  29. import TablePage from './components/table.vue'
  30. const total = ref(0)
  31. const query = ref({
  32. pageNo: 1,
  33. pageSize: 10,
  34. status: '0'
  35. })
  36. const items = ref([])
  37. const tabList = ref([])
  38. const textItems = ref({
  39. type: 'text',
  40. value: '',
  41. width: 250,
  42. label: '搜索姓名',
  43. clearable: true,
  44. appendInnerIcon: 'mdi-magnify'
  45. })
  46. // 获取tab列表项
  47. const getTabData = () => {
  48. getDict('menduner_hire_job_cv_status').then(({ data }) => {
  49. data = data?.length && data || []
  50. tabList.value = data
  51. })
  52. }
  53. getTabData()
  54. const getList = async () => {
  55. const res = await getHireJobCvPage(query.value)
  56. if (!res.list.length) {
  57. items.value = []
  58. total.value = 0
  59. return
  60. }
  61. items.value = res.list.map(e => {
  62. let obj = e
  63. obj.person = Object.assign(e.person, dealDictObjData({}, e.person))
  64. obj.job = Object.assign(e.job, dealDictObjData({}, e.job))
  65. return obj
  66. })
  67. total.value = res.total
  68. }
  69. getList()
  70. const handleSearch = () => {
  71. if (textItems.value.value) query.value.name = textItems.value.value
  72. else delete query.value.name
  73. query.value.pageNo = 1
  74. getList()
  75. }
  76. const handleUpdateTab = () => {
  77. query.value.pageNo = 1
  78. getList()
  79. }
  80. // 分页
  81. const handleChangePage = (i) => {
  82. query.value.pageNo = i
  83. getList()
  84. }
  85. </script>
  86. <style scoped lang="scss">
  87. </style>