✨ feat: 添加离职申请的用户绑定,修改用户档案
This commit is contained in:
@@ -18,7 +18,7 @@
|
|||||||
<el-row :gutter="18">
|
<el-row :gutter="18">
|
||||||
<el-col :span="12">
|
<el-col :span="12">
|
||||||
<el-form-item label="离职人员" required>
|
<el-form-item label="离职人员" required>
|
||||||
<el-select v-model="form.userId" filterable placeholder="请选择">
|
<el-select v-model="form.userId" filterable placeholder="请选择" :disabled="!canChangeUser">
|
||||||
<el-option
|
<el-option
|
||||||
v-for="item in userList"
|
v-for="item in userList"
|
||||||
:key="item.userId"
|
:key="item.userId"
|
||||||
@@ -63,6 +63,7 @@
|
|||||||
import { addOffboarding } from "@/api/oa/offboarding";
|
import { addOffboarding } from "@/api/oa/offboarding";
|
||||||
import { listUser } from "@/api/system/user";
|
import { listUser } from "@/api/system/user";
|
||||||
import { uploadFile, addFile } from '@/api/oa/document'
|
import { uploadFile, addFile } from '@/api/oa/document'
|
||||||
|
import { getUserProfile } from "@/api/system/user";
|
||||||
|
|
||||||
export default {
|
export default {
|
||||||
name: "Offboarding",
|
name: "Offboarding",
|
||||||
@@ -77,6 +78,7 @@
|
|||||||
},
|
},
|
||||||
created() {
|
created() {
|
||||||
this.getUserList();
|
this.getUserList();
|
||||||
|
this.getUserInfo();
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
// 获取用户列表
|
// 获取用户列表
|
||||||
@@ -86,6 +88,22 @@
|
|||||||
})
|
})
|
||||||
},
|
},
|
||||||
|
|
||||||
|
canChangeUser() {
|
||||||
|
const dir = this.user.roles.map(item => {
|
||||||
|
return item.roleKey
|
||||||
|
})
|
||||||
|
return dir.includes("admin")
|
||||||
|
},
|
||||||
|
|
||||||
|
// 获取用户信息
|
||||||
|
getUserInfo() {
|
||||||
|
getUserProfile().then(res => {
|
||||||
|
this.user = res.data.user;
|
||||||
|
this.form.userId = this.user.userId;
|
||||||
|
console.log(this.user);
|
||||||
|
})
|
||||||
|
},
|
||||||
|
|
||||||
// 文件状态改变时的处理
|
// 文件状态改变时的处理
|
||||||
handleFileChange(file, fileList) {
|
handleFileChange(file, fileList) {
|
||||||
this.fileList = fileList;
|
this.fileList = fileList;
|
||||||
|
|||||||
@@ -12,27 +12,39 @@
|
|||||||
</div>
|
</div>
|
||||||
<ul class="list-group list-group-striped">
|
<ul class="list-group list-group-striped">
|
||||||
<li class="list-group-item">
|
<li class="list-group-item">
|
||||||
|
<span>
|
||||||
<svg-icon icon-class="user" />用户名称
|
<svg-icon icon-class="user" />用户名称
|
||||||
|
</span>
|
||||||
<div class="pull-right">{{ user.userName }}</div>
|
<div class="pull-right">{{ user.userName }}</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="list-group-item">
|
<li class="list-group-item">
|
||||||
|
<span>
|
||||||
<svg-icon icon-class="phone" />手机号码
|
<svg-icon icon-class="phone" />手机号码
|
||||||
|
</span>
|
||||||
<div class="pull-right">{{ user.phonenumber }}</div>
|
<div class="pull-right">{{ user.phonenumber }}</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="list-group-item">
|
<li class="list-group-item">
|
||||||
|
<span>
|
||||||
<svg-icon icon-class="email" />用户邮箱
|
<svg-icon icon-class="email" />用户邮箱
|
||||||
|
</span>
|
||||||
<div class="pull-right">{{ user.email }}</div>
|
<div class="pull-right">{{ user.email }}</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="list-group-item">
|
<li class="list-group-item">
|
||||||
|
<span>
|
||||||
<svg-icon icon-class="tree" />所属部门
|
<svg-icon icon-class="tree" />所属部门
|
||||||
|
</span>
|
||||||
<div class="pull-right" v-if="user.dept">{{ user.dept.deptName }} / {{ postGroup }}</div>
|
<div class="pull-right" v-if="user.dept">{{ user.dept.deptName }} / {{ postGroup }}</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="list-group-item">
|
<li class="list-group-item">
|
||||||
|
<span>
|
||||||
<svg-icon icon-class="peoples" />所属角色
|
<svg-icon icon-class="peoples" />所属角色
|
||||||
|
</span>
|
||||||
<div class="pull-right">{{ roleGroup }}</div>
|
<div class="pull-right">{{ roleGroup }}</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="list-group-item">
|
<li class="list-group-item">
|
||||||
|
<span>
|
||||||
<svg-icon icon-class="date" />创建日期
|
<svg-icon icon-class="date" />创建日期
|
||||||
|
</span>
|
||||||
<div class="pull-right">{{ user.createTime }}</div>
|
<div class="pull-right">{{ user.createTime }}</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="list-group-item" v-if="onBoardingInfo.status == '0'">
|
<li class="list-group-item" v-if="onBoardingInfo.status == '0'">
|
||||||
@@ -42,7 +54,9 @@
|
|||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="list-group-item" v-else>
|
<li class="list-group-item" v-else>
|
||||||
|
<span>
|
||||||
<svg-icon icon-class="date" />转正日期
|
<svg-icon icon-class="date" />转正日期
|
||||||
|
</span>
|
||||||
<div class="pull-right">{{ onBoardingInfo.joiningDate }}</div>
|
<div class="pull-right">{{ onBoardingInfo.joiningDate }}</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="list-group-item">
|
<li class="list-group-item">
|
||||||
@@ -51,10 +65,10 @@
|
|||||||
<el-button type="danger" @click="toApplyQuit">申请离职</el-button>
|
<el-button type="danger" @click="toApplyQuit">申请离职</el-button>
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
<li class="list-group-item">
|
<li class="list-group-item" v-if="hasDocument">
|
||||||
个人档案
|
个人档案
|
||||||
<div class="pull-right">
|
<div class="pull-right">
|
||||||
<el-button type="text" @click="openFileDrawer">查看档案</el-button>
|
<el-button type="danger" @click="openFileDrawer">查看档案</el-button>
|
||||||
</div>
|
</div>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
@@ -78,15 +92,15 @@
|
|||||||
</el-col>
|
</el-col>
|
||||||
</el-row>
|
</el-row>
|
||||||
|
|
||||||
<el-drawer :title="`${user.nickName} - 文件管理`"
|
<el-drawer title="文件管理"
|
||||||
:visible.sync="fileDrawerVisible"
|
:visible.sync="showFile"
|
||||||
size="800px"
|
size="800px"
|
||||||
direction="rtl"
|
direction="rtl"
|
||||||
append-to-body>
|
append-to-body>
|
||||||
<user-file-manager
|
<UserFileManager
|
||||||
:user-id="user.userId"
|
:user-id="user.userId"
|
||||||
:read-only="true"
|
:read-only="true"
|
||||||
v-if="fileDrawerVisible" />
|
v-if="showFile" />
|
||||||
</el-drawer>
|
</el-drawer>
|
||||||
</div>
|
</div>
|
||||||
</template>
|
</template>
|
||||||
@@ -108,15 +122,14 @@ export default {
|
|||||||
roleGroup: {},
|
roleGroup: {},
|
||||||
postGroup: {},
|
postGroup: {},
|
||||||
activeTab: "userinfo",
|
activeTab: "userinfo",
|
||||||
fileDrawerVisible: false,
|
showFile: false,
|
||||||
onBoardingInfo: {}
|
onBoardingInfo: {},
|
||||||
|
hasDocument: false,
|
||||||
};
|
};
|
||||||
},
|
},
|
||||||
|
|
||||||
created() {
|
created() {
|
||||||
this.getUser();
|
this.getUser();
|
||||||
// 获取用户入职信息
|
|
||||||
|
|
||||||
},
|
},
|
||||||
methods: {
|
methods: {
|
||||||
getUser() {
|
getUser() {
|
||||||
@@ -126,14 +139,26 @@ export default {
|
|||||||
this.roleGroup = response.data.roleGroup;
|
this.roleGroup = response.data.roleGroup;
|
||||||
this.postGroup = response.data.postGroup;
|
this.postGroup = response.data.postGroup;
|
||||||
this.getOnBoardInfo();
|
this.getOnBoardInfo();
|
||||||
|
this.checkHasDocument();
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
async getOnBoardInfo() {
|
async getOnBoardInfo() {
|
||||||
const { data } = await getOnboarding(this.user.userId);
|
const { data } = await getOnboarding(this.user.userId);
|
||||||
this.onBoardingInfo = data;
|
this.onBoardingInfo = data;
|
||||||
},
|
},
|
||||||
|
|
||||||
|
async checkHasDocument() {
|
||||||
|
const dir = this.user.roles.map(item => {
|
||||||
|
return item.roleKey
|
||||||
|
})
|
||||||
|
|
||||||
|
this.hasDocument = !dir.includes("admin")
|
||||||
|
},
|
||||||
|
|
||||||
openFileDrawer() {
|
openFileDrawer() {
|
||||||
this.fileDrawerVisible = true;
|
console.log("打开文件抽屉");
|
||||||
|
this.showFile = true;
|
||||||
|
console.log(this.showFile);
|
||||||
},
|
},
|
||||||
// 跳转到申请转正页面
|
// 跳转到申请转正页面
|
||||||
toApplyProbation() {
|
toApplyProbation() {
|
||||||
@@ -148,3 +173,11 @@ export default {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
|
<style scoped>
|
||||||
|
.list-group-item {
|
||||||
|
display: flex;
|
||||||
|
justify-content: space-between;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
</style>
|
||||||
|
|||||||
Reference in New Issue
Block a user