203 lines
4.9 KiB
Vue
Raw Normal View History

<template>
2025-07-26 21:29:04 +08:00
<BasicLayout>
2025-09-05 17:46:43 +08:00
<template #top>
<view>
<BasicTabs
class="detail-tabs"
:list="tabList"
bar-width="60px"
scroll-count="4"
:current="curTabIndex"
@change="switchTab"
/>
</view>
</template>
2025-08-29 01:27:54 +08:00
<view class="qj-detail">
2025-09-05 17:46:43 +08:00
<!-- 请假信息 -->
<view v-show="curTabIndex === 0">
<JsQjDetailInfo
:qjId="qjId"
:dbFlag="dbFlag"
@loadQjData="handleQjDataLoaded"
/>
</view>
<!-- 代课信息 -->
<view v-show="curTabIndex === 1">
<view v-if="!showDkFlag" class="empty-dk">
<view>{{ showDkEmptyLabel }}</view>
</view>
<JsQjDetailDk v-else
2025-09-05 17:46:43 +08:00
:qjId="qjId"
@loadDkList="handleDkListLoaded"
/>
</view>
2025-08-29 01:27:54 +08:00
2025-09-05 17:46:43 +08:00
<!-- 审批流程 -->
<view v-show="curTabIndex === 2">
<ProgressList :qjId="qjId" />
</view>
2025-08-29 01:27:54 +08:00
</view>
2025-07-26 21:29:04 +08:00
<template #bottom>
<view class="white-bg-color py-5">
<view class="px-15">
<BasicForm @register="register" />
</view>
2025-07-26 21:29:04 +08:00
<view class="flex-row items-center pb-10 pt-5">
2025-09-05 17:46:43 +08:00
<u-button text="取消" class="ml-15 mr-7" :plain="true" @click="navigateBack" />
<u-button text="提交" class="mr-15 mr-7" type="primary" @click="submit" />
2025-07-26 21:29:04 +08:00
</view>
</view>
</template>
</BasicLayout>
</template>
<script setup lang="ts">
2025-08-29 01:27:54 +08:00
import { onLoad } from "@dcloudio/uni-app";
import { useForm } from "@/components/BasicForm/hooks/useForm";
import { navigateBack } from "@/utils/uniapp";
2025-07-27 23:37:02 +08:00
import { jsQjSpApi } from "@/api/base/jsQjApi";
import { useUserStore } from "@/store/modules/user";
2025-08-29 01:27:54 +08:00
import { useDataStore } from "@/store/modules/data";
import { ref } from "vue";
2025-09-05 17:46:43 +08:00
import JsQjDetailInfo from "./components/jsQjDetailInfo.vue";
import JsQjDetailDk from "./components/jsQjDetailDk.vue";
import ProgressList from "./components/progressList.vue";
import { QjPageUtils } from "@/utils/qjPageUtils";
2025-08-29 01:27:54 +08:00
const { getJs } = useUserStore();
const { setData } = useDataStore();
const tabList = ref<any>([
{ name: "请假信息", id: "tab-qj" },
{ name: "代课信息", id: "tab-dk" },
{ name: "审批流程", id: "tab-sp" }
]);
2025-09-05 17:46:43 +08:00
const curTabIndex = ref(0);
const dbFlag = ref(false);
2025-08-29 01:27:54 +08:00
const qjId = ref('');
const showDkFlag = ref(false);
const showDkEmptyLabel = ref('');
2025-07-26 21:29:04 +08:00
2025-08-29 01:27:54 +08:00
const [register, { getValue }] = useForm({
schema: [
{
field: "spStatus",
label: "审批意见",
component: "BasicCheckbox",
required: true,
itemProps: {
labelPosition: "top",
},
componentProps: {
data: [
{ value: 'approved', text: "同意" },
{ value: 'rejected', text: "拒绝" },
],
},
},
{
field: "spRemark",
2025-08-29 01:27:54 +08:00
label: "审批说明",
component: "BasicInput",
required: true,
itemProps: {
labelPosition: "top",
},
componentProps: {
type: "textarea",
placeholder: "请输入审批说明",
},
},
],
});
2025-07-26 21:29:04 +08:00
2025-09-05 17:46:43 +08:00
// 切换Tab
const switchTab = (index: number) => {
curTabIndex.value = index;
};
2025-07-26 21:29:04 +08:00
2025-08-29 01:27:54 +08:00
const handleQjDataLoaded = (data: any) => {
setData(data);
data = data || {};
const dkfs = typeof(data.dkfs) === "string" ? parseInt(data.dkfs) : (data.dkfs || 2);
showDkFlag.value = dkfs === 0;
if (dkfs === 1) {
showDkEmptyLabel.value = "审批同意后由教科处协调";
} else if (dkfs === 2) {
showDkEmptyLabel.value = "无需代课";
}
2025-07-27 23:37:02 +08:00
};
2025-08-29 01:27:54 +08:00
const handleDkListLoaded = (list: any[]) => {
// 代课明细数据已由JsQjDetail组件处理
2025-07-27 23:37:02 +08:00
};
2025-08-29 01:27:54 +08:00
const submit = async () => {
2025-07-27 23:37:02 +08:00
try {
2025-08-29 01:27:54 +08:00
const formData = await getValue();
if (!formData.spStatus || !formData.spRemark) {
2025-08-29 01:27:54 +08:00
uni.showToast({
title: '请填写完整的审批信息',
icon: 'none'
});
return;
}
const params = {
qjId: qjId.value,
2025-08-29 01:27:54 +08:00
jsId: getJs.id,
spStatus: formData.spStatus,
spRemark: formData.spRemark,
2025-08-29 01:27:54 +08:00
};
2025-09-05 17:46:43 +08:00
2025-08-29 01:27:54 +08:00
uni.showLoading({
title: "提交中...",
});
2025-09-05 17:46:43 +08:00
2025-08-29 01:27:54 +08:00
const res = await jsQjSpApi(params);
2025-09-05 17:46:43 +08:00
2025-07-27 23:37:02 +08:00
uni.hideLoading();
2025-08-29 01:27:54 +08:00
uni.showToast({
title: '审批提交成功',
icon: 'success'
});
2025-07-27 23:37:02 +08:00
setTimeout(() => {
uni.reLaunch({ url: '/pages/base/message/index' });
}, 1000);
2025-08-29 01:27:54 +08:00
} catch (error) {
2025-07-27 23:37:02 +08:00
uni.hideLoading();
2025-08-29 01:27:54 +08:00
uni.showToast({
title: '提交失败,请重试',
icon: 'none'
});
console.error('审批提交失败:', error);
2025-07-27 23:37:02 +08:00
}
};
2025-08-29 01:27:54 +08:00
onLoad(async (data?: any) => {
const ret = await QjPageUtils.init(data);
if (!ret || !ret.success) {
return;
}
qjId.value = ret.qjId;
dbFlag.value = ret.dbFlag;
});
2025-07-26 21:29:04 +08:00
</script>
2025-07-27 23:37:02 +08:00
2025-08-29 01:27:54 +08:00
<style lang="scss" scoped>
.qj-detail {
background-color: #f5f7fa;
2025-07-27 23:37:02 +08:00
}
2025-08-29 01:27:54 +08:00
.empty-dk {
2025-08-29 01:27:54 +08:00
margin: 15px;
background-color: #fff;
border-radius: 8px;
padding: 50px 15px;
2025-08-29 01:27:54 +08:00
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
text-align: center;
2025-07-27 23:37:02 +08:00
}
</style>