249 lines
7.0 KiB
Vue
249 lines
7.0 KiB
Vue
<!-- 请假申请 -->
|
|
<template>
|
|
<view class="form-page">
|
|
<scroll-view scroll-y class="form-scroll">
|
|
<uni-forms v-model="form" label-width="200rpx" ref="customForm" :rules="customRules">
|
|
<!-- 审批状态卡片 -->
|
|
<view class="form-card" v-if="form.ticket_">
|
|
<ticketd :ticket_="form.ticket_"></ticketd>
|
|
</view>
|
|
|
|
<!-- 基本信息 -->
|
|
<view class="form-card">
|
|
<view class="form-card-title">基本信息</view>
|
|
<uni-forms-item label="部门">
|
|
<uni-easyinput v-model="form.belong_dept_name" placeholder="请输入岗位" :disabled="true" v-if="mode!='show'"/>
|
|
<span v-else>{{form.belong_dept_name}}</span>
|
|
</uni-forms-item>
|
|
<uni-forms-item label="员工信息">
|
|
<span>{{form.employee_name}}</span>
|
|
</uni-forms-item>
|
|
<uni-forms-item label="人员岗位">
|
|
<uni-easyinput v-model="form.post_name" placeholder="请输入需求岗位" :disabled="true" v-if="mode!='show'"/>
|
|
<span v-else>{{form.post_name}}</span>
|
|
</uni-forms-item>
|
|
</view>
|
|
|
|
<!-- 请假详情 -->
|
|
<view class="form-card">
|
|
<view class="form-card-title">请假详情</view>
|
|
<uni-forms-item label="请假时长(8h/天)" required>
|
|
<uni-number-box v-model="form.hour" :min="0" v-if="mode!='show'"></uni-number-box>
|
|
<span v-else>{{form.hour}}小时</span>
|
|
</uni-forms-item>
|
|
<uni-forms-item label="开始日期" required>
|
|
<uni-datetime-picker type="datetime" :clear-icon="false" v-model="form.start_date" v-if="mode!='show'"/>
|
|
<span v-else>{{form.start_date}}</span>
|
|
</uni-forms-item>
|
|
<uni-forms-item label="结束日期" required>
|
|
<uni-datetime-picker type="datetime" :clear-icon="false" v-model="form.end_date" v-if="mode!='show'"/>
|
|
<span v-else>{{form.end_date}}</span>
|
|
</uni-forms-item>
|
|
<uni-forms-item label="请假类型" required>
|
|
<uni-data-select
|
|
v-if="mode!='show'"
|
|
v-model="form.leave_type"
|
|
:localdata="leaveList"
|
|
:disabled="mode=='show'"
|
|
@change="leaveChange"
|
|
></uni-data-select>
|
|
<span v-else>{{getLabel(leaveList,form.leave_type) }}</span>
|
|
</uni-forms-item>
|
|
<uni-forms-item label-width="100" label="请假事由" required>
|
|
<textarea placeholder-style="color:#c0c4cc" v-model="form.reason" placeholder="请输入请假事由" class="form-textarea"/>
|
|
</uni-forms-item>
|
|
<uni-forms-item label="上传附件" v-if="showUpload">
|
|
<xtUpload v-model="form.file" xtype="path" :disabled="mode=='show'"></xtUpload>
|
|
</uni-forms-item>
|
|
</view>
|
|
</uni-forms>
|
|
</scroll-view>
|
|
<view class="footer_fixed">
|
|
<button v-if="mode=='edit'" class="form-btn form-btn-danger" @click="handleDel" :loading="saveLoading" :disabled="saveLoading">
|
|
删除
|
|
</button>
|
|
<button v-if="mode!='show'" class="form-btn form-btn-primary" @click="handleSave" :loading="saveLoading" :disabled="saveLoading">
|
|
提交审批
|
|
</button>
|
|
<ticketd_b :workflow_key="'wf_leave'" v-if="form.ticket_ && mode == 'show'" :t_id="form.id" :ticket_="form.ticket_"
|
|
:ticket_data="ticket_data" @success="()=>{uni.navigateBack()}" ref="ticketd_b"></ticketd_b>
|
|
</view>
|
|
</view>
|
|
</template>
|
|
|
|
<script>
|
|
import ticketd_b from "../wf/ticketd_b.vue"
|
|
import ticketd from "../wf/ticketd.vue"
|
|
import {actStateEnum} from "@/utils/enum.js"
|
|
export default {
|
|
components: { ticketd_b, ticketd },
|
|
data(){
|
|
return{
|
|
saveLoading: false,
|
|
mode:"show",
|
|
t_id: null,
|
|
form:{},
|
|
ticket_data:{},
|
|
userInfo:{},
|
|
type:0,
|
|
leaveList: [
|
|
{ value: 10, text: '事假' },
|
|
{ value: 20, text: '病假' },
|
|
{ value: 30, text: '婚假' },
|
|
{ value: 40, text: '丧假' },
|
|
{ value: 50, text: '公假' },
|
|
{ value: 60, text: '工伤' },
|
|
{ value: 70, text: '产假' },
|
|
{ value: 80, text: '护理假' },
|
|
{ value: 90, text: '其他' }
|
|
],
|
|
customRules: {
|
|
start_date: {
|
|
rules: [{
|
|
required: true,
|
|
errorMessage: '不能为空'
|
|
}]
|
|
},
|
|
end_date: {
|
|
rules: [{
|
|
required: true,
|
|
errorMessage: '不能为空'
|
|
}]
|
|
}
|
|
},
|
|
}
|
|
},
|
|
async onLoad(options) {
|
|
let that = this;
|
|
that.mode = options.mode?options.mode:'show';
|
|
that.t_id = options.t_id?options.t_id:null;
|
|
if(that.t_id) {
|
|
const res = await that.$api.leaveItem(that.t_id);
|
|
this.form = res
|
|
await this.fillNames()
|
|
if(that.form.ticket_.state_.type == 1 && that.form.create_by == uni.getStorageSync("userInfo").id ) {
|
|
that.mode = "edit";
|
|
}else{
|
|
that.mode = "show";
|
|
}
|
|
}
|
|
else{
|
|
that.fillNames();
|
|
}
|
|
},
|
|
computed: {
|
|
showUpload() {
|
|
return [20, 30, 40, 70].includes(this.form.leave_type)
|
|
}
|
|
},
|
|
methods:{
|
|
async fillNames(){
|
|
const employee = await this.$api.employeeInfo()
|
|
this.form.employee_name = employee.name
|
|
this.form.belong_dept_name = employee.belong_dept_name
|
|
this.form.post_name = employee.post_name
|
|
this.form.employee = employee.id;
|
|
this.mode = "add";
|
|
},
|
|
async handleDel(){
|
|
let that = this;
|
|
await that.$api.leaveDelete(that.form.id)
|
|
uni.navigateBack()
|
|
},
|
|
async handleSave(){
|
|
let that = this;
|
|
that.$refs.customForm.validate().then(res => {
|
|
|
|
}).catch(err => {
|
|
console.log('err', err);
|
|
})
|
|
await that.$api.leaveCreate(that.form)
|
|
uni.navigateBack()
|
|
},
|
|
getLabel(list, value) {
|
|
if (!list || value === undefined || value === null) return ''
|
|
const item = list.find(i => String(i.value) === String(value))
|
|
return item ? item.text : ''
|
|
},
|
|
leaveChange(val) {
|
|
const map = {
|
|
10: '事假',
|
|
20: '病假',
|
|
30: '婚假',
|
|
40: '丧假',
|
|
50: '公假',
|
|
60: '工伤',
|
|
70: '产假',
|
|
80: '护理假',
|
|
90: '其他',
|
|
}
|
|
this.form.leave_type_name = map[val] || ''
|
|
},
|
|
},
|
|
|
|
}
|
|
</script>
|
|
|
|
<style lang="scss" scoped>
|
|
.form-page {
|
|
min-height: 100vh;
|
|
background: #F0F2F5;
|
|
}
|
|
|
|
.form-scroll {
|
|
padding: 0;
|
|
padding-bottom: 180rpx;
|
|
}
|
|
|
|
.form-card {
|
|
background: #fff;
|
|
border-radius: 0;
|
|
padding: 24rpx;
|
|
margin-bottom: 0;
|
|
box-shadow: none;
|
|
}
|
|
|
|
.form-card-title {
|
|
font-size: 30rpx;
|
|
font-weight: 600;
|
|
color: #1F2937;
|
|
margin-bottom: 16rpx;
|
|
padding-left: 16rpx;
|
|
border-left: 6rpx solid #2BA471;
|
|
}
|
|
|
|
.form-textarea {
|
|
width: 100%;
|
|
min-height: 160rpx;
|
|
border: 2rpx solid #E5E7EB;
|
|
border-radius: 12rpx;
|
|
padding: 16rpx;
|
|
font-size: 28rpx;
|
|
color: #374151;
|
|
box-sizing: border-box;
|
|
background: #F9FAFB;
|
|
}
|
|
|
|
.form-btn {
|
|
flex: 1;
|
|
height: 80rpx;
|
|
line-height: 80rpx;
|
|
border-radius: 14rpx !important;
|
|
font-size: 28rpx;
|
|
font-weight: 500;
|
|
border: none !important;
|
|
letter-spacing: 2rpx;
|
|
}
|
|
|
|
.form-btn-primary {
|
|
background: linear-gradient(135deg, #2BA471, #1F8C5E) !important;
|
|
color: #fff !important;
|
|
box-shadow: 0 4rpx 12rpx rgba(43, 164, 113, 0.2);
|
|
}
|
|
|
|
.form-btn-danger {
|
|
background: linear-gradient(135deg, #EF4444, #DC2626) !important;
|
|
color: #fff !important;
|
|
box-shadow: 0 4rpx 12rpx rgba(239, 68, 68, 0.3);
|
|
}
|
|
</style> |