2025-07-23 00:01:09 +08:00
|
|
|
<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>
|
|
|
|
|
<view class="qj-detail">
|
|
|
|
|
<!-- 请假信息 -->
|
|
|
|
|
<view v-show="curTabIndex === 0">
|
|
|
|
|
<JsQjDetailInfo
|
|
|
|
|
:qjId="qjId"
|
|
|
|
|
:dbFlag="dbFlag"
|
|
|
|
|
@loadQjData="handleQjDataLoaded"
|
|
|
|
|
/>
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
<!-- 代课信息 -->
|
|
|
|
|
<view v-show="showDkTab && curTabIndex === 1">
|
|
|
|
|
<JsQjDetailDk
|
|
|
|
|
:qjId="qjId"
|
|
|
|
|
@loadDkList="handleDkListLoaded"
|
|
|
|
|
/>
|
|
|
|
|
</view>
|
|
|
|
|
|
|
|
|
|
<!-- 审批流程 -->
|
|
|
|
|
<view v-show="curTabIndex === 2">
|
|
|
|
|
<ProgressList :qjId="qjId" />
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
<template #bottom>
|
|
|
|
|
<view class="white-bg-color py-5">
|
|
|
|
|
<view class="flex-row items-center pb-10 pt-5">
|
|
|
|
|
<u-button text="驳回" class="ml-15 mr-7" :plain="true" @click="showDlg" />
|
|
|
|
|
<u-button text="同意" class="mr-15 mr-7" type="primary" @click="submit" />
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</template>
|
2025-07-27 23:37:02 +08:00
|
|
|
<!-- 驳回弹窗 -->
|
|
|
|
|
<u-popup
|
2025-08-29 01:27:54 +08:00
|
|
|
:show="dlgFlag"
|
2025-07-27 23:37:02 +08:00
|
|
|
mode="center"
|
|
|
|
|
:closeOnClickOverlay="false"
|
2025-08-29 01:27:54 +08:00
|
|
|
@close="closeDlg"
|
2025-07-27 23:37:02 +08:00
|
|
|
>
|
|
|
|
|
<view class="popup-content">
|
|
|
|
|
<view class="popup-title">驳回原因</view>
|
|
|
|
|
<u-input
|
|
|
|
|
v-model="rejectReason"
|
|
|
|
|
type="textarea"
|
|
|
|
|
placeholder="请填写驳回原因"
|
|
|
|
|
:autoHeight="true"
|
|
|
|
|
maxlength="200"
|
|
|
|
|
/>
|
|
|
|
|
<view class="popup-actions flex-row justify-end mt-4">
|
2025-08-29 01:27:54 +08:00
|
|
|
<u-button class="mr-2" @click="closeDlg">取消</u-button>
|
2025-07-27 23:37:02 +08:00
|
|
|
<u-button type="primary" @click="handleReject">确定</u-button>
|
|
|
|
|
</view>
|
|
|
|
|
</view>
|
|
|
|
|
</u-popup>
|
2025-07-26 21:29:04 +08:00
|
|
|
</BasicLayout>
|
2025-07-23 00:01:09 +08:00
|
|
|
</template>
|
|
|
|
|
|
|
|
|
|
<script setup lang="ts">
|
2025-09-05 17:46:43 +08:00
|
|
|
import { onLoad } from "@dcloudio/uni-app";
|
|
|
|
|
import { navigateBack } from "@/utils/uniapp";
|
2025-08-29 01:27:54 +08:00
|
|
|
import { jsQjJwcQrApi } from "@/api/base/jsQjApi";
|
2025-07-27 23:37:02 +08:00
|
|
|
import { useUserStore } from "@/store/modules/user";
|
2025-09-05 17:46:43 +08:00
|
|
|
import { useDataStore } from "@/store/modules/data";
|
2025-09-05 21:11:32 +08:00
|
|
|
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";
|
2025-09-05 21:11:32 +08:00
|
|
|
import { QjPageUtils } from "@/utils/qjPageUtils";
|
2025-09-05 17:46:43 +08:00
|
|
|
|
2025-09-05 21:11:32 +08:00
|
|
|
const { getJs } = useUserStore();
|
|
|
|
|
const { setData } = useDataStore();
|
2025-07-23 00:01:09 +08:00
|
|
|
|
2025-09-05 17:46:43 +08:00
|
|
|
const tabList = ref<any>([{ name: "请假信息", id: "tab-qj" }]);
|
|
|
|
|
const curTabIndex = ref(0);
|
2025-07-23 00:01:09 +08:00
|
|
|
|
2025-08-29 01:27:54 +08:00
|
|
|
const dbFlag = ref(false);
|
2025-09-05 17:46:43 +08:00
|
|
|
const qjId = ref('');
|
|
|
|
|
const showDkTab = ref(false);
|
|
|
|
|
|
2025-08-29 01:27:54 +08:00
|
|
|
const dlgFlag = ref(false);
|
2025-07-27 23:37:02 +08:00
|
|
|
const rejectReason = ref("");
|
2025-07-26 21:29:04 +08:00
|
|
|
|
2025-09-05 17:46:43 +08:00
|
|
|
|
|
|
|
|
// 构建Tab列表
|
|
|
|
|
const rebuildTabList = (showDk: boolean) => {
|
|
|
|
|
// 构建Tab列表
|
|
|
|
|
tabList.value = [
|
|
|
|
|
{ name: "请假信息", id: "tab-qj" },
|
|
|
|
|
];
|
|
|
|
|
if (showDk) {
|
|
|
|
|
tabList.value.push({ name: "代课信息", id: "tab-dk" });
|
|
|
|
|
}
|
|
|
|
|
tabList.value.push({ name: "审批流程", id: "tab-sp" });
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
// 切换Tab
|
|
|
|
|
const switchTab = (index: number) => {
|
|
|
|
|
curTabIndex.value = index;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const handleQjDataLoaded = (data: any) => {
|
|
|
|
|
setData(data);
|
|
|
|
|
showDkTab.value = !!(data && data.dkfs != 2);
|
|
|
|
|
rebuildTabList(showDkTab.value);
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const handleDkListLoaded = (list: any[]) => {
|
|
|
|
|
// 代课明细数据已由JsQjDetail组件处理
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const showDlg = () => {
|
|
|
|
|
dlgFlag.value = true;
|
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
const closeDlg = () => {
|
|
|
|
|
dlgFlag.value = false;
|
|
|
|
|
};
|
|
|
|
|
|
2025-07-26 21:29:04 +08:00
|
|
|
const submit = async () => {
|
2025-07-27 23:37:02 +08:00
|
|
|
const params = {
|
|
|
|
|
qjId: qjId.value,
|
|
|
|
|
jsId: getJs.id,
|
2025-08-29 01:27:54 +08:00
|
|
|
spStatus: "approved",
|
|
|
|
|
spRemark: "同意",
|
2025-07-27 23:37:02 +08:00
|
|
|
};
|
2025-08-29 01:27:54 +08:00
|
|
|
uni.showLoading({ title: "确认中..." });
|
2025-07-27 23:37:02 +08:00
|
|
|
await jsQjJwcQrApi(params);
|
2025-07-26 21:29:04 +08:00
|
|
|
uni.hideLoading();
|
|
|
|
|
navigateBack();
|
|
|
|
|
};
|
|
|
|
|
|
2025-07-27 23:37:02 +08:00
|
|
|
// 驳回处理
|
|
|
|
|
const handleReject = async () => {
|
|
|
|
|
if (!rejectReason.value.trim()) {
|
|
|
|
|
uni.showToast({ title: "请填写驳回意见", icon: "none" });
|
|
|
|
|
return;
|
|
|
|
|
}
|
2025-08-29 01:27:54 +08:00
|
|
|
const params = {
|
2025-07-27 23:37:02 +08:00
|
|
|
qjId: qjId.value,
|
|
|
|
|
jsId: getJs.id,
|
2025-08-29 01:27:54 +08:00
|
|
|
spStatus: "rejected",
|
|
|
|
|
spRemark: rejectReason.value,
|
2025-07-27 23:37:02 +08:00
|
|
|
};
|
|
|
|
|
uni.showLoading({ title: "正在驳回..." });
|
2025-08-29 01:27:54 +08:00
|
|
|
await jsQjJwcQrApi(params);
|
|
|
|
|
uni.hideLoading();
|
|
|
|
|
closeDlg();
|
|
|
|
|
navigateBack();
|
2025-07-27 23:37:02 +08:00
|
|
|
};
|
|
|
|
|
|
2025-09-05 17:46:43 +08:00
|
|
|
onLoad(async (data?: any) => {
|
2025-09-05 21:11:32 +08:00
|
|
|
const ret = await QjPageUtils.init(data);
|
|
|
|
|
if (!ret || !ret.success) {
|
|
|
|
|
return;
|
2025-07-23 00:01:09 +08:00
|
|
|
}
|
2025-09-05 21:11:32 +08:00
|
|
|
qjId.value = ret.qjId;
|
|
|
|
|
dbFlag.value = ret.dbFlag;
|
2025-07-23 00:01:09 +08:00
|
|
|
});
|
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>
|
2025-09-05 17:46:43 +08:00
|
|
|
.qj-detail {
|
|
|
|
|
background-color: #f5f7fa;
|
2025-07-27 23:37:02 +08:00
|
|
|
}
|
2025-08-29 01:27:54 +08:00
|
|
|
|
2025-09-05 17:46:43 +08:00
|
|
|
.info-card {
|
|
|
|
|
margin: 15px;
|
|
|
|
|
background-color: #fff;
|
|
|
|
|
border-radius: 8px;
|
|
|
|
|
padding: 15px;
|
|
|
|
|
box-shadow: 0 2px 6px rgba(0, 0, 0, 0.05);
|
2025-08-29 01:27:54 +08:00
|
|
|
|
2025-09-05 17:46:43 +08:00
|
|
|
.card-header {
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
color: #333;
|
|
|
|
|
margin-bottom: 10px;
|
|
|
|
|
|
|
|
|
|
.applicant-name {
|
|
|
|
|
font-size: 16px;
|
|
|
|
|
font-weight: bold;
|
|
|
|
|
color: #333;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
.divider {
|
|
|
|
|
height: 1px;
|
|
|
|
|
background-color: #eee;
|
|
|
|
|
margin-bottom: 15px;
|
|
|
|
|
}
|
2025-08-29 01:27:54 +08:00
|
|
|
|
2025-09-05 17:46:43 +08:00
|
|
|
.card-body {
|
|
|
|
|
padding: 15px;
|
|
|
|
|
}
|
2025-07-27 23:37:02 +08:00
|
|
|
}
|
2025-09-05 17:46:43 +08:00
|
|
|
</style>
|