优化
This commit is contained in:
@ -42,11 +42,7 @@
|
|||||||
<el-col :span="1.5">
|
<el-col :span="1.5">
|
||||||
<el-button type="primary" plain icon="Plus" @click="handleAdd" v-hasPermi="['project:constructionUser:add']">新增 </el-button>
|
<el-button type="primary" plain icon="Plus" @click="handleAdd" v-hasPermi="['project:constructionUser:add']">新增 </el-button>
|
||||||
</el-col>
|
</el-col>
|
||||||
<el-col :span="1.5">
|
|
||||||
<el-button type="success" plain icon="Edit" :disabled="single" @click="handleUpdate()" v-hasPermi="['project:constructionUser:edit']">
|
|
||||||
修改
|
|
||||||
</el-button>
|
|
||||||
</el-col>
|
|
||||||
<el-col :span="1.5">
|
<el-col :span="1.5">
|
||||||
<el-button
|
<el-button
|
||||||
type="danger"
|
type="danger"
|
||||||
@ -597,7 +593,7 @@ const initFormData: ConstructionUserForm = {
|
|||||||
salary: undefined,
|
salary: undefined,
|
||||||
remark: undefined
|
remark: undefined
|
||||||
};
|
};
|
||||||
const data = reactive<PageData<ConstructionUserForm, ConstructionUserQuery>>({
|
const data = reactive({
|
||||||
form: { ...initFormData },
|
form: { ...initFormData },
|
||||||
queryParams: {
|
queryParams: {
|
||||||
pageNum: 1,
|
pageNum: 1,
|
||||||
@ -606,6 +602,7 @@ const data = reactive<PageData<ConstructionUserForm, ConstructionUserQuery>>({
|
|||||||
nickName: undefined,
|
nickName: undefined,
|
||||||
userName: undefined,
|
userName: undefined,
|
||||||
projectId: currentProject.value.id,
|
projectId: currentProject.value.id,
|
||||||
|
notUserRole:1,
|
||||||
contractorId: undefined,
|
contractorId: undefined,
|
||||||
teamId: undefined,
|
teamId: undefined,
|
||||||
status: undefined,
|
status: undefined,
|
||||||
|
@ -0,0 +1,188 @@
|
|||||||
|
<template>
|
||||||
|
<div>
|
||||||
|
<div class="block_box">
|
||||||
|
<span>用户信息</span>
|
||||||
|
<el-form label-width="130px">
|
||||||
|
<el-row :gutter="20" justify="space-around">
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="人脸照">
|
||||||
|
<el-image :src="userDetail?.facePicUrl" style="width: 150px; height: 150px" />
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="姓名">
|
||||||
|
{{ userDetail?.userName }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="联系电话">
|
||||||
|
{{ userDetail?.phone }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="性别">
|
||||||
|
<dict-tag :options="user_sex_type" :value="userDetail?.sex" />
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="年龄">
|
||||||
|
{{ dayjs().diff(dayjs(userDetail?.sfzBirth), 'year') }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="民族">
|
||||||
|
{{ userDetail?.nation }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="籍贯">
|
||||||
|
{{ userDetail?.nativePlace }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="身份证号码">
|
||||||
|
{{ userDetail?.sfzNumber }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="身份证号码">
|
||||||
|
{{ userDetail?.sfzNumber }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="身份证有效开始期">
|
||||||
|
{{ dayjs(userDetail?.sfzStart).format('YYYY 年 MM 月 DD 日') }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="身份证有效结束期">
|
||||||
|
{{ dayjs(userDetail?.sfzEnd).format('YYYY 年 MM 月 DD 日') }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="身份证地址">
|
||||||
|
{{ userDetail?.sfzSite }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-form>
|
||||||
|
</div>
|
||||||
|
<div class="block_box">
|
||||||
|
<span>银行卡</span>
|
||||||
|
<el-form label-width="130px">
|
||||||
|
<el-row :gutter="20">
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="银行卡号">
|
||||||
|
{{ userDetail?.yhkNumber }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="银行开户行">
|
||||||
|
{{ userDetail?.yhkOpeningBank }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="持卡人">
|
||||||
|
{{ userDetail?.yhkCardholder }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-form>
|
||||||
|
</div>
|
||||||
|
<div class="block_box">
|
||||||
|
<span>单位信息</span>
|
||||||
|
<el-form label-width="130px">
|
||||||
|
<el-row :gutter="20">
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="施工单位">
|
||||||
|
{{ userDetail?.contractorVo?.name }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="工种">
|
||||||
|
<dict-tag :options="type_of_work" :value="userDetail?.typeOfWork" />
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-form>
|
||||||
|
</div>
|
||||||
|
<div class="block_box">
|
||||||
|
<span>其他信息</span>
|
||||||
|
<el-form label-width="130px">
|
||||||
|
<el-row :gutter="20">
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="班组">
|
||||||
|
{{ userDetail?.teamVo?.teamName }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="打卡状态">
|
||||||
|
<dict-tag :options="user_clock_type" :value="userDetail?.clock" />
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="入场时间">
|
||||||
|
{{ userDetail?.entryDate ? dayjs(userDetail?.entryDate).format('YYYY 年 MM 月 DD 日 HH:mm:ss') : '' }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
<el-col :span="12">
|
||||||
|
<el-form-item label="离场时间">
|
||||||
|
{{ userDetail?.leaveDate ? dayjs(userDetail?.leaveDate).format('YYYY 年 MM 月 DD 日 HH:mm:ss') : '' }}
|
||||||
|
</el-form-item>
|
||||||
|
</el-col>
|
||||||
|
</el-row>
|
||||||
|
</el-form>
|
||||||
|
</div>
|
||||||
|
</div>
|
||||||
|
</template>
|
||||||
|
|
||||||
|
<script setup lang="ts">
|
||||||
|
import { getConstructionUser } from '@/api/project/constructionUser';
|
||||||
|
import { ConstructionUserVO } from '@/api/project/constructionUser/types';
|
||||||
|
import { dayjs } from 'element-plus';
|
||||||
|
|
||||||
|
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
|
||||||
|
const { type_of_work, user_sex_type, user_clock_type } = toRefs<any>(proxy?.useDict('type_of_work', 'user_sex_type', 'user_clock_type'));
|
||||||
|
|
||||||
|
interface Props {
|
||||||
|
userId?: string | number;
|
||||||
|
}
|
||||||
|
|
||||||
|
const props = defineProps<Props>();
|
||||||
|
const loading = ref<boolean>(false);
|
||||||
|
const userDetail = ref<ConstructionUserVO>();
|
||||||
|
const getUserDetail = async () => {
|
||||||
|
loading.value = true;
|
||||||
|
const res = await getConstructionUser(props.userId);
|
||||||
|
if (res.data && res.code === 200) {
|
||||||
|
userDetail.value = res.data;
|
||||||
|
}
|
||||||
|
loading.value = false;
|
||||||
|
};
|
||||||
|
|
||||||
|
onMounted(() => {
|
||||||
|
getUserDetail();
|
||||||
|
});
|
||||||
|
|
||||||
|
watch(
|
||||||
|
() => props.userId,
|
||||||
|
(newId, oldId) => {
|
||||||
|
if (newId !== oldId) {
|
||||||
|
getUserDetail();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
</script>
|
||||||
|
<style lang="scss" scoped>
|
||||||
|
.block_box {
|
||||||
|
border: 1px solid #9eccfa;
|
||||||
|
border-radius: 6px;
|
||||||
|
padding: 10px 20px 20px 10px;
|
||||||
|
margin: 15px;
|
||||||
|
> span {
|
||||||
|
color: #409eff;
|
||||||
|
font-weight: 700;
|
||||||
|
font-size: 14px;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
</style>
|
1170
src/views/project/projectUser/index.vue
Normal file
1170
src/views/project/projectUser/index.vue
Normal file
File diff suppressed because it is too large
Load Diff
Reference in New Issue
Block a user