|
@@ -1,23 +1,12 @@
|
|
|
<template>
|
|
|
<div id="leaveReason">
|
|
|
<el-row>
|
|
|
- <el-col :span="24" class="info">
|
|
|
+ <el-col :span="24" class="style">
|
|
|
<el-col :span="24" class="top">
|
|
|
- 请假审核结果
|
|
|
+ <topInfo></topInfo>
|
|
|
</el-col>
|
|
|
- <el-col :span="24" class="reason">
|
|
|
- <p>请假开始时间:{{ reasonInfo.starttime }}</p>
|
|
|
- <p>请假结束时间:{{ reasonInfo.endtime }}</p>
|
|
|
- <p>
|
|
|
- 请假理由:
|
|
|
- <span class="span">{{ reasonInfo.reason }}</span>
|
|
|
- </p>
|
|
|
- <span v-if="reasonInfo.ispass === '0' || reasonInfo.ispass === '1'">
|
|
|
- <p>
|
|
|
- 请假拒绝理由:
|
|
|
- <span class="span">{{ reasonInfo.refcause }}</span>
|
|
|
- </p>
|
|
|
- </span>
|
|
|
+ <el-col :span="24" class="main">
|
|
|
+ <leaveRefuse :refuseInfo="refuseInfo"></leaveRefuse>
|
|
|
</el-col>
|
|
|
</el-col>
|
|
|
</el-row>
|
|
@@ -25,19 +14,19 @@
|
|
|
</template>
|
|
|
|
|
|
<script>
|
|
|
+import topInfo from '@/layout/common/topInfo.vue';
|
|
|
+import leaveRefuse from '@/layout/user/leaveRefuse.vue';
|
|
|
import { createNamespacedHelpers, mapGetters } from 'vuex';
|
|
|
const { mapActions: mapLeave } = createNamespacedHelpers('leave');
|
|
|
export default {
|
|
|
name: 'leaveReason',
|
|
|
props: {},
|
|
|
- components: {},
|
|
|
+ components: {
|
|
|
+ topInfo, //头部导航
|
|
|
+ leaveRefuse, //拒绝理由
|
|
|
+ },
|
|
|
data: () => ({
|
|
|
- reasonInfo: {
|
|
|
- starttime: '2020-02-18',
|
|
|
- endtime: '2020-02-20',
|
|
|
- reason: '请假理由请假理由请假理由请假理由请假理由请假理由请假理由请假理由',
|
|
|
- refcause: '拒绝理由拒绝理由拒绝理由拒绝理由拒绝理由拒绝理由拒绝理由拒绝理由',
|
|
|
- },
|
|
|
+ refuseInfo: {},
|
|
|
}),
|
|
|
created() {
|
|
|
this.searchInfo();
|
|
@@ -52,7 +41,7 @@ export default {
|
|
|
async searchInfo() {
|
|
|
if (this.$route.query.id) {
|
|
|
const res = await this.fetch(this.id);
|
|
|
- this.$set(this, `reasonInfo`, res.data);
|
|
|
+ this.$set(this, `refuseInfo`, res.data);
|
|
|
}
|
|
|
},
|
|
|
},
|
|
@@ -60,33 +49,17 @@ export default {
|
|
|
</script>
|
|
|
|
|
|
<style lang="less" scoped>
|
|
|
-p {
|
|
|
- padding: 0;
|
|
|
- margin: 0;
|
|
|
-}
|
|
|
-.info {
|
|
|
+.style {
|
|
|
width: 100%;
|
|
|
- height: 100vh;
|
|
|
+ min-height: 667px;
|
|
|
position: relative;
|
|
|
- overflow: hidden;
|
|
|
- background-color: #edeae8;
|
|
|
+ background-color: #f9fafc;
|
|
|
}
|
|
|
-.info .top {
|
|
|
- text-align: center;
|
|
|
- padding: 15px 0;
|
|
|
- font-size: 30px;
|
|
|
-}
|
|
|
-.reason {
|
|
|
- padding: 0 15px;
|
|
|
- color: #333;
|
|
|
-}
|
|
|
-.reason p {
|
|
|
- padding: 10px 0;
|
|
|
+.top {
|
|
|
+ height: 46px;
|
|
|
+ overflow: hidden;
|
|
|
}
|
|
|
-.reason p .span {
|
|
|
- width: 100%;
|
|
|
- display: inline-block;
|
|
|
- text-indent: 2rem;
|
|
|
- line-height: 30px;
|
|
|
+.main {
|
|
|
+ min-height: 570px;
|
|
|
}
|
|
|
</style>
|