index.vue 3.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116
  1. <!-- 精英管理 -->
  2. <template>
  3. <v-card class="pa-5 card-box">
  4. <div class="d-flex justify-space-between">
  5. <v-tabs v-model="tab" align-tabs="start" color="primary" bg-color="#f7f8fa">
  6. <v-tab v-for="k in tabList" :value="k.value" :key="k.value">{{ k.label }}</v-tab>
  7. </v-tabs>
  8. <TextInput v-model="textItems.value" :item="textItems" @appendInnerClick="handleSearch" @enter="handleSearch"></TextInput>
  9. </div>
  10. <Screen :tab="tab" @search="handleScreen" @reset="handleScreenReset"></Screen>
  11. <v-window v-model="tab" class="mt-1">
  12. <v-window-item v-for="k in tabList" :value="k.value" :key="k.value">
  13. <TablePage :items="items" :tab="k.value" @refresh="getList"></TablePage>
  14. <CtPagination
  15. v-if="total > 0"
  16. :total="total"
  17. :page="query.pageNo"
  18. :limit="query.pageSize"
  19. @handleChange="handleChangePage"
  20. ></CtPagination>
  21. </v-window-item>
  22. </v-window>
  23. </v-card>
  24. </template>
  25. <script setup>
  26. defineOptions({ name: 'enterprise-personnelManagement-management'})
  27. import { ref } from 'vue'
  28. import { getPersonCvPage } from '@/api/enterprise'
  29. import { dealDictObjData } from '@/utils/position'
  30. import { getInterviewInvitePage } from '@/api/recruit/enterprise/interview'
  31. import TablePage from './components/table.vue'
  32. import Screen from './components/screen.vue'
  33. const total = ref(0)
  34. const query = ref({
  35. pageNo: 1,
  36. pageSize: 10,
  37. status: null,
  38. type: 0
  39. })
  40. const tab = ref(0)
  41. const tabList = ref([
  42. { label: '投递简历', value: 0, api: getPersonCvPage, status: null },
  43. { label: '已邀约', value: 1, api: getInterviewInvitePage, status: '0' },
  44. { label: '已发offer', value: 2, api: getInterviewInvitePage, status: '1' },
  45. { label: '已入职', value: 3, api: getInterviewInvitePage, status: '2' },
  46. { label: '不合适', value: 4 },
  47. ])
  48. const textItems = ref({
  49. type: 'text',
  50. value: '',
  51. width: 250,
  52. label: '搜索姓名',
  53. clearable: true,
  54. appendInnerIcon: 'mdi-magnify'
  55. })
  56. // 获取牛人列表
  57. const items = ref([])
  58. const getList = async () => {
  59. if (tab.value === 4) return
  60. const api = tabList.value[tab.value].api
  61. query.value.status = tab.value === 0 ? null : tabList.value[tab.value].status
  62. const { list, total: number } = await api(query.value)
  63. if (!list.length) {
  64. items.value = []
  65. total.value = 0
  66. return
  67. }
  68. total.value = number
  69. items.value = list.map(e => {
  70. let obj = e
  71. obj.person = Object.assign(e.person, dealDictObjData({}, e.person))
  72. obj.job = Object.assign(e.job, dealDictObjData({}, e.job))
  73. return obj
  74. })
  75. }
  76. getList()
  77. // 分页
  78. const handleChangePage = (i) => {
  79. query.value.pageNo = i
  80. getList()
  81. }
  82. // 牛人姓名检索
  83. const handleSearch = () => {
  84. if (textItems.value.value) query.value.name = textItems.value.value
  85. else delete query.value.name
  86. query.value.pageNo = 1
  87. getList()
  88. }
  89. // 下拉筛选
  90. const handleScreen = ({ value, key }) => {
  91. if (value) query.value[key] = value
  92. else delete query.value[key]
  93. getList()
  94. }
  95. // 下拉筛选重置
  96. const handleScreenReset = () => {
  97. query.value = {
  98. pageSize: 10,
  99. pageNo: 1,
  100. status: tab.value
  101. }
  102. if (textItems.value.value) query.value.name = textItems.value.value
  103. getList()
  104. }
  105. </script>
  106. <style scoped lang="scss">
  107. </style>