瀏覽代碼

Merge branch 'groupJobFair' of https://git.citupro.com/zhengnaiwen_citu/menduner into groupJobFair

lifanagju_citu 7 月之前
父節點
當前提交
b032dd5d9a

+ 1 - 0
components.d.ts

@@ -31,6 +31,7 @@ declare module 'vue' {
     CtTextField: typeof import('./src/components/CtVuetify/CtTextField/index.vue')['default']
     DatePicker: typeof import('./src/components/DatePicker/index.vue')['default']
     Echarts: typeof import('./src/components/Echarts/index.vue')['default']
+    ElCascader: typeof import('element-plus/es')['ElCascader']
     ElConfigProvider: typeof import('element-plus/es')['ElConfigProvider']
     Empty: typeof import('./src/components/Empty/index.vue')['default']
     File: typeof import('./src/components/Upload/file.vue')['default']

+ 24 - 0
src/api/recruit/personal/student.js

@@ -61,4 +61,28 @@ export const getStudentPracticeCompanyList = async () => {
 	return await request.get({
 		url: '/app-api/menduner/system/student/record-enterprise/list'
 	})
+}
+
+// 学校列表
+export const getSchoolList = async (params) => {
+	return await request.get({
+		url: '/app-api/menduner/system/school/info/list',
+		params
+	})
+}
+
+// 根据学校id获取院系列表
+export const getDepartmentListBySchoolId = async (params) => {
+	return await request.get({
+		url: '/app-api/menduner/system/school/organization/list',
+		params
+	})
+}
+
+// 获取专业列表
+export const getMajorList = async (params) => {
+  return await request.get({
+    url: '/app-api/menduner/system/major/list',
+    params
+  })
 }

+ 8 - 0
src/api/school.js

@@ -111,6 +111,14 @@ export const getOrganizationList = async (params) => {
 	})
 }
 
