机构管理相关

This commit is contained in:
Flow 2025-04-28 10:26:35 +08:00
parent 227cbee8ec
commit a92eca9198
6 changed files with 31 additions and 27 deletions

View File

@ -2,7 +2,7 @@ import request from '@/config/axios'
// 机构 VO // 机构 VO
export interface InspectOrgVO { export interface InspectOrgVO {
orgID: string // 机构ID orgid: string // 机构ID
orgName: string // 机构名称 orgName: string // 机构名称
address: string // 机构地址 address: string // 机构地址
contactTel: string // 联系电话 contactTel: string // 联系电话

View File

@ -19,7 +19,7 @@
<el-input v-model="formData.orgSN" placeholder="请输入机构编号" /> <el-input v-model="formData.orgSN" placeholder="请输入机构编号" />
</el-form-item> </el-form-item>
<el-form-item label="机构码" prop="inHisCode"> <el-form-item label="机构码" prop="inHisCode">
<el-input v-model="formData.inHisCode" placeholder="请输入在his系统中的 hiscode 机构码" /> <el-input v-model="formData.inHisCode" placeholder="请输入机构码" />
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="12"> <el-col :span="12">
@ -86,6 +86,7 @@ const formRules = reactive({
orgType: [{ required: true, message: '请选择医院机构类型', trigger: 'change' }], orgType: [{ required: true, message: '请选择医院机构类型', trigger: 'change' }],
orgName: [{ required: true, message: '请输入机构名称', trigger: 'change' }], orgName: [{ required: true, message: '请输入机构名称', trigger: 'change' }],
contactPerson: [{ required: true, message: '请输入联系人姓名', trigger: 'change' }], contactPerson: [{ required: true, message: '请输入联系人姓名', trigger: 'change' }],
inHisCode: [{ required: true, message: '请输入机构码', trigger: 'change' }],
contactTel: [ contactTel: [
{ required: true, message: '请填入正确的手机号', trigger: 'blur' }, { required: true, message: '请填入正确的手机号', trigger: 'blur' },
{ {

View File

@ -54,7 +54,7 @@
<!-- 列表 --> <!-- 列表 -->
<ContentWrap> <ContentWrap>
<el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true"> <el-table v-loading="loading" :data="list" :stripe="true" :show-overflow-tooltip="true">
<el-table-column label="机构编号" align="center" prop="orgSN" /> <el-table-column label="机构码" align="center" prop="inHisCode" />
<el-table-column label="机构名称" align="center" prop="orgName" /> <el-table-column label="机构名称" align="center" prop="orgName" />
<el-table-column label="机构地址" align="center" prop="address" /> <el-table-column label="机构地址" align="center" prop="address" />
<el-table-column label="联系电话" align="center" prop="contactTel" /> <el-table-column label="联系电话" align="center" prop="contactTel" />

View File

@ -1,6 +1,6 @@
<template> <template>
<div class="head-container"> <div class="head-container">
<el-input v-model="deptName" class="mb-20px" clearable placeholder="请输入科室名称"> <el-input v-model="orgName" class="mb-20px" clearable placeholder="请输入机构名称">
<template #prefix> <template #prefix>
<Icon icon="ep:search" /> <Icon icon="ep:search" />
</template> </template>
@ -9,12 +9,12 @@
<div class="dept-list-container"> <div class="dept-list-container">
<div <div
v-for="item in filteredDeptList" v-for="item in filteredDeptList"
:key="item.departmentCode" :key="item.orgid"
class="dept-item" class="dept-item"
:class="{ 'active': selectedDept === item.departmentCode }" :class="{ 'active': selectedDept === item.orgid }"
@click="handleDeptChange(item.departmentCode)" @click="handleDeptChange(item.orgid)"
> >
{{ item.departmentName }} {{ item.orgName }}
</div> </div>
</div> </div>
</template> </template>
@ -24,29 +24,31 @@ import { ElTree } from 'element-plus'
import * as DeptApi from '@/api/system/dept' import * as DeptApi from '@/api/system/dept'
import { defaultProps, handleTree } from '@/utils/tree' import { defaultProps, handleTree } from '@/utils/tree'
import { DepartmentApi, DepartmentVO } from '@/api/inspect/inspectdepartment/index' import { DepartmentApi, DepartmentVO } from '@/api/inspect/inspectdepartment/index'
import { InspectOrgApi, InspectOrgVO } from '@/api/inspect/inspectorg/index'
defineOptions({ name: 'SystemUserDeptTree' }) defineOptions({ name: 'SystemUserDeptTree' })
const deptName = ref('') const orgName = ref('')
const deptList = ref<DepartmentVO[]>([]) // const orgList = ref<InspectOrgVO[]>([]) //
const selectedDept = ref('') const selectedDept = ref('')
/** 获取科室列表 */ /** 获取科室列表 */
const getList = async () => { const getList = async () => {
const res = await DepartmentApi.getListDepartment() const res = await InspectOrgApi.getInspectOrgAll({})
deptList.value = res orgList.value = res
console.log(orgList.value)
} }
/** 过滤后的科室列表 */ /** 过滤后的科室列表 */
const filteredDeptList = computed(() => { const filteredDeptList = computed(() => {
if (!deptName.value) return deptList.value if (!orgName.value) return orgList.value.list
return deptList.value.filter(item => return orgList.value.list.filter(item =>
item.departmentName.includes(deptName.value) item.orgName.includes(orgName.value)
) )
}) })
/** 处理科室选择 */ /** 处理科室选择 */
const handleDeptChange = (deptId: string | number) => { const handleDeptChange = (deptId: string | number) => {
const selectedDepartment = deptList.value.find(item => item.departmentCode === deptId) const selectedDepartment = orgList.value.list.find(item => item.orgid === deptId)
emits('node-click', selectedDepartment) emits('node-click', selectedDepartment)
} }

View File

@ -14,13 +14,13 @@
</el-form-item> </el-form-item>
</el-col> </el-col>
<el-col :span="12"> <el-col :span="12">
<el-form-item label="归属科室" prop="deptId"> <el-form-item label="归属机构" prop="deptId">
<el-select v-model="formData.deptId" placeholder="请选择归属科室"> <el-select v-model="formData.deptId" placeholder="请选择归属机构">
<el-option <el-option
v-for="item in deptList" v-for="item in orgList.list"
:key="item.departmentName" :key="item.orgid"
:label="item.departmentName" :label="item.orgName"
:value="item.departmentCode" :value="item.orgid"
/> />
</el-select> </el-select>
</el-form-item> </el-form-item>
@ -103,7 +103,7 @@ import * as PostApi from '@/api/system/post'
import * as DeptApi from '@/api/system/dept' import * as DeptApi from '@/api/system/dept'
import * as UserApi from '@/api/system/user' import * as UserApi from '@/api/system/user'
import { FormRules } from 'element-plus' import { FormRules } from 'element-plus'
import { DepartmentApi, DepartmentVO } from '@/api/inspect/inspectdepartment/index' import { InspectOrgApi, InspectOrgVO } from '@/api/inspect/inspectorg/index'
defineOptions({ name: 'SystemUserForm' }) defineOptions({ name: 'SystemUserForm' })
@ -148,7 +148,7 @@ const formRules = reactive<FormRules>({
] ]
}) })
const formRef = ref() // Ref const formRef = ref() // Ref
const deptList = ref<DepartmentVO[]>([]) // const orgList = ref<InspectOrgVO[]>([]) //
const postList = ref([] as PostApi.PostVO[]) // const postList = ref([] as PostApi.PostVO[]) //
/** 打开弹窗 */ /** 打开弹窗 */
@ -168,7 +168,8 @@ const open = async (type: string, id?: number) => {
} }
// //
// deptList.value = handleTree(await DeptApi.getSimpleDeptList()) // deptList.value = handleTree(await DeptApi.getSimpleDeptList())
deptList.value = await DepartmentApi.getListDepartment() orgList.value = await InspectOrgApi.getInspectOrgAll({})
console.log(orgList.value)
// //
// postList.value = await PostApi.getSimplePostList() // postList.value = await PostApi.getSimplePostList()
} }

View File

@ -110,7 +110,7 @@
:show-overflow-tooltip="true" :show-overflow-tooltip="true"
/> />
<el-table-column <el-table-column
label="科室" label="机构"
align="center" align="center"
key="deptName" key="deptName"
prop="deptName" prop="deptName"
@ -258,7 +258,7 @@ const resetQuery = () => {
/** 处理部门被点击 */ /** 处理部门被点击 */
const handleDeptNodeClick = async (row) => { const handleDeptNodeClick = async (row) => {
queryParams.deptId = row.departmentCode queryParams.deptId = row.orgid
await getList() await getList()
} }