index.vue 3.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139
  1. <!-- 精英管理 -->
  2. <template>
  3. <v-card class="pa-3 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" @select="handleSelect" @change="handleChangeBounty"></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" :total="total" :pageInfo="query" :tab="k.value" :statusList="statusList" @refresh="getList" @page="handleChangePage"></TablePage>
  14. </v-window-item>
  15. </v-window>
  16. </v-card>
  17. </template>
  18. <script setup>
  19. defineOptions({ name: 'enterprise-elite-management'})
  20. import { ref } from 'vue'
  21. import { getPersonCvPage } from '@/api/enterprise'
  22. import { personCvUnfitPage } from '@/api/recruit/enterprise/personnel'
  23. import { dealDictObjData } from '@/utils/position'
  24. import { getDict } from '@/hooks/web/useDictionaries'
  25. import { getInterviewInvitePage } from '@/api/recruit/enterprise/interview'
  26. import TablePage from './components/table.vue'
  27. import Screen from './components/screen.vue'
  28. const total = ref(0)
  29. const query = ref({
  30. pageNo: 1,
  31. pageSize: 10,
  32. status: null,
  33. type: null
  34. })
  35. const tab = ref(0)
  36. const tabList = ref([
  37. { label: '投递简历', value: 0, api: getPersonCvPage, status: null },
  38. { label: '已邀约', value: 1, api: getInterviewInvitePage, status: '0' },
  39. { label: '已入职', value: 2, api: getInterviewInvitePage, status: '1' },
  40. { label: '已结算', value: 3, api: getInterviewInvitePage, status: '2' },
  41. { label: '不合适', value: 4, api: personCvUnfitPage },
  42. ])
  43. const textItems = ref({
  44. type: 'text',
  45. value: '',
  46. width: 250,
  47. label: '搜索姓名',
  48. clearable: true,
  49. appendInnerIcon: 'mdi-magnify'
  50. })
  51. // 状态字典
  52. const statusList = ref([])
  53. getDict('menduner_interview_invite_status').then(({data}) => {
  54. if (data && data.length) statusList.value = data
  55. })
  56. // 获取牛人列表
  57. const items = ref([])
  58. const getList = async () => {
  59. const api = tabList.value[tab.value].api
  60. if (tab.value !== 0) {
  61. query.value.conversationStatus = tabList.value[tab.value].status
  62. delete query.value.status
  63. delete query.value.type
  64. }
  65. const { list, total: number } = await api(query.value)
  66. if (!list.length) {
  67. items.value = []
  68. total.value = 0
  69. return
  70. }
  71. total.value = number
  72. items.value = list.map(e => {
  73. let obj = e
  74. obj.jobClosed = e?.job?.status === '1' || false // 职位已关闭
  75. obj.person = Object.assign(e.person, dealDictObjData({}, e.person))
  76. obj.job = Object.assign(e.job, dealDictObjData({}, e.job))
  77. return obj
  78. })
  79. }
  80. getList()
  81. // 分页
  82. const handleChangePage = (i) => {
  83. query.value.pageNo = i
  84. getList()
  85. }
  86. // 牛人姓名检索
  87. const handleSearch = () => {
  88. if (textItems.value.value) query.value.name = textItems.value.value
  89. else delete query.value.name
  90. query.value.pageNo = 1
  91. getList()
  92. }
  93. // 下拉筛选
  94. const handleScreen = ({ value, key }) => {
  95. if (value) query.value[key] = value
  96. else delete query.value[key]
  97. getList()
  98. }
  99. // 下拉筛选重置
  100. const handleScreenReset = () => {
  101. query.value = {
  102. pageSize: 10,
  103. pageNo: 1,
  104. status: tab.value
  105. }
  106. if (tab.value === 0) {
  107. query.value.status = null
  108. query.value.type = null
  109. }
  110. if (textItems.value.value) query.value.name = textItems.value.value
  111. getList()
  112. }
  113. const handleSelect = (e) => {
  114. query.value.pageNo = 1
  115. query.value.status = e
  116. getList()
  117. }
  118. // 赏金职位
  119. const handleChangeBounty = (e) => {
  120. query.value.type = e ? 1 : 0
  121. query.value.pageNo = 1
  122. getList()
  123. }
  124. </script>
  125. <style scoped lang="scss">
  126. </style>