+// 获取机构树状结构
+export const getOrganizationTree = async (params) => {
+	return await request.get({
+		url: '/app-api/menduner/system/teacher/school/organization/get/tree',
+		params
+	})
+}
+
 // 创建机构
 export const createOrganization = async (data) => {
 	return await request.post({

+ 9 - 1
src/views/recruit/personal/PersonalCenter/index.vue

@@ -55,7 +55,9 @@ import { getCurrentLocaleLang } from '@/utils/lang.js'
 import personCenterRoute from '@/router/modules/components/recruit/personCenter'
 import { useUserStore } from '@/store/user'
 import { usePersonCenterStore } from '@/store/personCenter'
+import { useRoute } from 'vue-router'
 
+const route = useRoute()
 const userStore = useUserStore()
 
 const info = localStorage.getItem('baseInfo') ? JSON.parse(localStorage.getItem('baseInfo')) : {}
@@ -114,10 +116,16 @@ const handleClosePreview = () => {
 }
 
 // 更新账户信息
+const refreshPath = [
+  '/recruit/personal/personalCenter/wallet',
+  '/recruit/personal/personalCenter/tradeOrder',
+  '/recruit/personal/personalCenter/inviteRecord',
+  '/recruit/personal/personalCenter/memberBenefits/taskCenter'
+]
 const updateAccountInfo = async () => {
   await userStore.getUserAccountInfo()
 }
-updateAccountInfo()
+if (refreshPath.includes(route.path)) updateAccountInfo()
 </script>
 
 <style scoped lang="scss">

+ 79 - 52
src/views/recruit/personal/PersonalCenter/student/information/index.vue

@@ -14,64 +14,86 @@
 
 <script setup>
 defineOptions({name: 'personal-personCenter-studentInformation-index'})
-import { ref } from 'vue'
+import { ref, onMounted } from 'vue'
 import { saveStudentSimpleInfo } from '@/api/recruit/personal/shareJob'
-import { schoolList, departmentList } from '@/api/recruit/personal/resume'
 import { useI18n } from '@/hooks/web/useI18n'
 import Snackbar from '@/plugins/snackbar'
 import { isValidIdCard18 } from '@/utils/validate'
 import { useUserStore } from '@/store/user'
+import { getSchoolList, getDepartmentListBySchoolId, getMajorList } from '@/api/recruit/personal/student'
 
 const { t } = useI18n()
 const userStore = useUserStore()
 const overlay = ref(false)
 
 const CtFormRef = ref()
+
+// 专业名称下拉列表
+let majorName = null
+const getMajorData = async (name) => {
+  const item = items.value.options.find(e => e.key === 'majorId')
+  if (!item) return
+  if (item.items?.length && (majorName === name)) return // 防抖
+  majorName = name
+  if (name === null || name === '') { item.items = [] }
+  else {
+    const data = await getMajorList({ name })
+    item.items = data
+  }
+}
+
 const items = ref({
   options: [
     {
       type: 'autocomplete',
       key: 'schoolId',
-      value: {},
+      value: null,
       default: null,
       label: '就读学校 *',
       outlined: true,
-      returnObject: true,
-      itemText: 'schoolName',
+      itemText: 'name',
       itemValue: 'schoolId',
       rules: [v => !!v || '请选择就读学校'],
       items: [],
-      change: e => getDepartmentList(e),
+      change: e => getDepartmentList(e, 'schoolDeptId', 0, true),
     },
     {
       type: 'autocomplete',
-      key: 'schoolDepartmentName',
+      key: 'schoolDeptId',
       value: null,
       default: null,
       label: '所在院系 *',
       outlined: true,
-      itemText: 'departmentTitle',
-      itemValue: 'departmentTitle',
+      itemText: 'name',
+      itemValue: 'id',
       rules: [v => !!v || '请选择所在院系'],
+      change: e => getDepartmentList(e, 'schoolClassId', 2, true),
       items: []
     },
     {
-      type: 'text',
-      key: 'majorName',
-      value: '',
-      default: null,
-      label: '所学专业 *',
+      type: 'combobox',
+      key: 'schoolClassId',
+      value: null,
+      label: '所在班级 *',
       outlined: true,
-      rules: [v => !!v || '请输入所学专业']
+      clearable: true,
+      canBeInputted: true,
+      itemTextName: 'schoolClassName',
+      itemText: 'name',
+      itemValue: 'id',
+      rules: [v => !!v || '请选择所在班级'],
+      items: []
     },
     {
-      type: 'text',
-      key: 'schoolClassName',
-      value: '',
-      default: null,
-      label: '所在班级 *',
+      type: 'autocomplete',
+      key: 'majorId',
+      value: null,
+      label: '所学专业 *',
       outlined: true,
-      rules: [v => !!v || '请填写所在班级']
+      itemText: 'nameCn',
+      itemValue: 'id',
+      rules: [v => !!v || '请选择所学专业'],
+      items: []
     },
     {
       type: 'text',
@@ -115,10 +137,9 @@ const items = ref({
       type: 'phoneNumber',
       key: 'emergencyContactPhone',
       value: '',
-      clearable: true,
       label: '紧急联系人手机号 *',
       rules: [v => !!v || '请填写紧急联系人手机号']
-    },
+    }
   ]
 })
 
@@ -129,47 +150,51 @@ items.value.options.forEach((e, index) => {
 })
 
 // 学校下拉列表
-const getSchoolListData = async (schoolId) => {
+const getSchoolListData = async () => {
   const item = items.value.options.find(e => e.key === 'schoolId')
   if (!item) return
-  const { records } = await schoolList({ current: 1,size: 9999 })
-  item.items = records || []
-
-  if (schoolId) {
-    item.value = records.find(e => e.schoolId === schoolId)
-  }
+  const data = await getSchoolList()
+  item.items = data || []
 }
-getSchoolListData()
 
-const getDepartmentList = async (e) => {
-  const item = items.value.options.find(e => e.key === 'schoolDepartmentName')
+
+// 根据学校id获取院系、班级列表
+const getDepartmentList = async (id, key, type, isRefreshValue = false) => {
+  const item = items.value.options.find(e => e.key === key)
   if (!item) return
-  const query = {
-    page: { size: 9999,	current: 1	},
-    entity: { schoolId: typeof e === 'object' ? e.schoolId : e }
-  }
-  const res = await departmentList(query)
-  const list = res?.records?.length ? res.records : []
-  item.items = list.map(e => e.entity)
-  if (typeof e === 'object') item.value = null
+
+  let params = { type } // type: 0院系|1专业|2班级
+  // 查院系用schoolId,查班级用parentId
+  if (key === 'schoolDeptId') params.schoolId = id
+  else params.parentId = id
+
+  const data = await getDepartmentListBySchoolId(params)
+  item.items = data || []
+
+  // 下拉框选择时需清空下级value
+  if (isRefreshValue) item.value = null
 }
 
 // 获取学生基本信息
 const studentInfoFun = async () => {
   await userStore.getStudentInformation()
   const data = JSON.parse(localStorage.getItem('studentInfo') || '{}')
-  if (data.schoolId) getDepartmentList(data.schoolId)
+  if (data.schoolId) getDepartmentList(data.schoolId, 'schoolDeptId', 0)
+  if (data?.schoolClassId) getDepartmentList(data.schoolDeptId, 'schoolClassId', 2)
+  if (data?.majorId) getMajorData(data?.major?.nameCn)
   // 回显
   items.value.options.forEach(e => {
     if (data[e.key]) {
-      if (e.key === 'schoolId') {
-        getSchoolListData(data[e.key])
-      }
-      else e.value = data[e.key]
+      e.value = data[e.key]
     }
   })
 }
-studentInfoFun()
+onMounted(() => {
+  // 获取学校列表
+  getSchoolListData()
+  // 获取学生基本信息
+  studentInfoFun()
+})
 
 
 // 提交
@@ -179,14 +204,16 @@ const handleSubmit = async () => {
   overlay.value = true
   const params = {}
   items.value.options.forEach(item => {
-    params[item.key] = item.returnObject ? '' : item.value
-    if (item.key === 'schoolId') {
-      params.schoolName = item.value.schoolName
-      params.schoolId = item.value.schoolId
+    // 班级有下拉选择的,需要根据选择的值赋值
+    if (item.key === 'schoolClassId') {
+      const classObj = item.items.find(e => item.itemValue === e.value)
+      if (!classObj) {
+        params[item.key] = null
+        params[item.itemTextName] = item.value
+      } else params[item.key] = item.value
     } else params[item.key] = item.value
   })
 
-
   await saveStudentSimpleInfo(params)
   setTimeout(async () => {
     await userStore.getStudentInformation()

+ 26 - 37
src/views/recruit/teacher/internshipReport/index.vue

@@ -1,26 +1,30 @@
 <template>
   <v-card class="card-box d-flex pa-3">
     <div style="width: 20%; border-right: 1px solid #ccc;">
-      <v-treeview
-        :items="treeData"
-        activatable
-        color="primary"
-        item-value="id"
-        open-all
-        open-strategy="single"
-        density="compact"
-        @update:activated="handleClick"
-        @update:opened="handleClick"
-      >
-        <template v-slot:title="{ item }">
-          <div class="treeTitle font-size-15" v-ellipse-tooltip style="max-width: 100%;">{{ formatName(item.title) }}</div>
-        </template>
-      </v-treeview>
+      <div v-if="treeData.length > 0">
+        <v-treeview
+          :items="treeData"
+          activatable
+          class="mr-3"
+          color="primary"
+          item-value="id"
+          open-all
+          open-strategy="single"
+          density="compact"
+          @update:activated="handleClick"
+          @update:opened="handleClick"
+        >
+          <template v-slot:title="{ item }">
+            <div class="treeTitle font-size-15" v-ellipse-tooltip style="max-width: 100%;">{{ formatName(item.name) }}</div>
+          </template>
+        </v-treeview>
+      </div>
+      <div v-else class="font-size-15 color-999 text-center" style="line-height: 60vh;">暂无院系</div>
     </div>
     <div style="width: 80%" class="ml-3">
-      <div class="d-flex justify-space-between px-3">
+      <div class="d-flex justify-space-between">
         <TextInput v-model="query.name" :item="textItem" @change="getUserList"></TextInput>
-        <v-btn class="mr-3" width="100" color="primary" prepend-icon="mdi-refresh" variant="outlined" @click="getTreeData">刷 新</v-btn>
+        <v-btn width="100" color="primary" prepend-icon="mdi-refresh" variant="outlined" @click="getTreeData">刷 新</v-btn>
       </div>
       <CtTable
         :items="tableData"
@@ -74,7 +78,7 @@
 defineOptions({ name: 'group-account'})
 import { ref } from 'vue'
 import { useI18n } from '@/hooks/web/useI18n'
-import { getEnterpriseTree } from '@/api/recruit/enterprise/system/group'
+import { getOrganizationTree } from '@/api/school'
 import { getUserAvatar } from '@/utils/avatar'
 import { formatName } from '@/utils/getText';
 
@@ -122,16 +126,7 @@ const tableData = ref([
   "createTime": 1741681159370
 }
 ])
-const treeData = ref([
-  {
-    title: '农学',
-    children: [{ title: '农学1' }, { title: '农学2' }]
-  },
-  {
-    title: '文学',
-    children: [{ title: '文学1' }, { title: '文学2' }]
-  }
-])
+const treeData = ref([])
 const headers = [
   { title: '学生姓名', key: 'studentName', sortable: false },
   { title: '实习企业', key: 'enterpriseName', sortable: false },
@@ -166,15 +161,11 @@ const getUserList = async () => {
 const getTreeData = async () => {
   treeData.value = []
   try {
-    const data = await getEnterpriseTree()
-    if (!data) return
-    treeData.value[0] = data
-    query.value.enterpriseId = data.id
-    // 获取用户列表
-    getUserList()
+    const data = await getOrganizationTree({ schoolId: schoolInfo.value.schoolId })
+    treeData.value = data || []
   } catch {}
 }
-// getTreeData()
+getTreeData()
 
 // 分页
 const handleChangePage = (e) => {
@@ -185,8 +176,6 @@ const handleChangePage = (e) => {
 // 树形click
 const handleClick = (e) => {
   if (!e.length) return
-  query.value.enterpriseId = e[0]
-  getUserList()
 }
 
 // 查看实习报告