157 lines
3.4 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>
<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">
<LcglSpList :yw-id="qjId" yw-type="JS_QJ" />
2025-09-05 17:46:43 +08:00
</view>
</view>
<template #bottom>
<YwConfirm :api="jsQjJwcQrApi" :params="spParams"
@summit="submit" @reject="handleReject" />
2025-09-05 17:46:43 +08:00
</template>
2025-07-26 21:29:04 +08:00
</BasicLayout>
</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";
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 LcglSpList from "@/components/LcglSpList/index.vue";
import YwConfirm from "@/pages/components/YwConfirm/index.vue";
import { QjPageUtils } from "@/utils/qjPageUtils";
2025-09-05 17:46:43 +08:00
const { getJs } = useUserStore();
const { setData } = useDataStore();
2025-09-05 17:46:43 +08:00
const tabList = ref<any>([{ name: "请假信息", id: "tab-qj" }]);
const curTabIndex = ref(0);
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);
const spParams = computed(() => {
return {
qjId: qjId.value,
jsId: getJs.id,
};
});
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组件处理
};
2025-07-26 21:29:04 +08:00
const submit = async () => {
navigateBack();
};
2025-07-27 23:37:02 +08:00
// 驳回处理
const handleReject = async () => {
2025-08-29 01:27:54 +08:00
navigateBack();
2025-07-27 23:37:02 +08:00
};
2025-09-05 17:46:43 +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>
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>