调整请假和待办处理
This commit is contained in:
parent
16f7aaefdd
commit
b0a8ead56a
@ -159,6 +159,21 @@ export const dbBlApi = async (params: any) => {
|
|||||||
return await post("/api/db/bl", params);
|
return await post("/api/db/bl", params);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
// 获取消息推送列表(替代待办)
|
||||||
|
export const xxtsListApi = async (params: any) => {
|
||||||
|
return await get("/api/xxts/findPage", params);
|
||||||
|
};
|
||||||
|
|
||||||
|
// 处理消息推送(替代待办处理)
|
||||||
|
export const xxtsBlApi = async (params: any) => {
|
||||||
|
return await post("/api/xxts/bl", params);
|
||||||
|
};
|
||||||
|
|
||||||
|
// 根据ID获取消息推送详情
|
||||||
|
export const xxtsFindByIdApi = async (params: any) => {
|
||||||
|
return await get("/api/xxts/findById", params);
|
||||||
|
};
|
||||||
|
|
||||||
// 查询学生请假信息
|
// 查询学生请假信息
|
||||||
export const xsQjFindByIdApi = async (params: any) => {
|
export const xsQjFindByIdApi = async (params: any) => {
|
||||||
return await get("/api/xsQj/findById", params);
|
return await get("/api/xsQj/findById", params);
|
||||||
|
|||||||
@ -22,15 +22,15 @@
|
|||||||
<template #default="{ data }">
|
<template #default="{ data }">
|
||||||
<view class="white-bg-color r-md p-15 mb-15 flex-row" @click="goToDetail(data)">
|
<view class="white-bg-color r-md p-15 mb-15 flex-row" @click="goToDetail(data)">
|
||||||
<view class="card-left">
|
<view class="card-left">
|
||||||
<view class="card-title">{{ data.dbBt }}</view>
|
<view class="card-title">{{ data.xxbt }}</view>
|
||||||
<view class="card-desc" v-html="data.dbZy"></view>
|
<view class="card-desc" v-html="data.xxzy"></view>
|
||||||
<view class="card-meta">
|
<view class="card-meta">
|
||||||
<text>{{ data.createdTime }}</text>
|
<text>{{ data.xxtstime }}</text>
|
||||||
<text>{{ getTimeAgo(data.createdTime) }}</text>
|
<text>{{ getTimeAgo(data.xxtstime) }}</text>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
<view class="card-right" v-if="dbLxMap[data.dbLx]">
|
<view class="card-right" v-if="dbLxMap[data.xxlx]">
|
||||||
<view class="tag" :class="dbLxMap[data.dbLx].className">{{ dbLxMap[data.dbLx].label }}</view>
|
<view class="tag" :class="dbLxMap[data.xxlx].className">{{ dbLxMap[data.xxlx].label }}</view>
|
||||||
</view>
|
</view>
|
||||||
</view>
|
</view>
|
||||||
</template>
|
</template>
|
||||||
@ -41,14 +41,14 @@
|
|||||||
<script lang="ts" setup>
|
<script lang="ts" setup>
|
||||||
import {ref, onMounted} from "vue";
|
import {ref, onMounted} from "vue";
|
||||||
import { useLayout } from "@/components/BasicListLayout/hooks/useLayout";
|
import { useLayout } from "@/components/BasicListLayout/hooks/useLayout";
|
||||||
import { dbListApi } from "@/api/base/server";
|
import { xxtsListApi } from "@/api/base/server";
|
||||||
import { getTimeAgo } from "@/utils/dateUtils";
|
import { getTimeAgo } from "@/utils/dateUtils";
|
||||||
import { useUserStore } from "@/store/modules/user";
|
import { useUserStore } from "@/store/modules/user";
|
||||||
import { useDataStore } from "@/store/modules/data";
|
import { useDataStore } from "@/store/modules/data";
|
||||||
import { useDicStore } from "@/store/modules/dic";
|
import { useDicStore } from "@/store/modules/dic";
|
||||||
const { findByPid } = useDicStore();
|
const { findByPid } = useDicStore();
|
||||||
const { setDb } = useDataStore();
|
const { setDb, setXxts } = useDataStore();
|
||||||
const { getUser } = useUserStore();
|
const { getJs } = useUserStore();
|
||||||
|
|
||||||
const dbLxMap = ref<any>({});
|
const dbLxMap = ref<any>({});
|
||||||
|
|
||||||
@ -76,7 +76,7 @@ const fetchDbLxMap = async () => {
|
|||||||
};
|
};
|
||||||
|
|
||||||
const [register, {reload, setParam}] = useLayout({
|
const [register, {reload, setParam}] = useLayout({
|
||||||
api: dbListApi,
|
api: xxtsListApi,
|
||||||
componentProps: {
|
componentProps: {
|
||||||
auto: false
|
auto: false
|
||||||
},
|
},
|
||||||
@ -87,7 +87,7 @@ const currentTab = ref('A'); // 0: 待办, 1: 已办
|
|||||||
const fetchListData = async (tabIndex: string) => {
|
const fetchListData = async (tabIndex: string) => {
|
||||||
setParam({
|
setParam({
|
||||||
dbZt: tabIndex,
|
dbZt: tabIndex,
|
||||||
userId: getUser.id
|
jsrId: getJs.id
|
||||||
});
|
});
|
||||||
reload();
|
reload();
|
||||||
};
|
};
|
||||||
@ -108,6 +108,7 @@ onMounted(() => {
|
|||||||
const goToDetail = (data: any) => {
|
const goToDetail = (data: any) => {
|
||||||
if (data && data.id) {
|
if (data && data.id) {
|
||||||
setDb(data);
|
setDb(data);
|
||||||
|
setXxts(data); // 同时设置xxts数据,以便兼容微信工作号跳转
|
||||||
uni.navigateTo({
|
uni.navigateTo({
|
||||||
url: data.mobileUrl
|
url: data.mobileUrl
|
||||||
});
|
});
|
||||||
|
|||||||
@ -4,7 +4,7 @@
|
|||||||
<!-- 请假信息卡片 -->
|
<!-- 请假信息卡片 -->
|
||||||
<view class="info-card">
|
<view class="info-card">
|
||||||
<view class="card-header">
|
<view class="card-header">
|
||||||
<text class="applicant-name" v-if="dbFlag">{{ dbData.dbZy }}</text>
|
<text class="applicant-name" v-if="dbFlag">{{ xxtsData.dbZy }}</text>
|
||||||
<text class="applicant-name" v-else>学生{{ qjData.xsxm }}的请假申请</text>
|
<text class="applicant-name" v-else>学生{{ qjData.xsxm }}的请假申请</text>
|
||||||
</view>
|
</view>
|
||||||
<view class="divider"></view>
|
<view class="divider"></view>
|
||||||
@ -70,9 +70,14 @@
|
|||||||
import { onLoad } from "@dcloudio/uni-app";
|
import { onLoad } from "@dcloudio/uni-app";
|
||||||
import { useForm } from "@/components/BasicForm/hooks/useForm";
|
import { useForm } from "@/components/BasicForm/hooks/useForm";
|
||||||
import { navigateBack } from "@/utils/uniapp";
|
import { navigateBack } from "@/utils/uniapp";
|
||||||
import { xsQjFindByIdApi, xsQjSpApi, dbBlApi } from "@/api/base/server";
|
import { xsQjFindByIdApi, xsQjSpApi } from "@/api/base/server";
|
||||||
import { useDataStore } from "@/store/modules/data";
|
import { useDataStore } from "@/store/modules/data";
|
||||||
const { getData, getDb, setData } = useDataStore();
|
import { useUserStore } from "@/store/modules/user";
|
||||||
|
import { ref, nextTick } from "vue";
|
||||||
|
import { xxtsFindByIdApi, xxtsBlApi } from "@/api/base/server";
|
||||||
|
|
||||||
|
const { getData, setXxts, setData, getXxts } = useDataStore();
|
||||||
|
const { getJs } = useUserStore();
|
||||||
|
|
||||||
const dbFlag = ref(false);
|
const dbFlag = ref(false);
|
||||||
|
|
||||||
@ -110,20 +115,22 @@ const [register, { getValue }] = useForm({
|
|||||||
|
|
||||||
// 请假基础数据
|
// 请假基础数据
|
||||||
const qjData = computed(() => getData || {});
|
const qjData = computed(() => getData || {});
|
||||||
const dbData = computed(() => getDb || {});
|
const xxtsData = computed(() => getXxts || {});
|
||||||
|
|
||||||
const submit = async () => {
|
const submit = async () => {
|
||||||
const data = await getValue();
|
const params = {
|
||||||
const params = { ...qjData.value };
|
qjId: qjData.value.id,
|
||||||
params.flag = data.flag;
|
jsId: getJs.id,
|
||||||
params.comment = data.comment;
|
spStatus: 2,
|
||||||
|
spYj: "同意",
|
||||||
|
};
|
||||||
uni.showLoading({
|
uni.showLoading({
|
||||||
title: "提交中...",
|
title: "提交中...",
|
||||||
});
|
});
|
||||||
const res = await xsQjSpApi(params);
|
const res = await xsQjSpApi(params);
|
||||||
// 如果是待办项,更新待办项状态
|
// 如果是待办项,更新待办项状态
|
||||||
if (dbFlag.value) {
|
if (dbFlag.value) {
|
||||||
await dbBlApi({ id: dbData.value.id });
|
await xxtsBlApi({ id: xxtsData.value.id });
|
||||||
}
|
}
|
||||||
uni.hideLoading();
|
uni.hideLoading();
|
||||||
navigateBack();
|
navigateBack();
|
||||||
@ -133,10 +140,43 @@ onLoad(async (data: any) => {
|
|||||||
// 从待办过来的,需要从后端获取数据
|
// 从待办过来的,需要从后端获取数据
|
||||||
if (data && data.from && data.from == "db") {
|
if (data && data.from && data.from == "db") {
|
||||||
dbFlag.value = true;
|
dbFlag.value = true;
|
||||||
|
|
||||||
|
try {
|
||||||
|
// 优先从后端根据url中的id去查询Xxts
|
||||||
|
const xxtsRes = await xxtsFindByIdApi({ id: data.id });
|
||||||
|
if (xxtsRes && xxtsRes.result) {
|
||||||
|
const xxts = xxtsRes.result;
|
||||||
|
|
||||||
|
// 检查待办状态
|
||||||
|
if (xxts.dbZt === "B") {
|
||||||
|
setData({ id: xxts.xxzbId });
|
||||||
|
let url = "/pages/base/xs/qj/detail";
|
||||||
|
uni.navigateTo({ url });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
setXxts(xxts);
|
||||||
|
|
||||||
|
// 根据主表ID去查询学生请假信息
|
||||||
|
const res = await xsQjFindByIdApi({ id: xxts.xxzbId });
|
||||||
|
nextTick(() => {
|
||||||
|
setData(res.result);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("获取待办信息失败", error);
|
||||||
|
// 如果获取Xxts失败,回退到原来的逻辑
|
||||||
|
const xxtsData = getXxts();
|
||||||
|
if (xxtsData && xxtsData.dbZt === "B") {
|
||||||
|
setData({ id: data.id });
|
||||||
|
let url = "/pages/base/xs/qj/detail";
|
||||||
|
uni.navigateTo({ url });
|
||||||
|
return;
|
||||||
|
}
|
||||||
const res = await xsQjFindByIdApi({ id: data.id });
|
const res = await xsQjFindByIdApi({ id: data.id });
|
||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
setData(res.result);
|
setData(res.result);
|
||||||
});
|
});
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
dbFlag.value = false;
|
dbFlag.value = false;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -7,7 +7,7 @@
|
|||||||
<!-- 请假信息卡片 -->
|
<!-- 请假信息卡片 -->
|
||||||
<view class="info-card">
|
<view class="info-card">
|
||||||
<view class="card-header">
|
<view class="card-header">
|
||||||
<text class="applicant-name" v-if="dbFlag">{{ qjData.dbZy }}</text>
|
<text class="applicant-name" v-if="dbFlag">{{ qjData.xxzy }}</text>
|
||||||
<text class="applicant-name" v-else
|
<text class="applicant-name" v-else
|
||||||
>教师{{ qjData.jsName }}的请假申请</text
|
>教师{{ qjData.jsName }}的请假申请</text
|
||||||
>
|
>
|
||||||
@ -90,7 +90,7 @@
|
|||||||
import { findDkPageApi, findQjById } from "@/api/base/jsQjApi";
|
import { findDkPageApi, findQjById } from "@/api/base/jsQjApi";
|
||||||
import { useDataStore } from "@/store/modules/data";
|
import { useDataStore } from "@/store/modules/data";
|
||||||
import ProgressList from "./progressList.vue";
|
import ProgressList from "./progressList.vue";
|
||||||
const { getDb } = useDataStore();
|
const { getXxts } = useDataStore();
|
||||||
|
|
||||||
// 接收外部传入属性
|
// 接收外部传入属性
|
||||||
const props = withDefaults(
|
const props = withDefaults(
|
||||||
@ -174,7 +174,7 @@ const init = async () => {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
if (props.dbFlag) {
|
if (props.dbFlag) {
|
||||||
qjData.value.dbZy = getDb.dbZy;
|
qjData.value.xxzy = getXxts.xxzy;
|
||||||
}
|
}
|
||||||
notifyParentLoaded();
|
notifyParentLoaded();
|
||||||
};
|
};
|
||||||
|
|||||||
@ -52,6 +52,12 @@ let formData = ref<any>({
|
|||||||
jsId: getJs.id,
|
jsId: getJs.id,
|
||||||
});
|
});
|
||||||
|
|
||||||
|
if (typeof props.data.dkfs === "string") {
|
||||||
|
nextTick(() => {
|
||||||
|
formData.value.dkfs = parseInt(props.data.dkfs);
|
||||||
|
})
|
||||||
|
}
|
||||||
|
|
||||||
const [register, { setValue, getValue }] = useForm({
|
const [register, { setValue, getValue }] = useForm({
|
||||||
schema: [
|
schema: [
|
||||||
{
|
{
|
||||||
|
|||||||
@ -6,10 +6,11 @@
|
|||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { findQjById } from "@/api/base/jsQjApi";
|
import { findQjById } from "@/api/base/jsQjApi";
|
||||||
|
import { xxtsFindByIdApi } from "@/api/base/server";
|
||||||
import { useDataStore } from "@/store/modules/data";
|
import { useDataStore } from "@/store/modules/data";
|
||||||
import { onLoad } from "@dcloudio/uni-app";
|
import { onLoad } from "@dcloudio/uni-app";
|
||||||
import JsQjEdit from "./components/jsQjEdit.vue";
|
import JsQjEdit from "./components/jsQjEdit.vue";
|
||||||
const { setData, getData, getDb } = useDataStore();
|
const { setData, getData, setXxts, getXxts } = useDataStore();
|
||||||
|
|
||||||
const dbFlag = ref(false);
|
const dbFlag = ref(false);
|
||||||
|
|
||||||
@ -19,9 +20,35 @@ onLoad(async (data: any) => {
|
|||||||
// 从待办过来的,需要从后端获取数据
|
// 从待办过来的,需要从后端获取数据
|
||||||
if (data && data.from && data.from == "db") {
|
if (data && data.from && data.from == "db") {
|
||||||
dbFlag.value = true;
|
dbFlag.value = true;
|
||||||
if (getDb.dbZt === "B") {
|
|
||||||
setData({ id: data.id });
|
try {
|
||||||
let url = "/pages/view/hr/jsQj/detail"; // 使用新路径
|
// 优先从后端根据url中的id去查询Xxts
|
||||||
|
const xxtsRes = await xxtsFindByIdApi({ id: data.id });
|
||||||
|
if (xxtsRes && xxtsRes.result) {
|
||||||
|
const xxts = xxtsRes.result;
|
||||||
|
|
||||||
|
// 检查待办状态
|
||||||
|
if (xxts.dbZt === "B") {
|
||||||
|
setData({ id: xxts.xxzbId }); // 使用消息推送中的主表ID
|
||||||
|
let url = "/pages/view/hr/jsQj/detail";
|
||||||
|
uni.navigateTo({ url });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
setXxts(xxts);
|
||||||
|
|
||||||
|
// 根据主表ID去查询请假信息
|
||||||
|
const res = await findQjById({ id: xxts.xxzbId });
|
||||||
|
nextTick(() => {
|
||||||
|
setData(res.result);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("获取待办信息失败", error);
|
||||||
|
// 如果获取Xxts失败,回退到原来的逻辑
|
||||||
|
const xxtsData = getXxts();
|
||||||
|
if (xxtsData && xxtsData.dbZt === "B") {
|
||||||
|
setXxts(xxtsData);
|
||||||
|
let url = "/pages/view/hr/jsQj/detail";
|
||||||
uni.navigateTo({ url });
|
uni.navigateTo({ url });
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
@ -29,6 +56,7 @@ onLoad(async (data: any) => {
|
|||||||
nextTick(() => {
|
nextTick(() => {
|
||||||
setData(res.result);
|
setData(res.result);
|
||||||
});
|
});
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
dbFlag.value = false;
|
dbFlag.value = false;
|
||||||
}
|
}
|
||||||
|
|||||||
@ -89,6 +89,7 @@
|
|||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { jsQjDkQrApi } from "@/api/base/jsQjApi";
|
import { jsQjDkQrApi } from "@/api/base/jsQjApi";
|
||||||
|
import { xxtsFindByIdApi } from "@/api/base/server";
|
||||||
import { useDataStore } from "@/store/modules/data";
|
import { useDataStore } from "@/store/modules/data";
|
||||||
import { useUserStore } from "@/store/modules/user";
|
import { useUserStore } from "@/store/modules/user";
|
||||||
import { navigateBack } from "@/utils/uniapp";
|
import { navigateBack } from "@/utils/uniapp";
|
||||||
@ -96,7 +97,7 @@ import { onLoad } from "@dcloudio/uni-app";
|
|||||||
import { ref } from "vue";
|
import { ref } from "vue";
|
||||||
import JsQjDetail from "./components/jsQjDetail.vue";
|
import JsQjDetail from "./components/jsQjDetail.vue";
|
||||||
const { getJs } = useUserStore();
|
const { getJs } = useUserStore();
|
||||||
const { setData, getData, getDb } = useDataStore();
|
const { setData, getData, setXxts, getXxts } = useDataStore();
|
||||||
|
|
||||||
const dkList = ref<any>([]);
|
const dkList = ref<any>([]);
|
||||||
const qjData = ref<any>({});
|
const qjData = ref<any>({});
|
||||||
@ -125,10 +126,10 @@ const loadQjData = (data: any) => {
|
|||||||
};
|
};
|
||||||
const loadDkList = (data: any) => {
|
const loadDkList = (data: any) => {
|
||||||
// dbGlId是逗号分隔的字符串,需拆分为数组后判断
|
// dbGlId是逗号分隔的字符串,需拆分为数组后判断
|
||||||
if (!getDb.dbGlId) {
|
if (!getXxts.xxglId) {
|
||||||
getDb.dbGlId = "";
|
getXxts.xxglId = "";
|
||||||
}
|
}
|
||||||
const idArr = getDb.dbGlId.split(",");
|
const idArr = getXxts.xxglId.split(",");
|
||||||
dkList.value = [];
|
dkList.value = [];
|
||||||
data.map((dk: any) => {
|
data.map((dk: any) => {
|
||||||
if (idArr.includes(String(dk.id))) {
|
if (idArr.includes(String(dk.id))) {
|
||||||
@ -188,15 +189,40 @@ const handleReject = async () => {
|
|||||||
onLoad(async (data: any) => {
|
onLoad(async (data: any) => {
|
||||||
// 从待办过来的,需要从后端获取数据
|
// 从待办过来的,需要从后端获取数据
|
||||||
if (data && data.from && data.from == "db") {
|
if (data && data.from && data.from == "db") {
|
||||||
qjId.value = data.id;
|
|
||||||
dkId.value = data.dkId;
|
|
||||||
dbFlag.value = true;
|
dbFlag.value = true;
|
||||||
if (getDb.dbZt === "B") {
|
|
||||||
setData({ id: data.id });
|
try {
|
||||||
let url = "/pages/view/hr/jsQj/detail"; // 使用新路径
|
// 优先从后端根据url中的id去查询Xxts
|
||||||
|
const xxtsRes = await xxtsFindByIdApi({ id: data.id });
|
||||||
|
if (xxtsRes && xxtsRes.result) {
|
||||||
|
const xxts = xxtsRes.result;
|
||||||
|
|
||||||
|
// 检查待办状态
|
||||||
|
if (xxts.dbZt === "B") {
|
||||||
|
setData({ id: xxts.xxzbId });
|
||||||
|
let url = "/pages/view/hr/jsQj/detail";
|
||||||
uni.navigateTo({ url });
|
uni.navigateTo({ url });
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
setXxts(xxts);
|
||||||
|
|
||||||
|
// 使用消息推送中的主表ID和关联表ID
|
||||||
|
qjId.value = xxts.xxzbId;
|
||||||
|
dkId.value = xxts.xxglId;
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("获取待办信息失败", error);
|
||||||
|
// 如果获取Xxts失败,回退到原来的逻辑
|
||||||
|
qjId.value = data.id;
|
||||||
|
dkId.value = data.dkId;
|
||||||
|
const xxtsData = getXxts();
|
||||||
|
if (xxtsData && xxtsData.dbZt === "B") {
|
||||||
|
setData({ id: data.id });
|
||||||
|
let url = "/pages/view/hr/jsQj/detail";
|
||||||
|
uni.navigateTo({ url });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
qjId.value = getData.id;
|
qjId.value = getData.id;
|
||||||
dbFlag.value = false;
|
dbFlag.value = false;
|
||||||
|
|||||||
@ -69,6 +69,7 @@
|
|||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { jsQjJwcQrApi, jsQjZbApi } from "@/api/base/jsQjApi";
|
import { jsQjJwcQrApi, jsQjZbApi } from "@/api/base/jsQjApi";
|
||||||
|
import { xxtsFindByIdApi } from "@/api/base/server";
|
||||||
import JsPicker from "@/pages/components/JsPicker/index.vue";
|
import JsPicker from "@/pages/components/JsPicker/index.vue";
|
||||||
import { useDataStore } from "@/store/modules/data";
|
import { useDataStore } from "@/store/modules/data";
|
||||||
import { useUserStore } from "@/store/modules/user";
|
import { useUserStore } from "@/store/modules/user";
|
||||||
@ -77,7 +78,7 @@ import { onLoad } from "@dcloudio/uni-app";
|
|||||||
import { ref } from "vue";
|
import { ref } from "vue";
|
||||||
import JsQjDetail from "./components/jsQjDetail.vue";
|
import JsQjDetail from "./components/jsQjDetail.vue";
|
||||||
const { getJs } = useUserStore();
|
const { getJs } = useUserStore();
|
||||||
const { setData, getData, getDb } = useDataStore();
|
const { setData, getData, setXxts, getXxts } = useDataStore();
|
||||||
|
|
||||||
const dbFlag = ref(false);
|
const dbFlag = ref(false);
|
||||||
|
|
||||||
@ -161,7 +162,7 @@ const handleTransfer = async () => {
|
|||||||
const params: any = {
|
const params: any = {
|
||||||
qjId: qjId.value,
|
qjId: qjId.value,
|
||||||
jsId: getJs.id,
|
jsId: getJs.id,
|
||||||
dbId: getDb.id,
|
dbId: getXxts.id,
|
||||||
zbJsId: zbJs.value.value,
|
zbJsId: zbJs.value.value,
|
||||||
zbJsxm: zbJs.value.label,
|
zbJsxm: zbJs.value.label,
|
||||||
};
|
};
|
||||||
@ -182,14 +183,38 @@ const handleTransfer = async () => {
|
|||||||
onLoad(async (data: any) => {
|
onLoad(async (data: any) => {
|
||||||
// 从待办过来的,需要从后端获取数据
|
// 从待办过来的,需要从后端获取数据
|
||||||
if (data && data.from && data.from == "db") {
|
if (data && data.from && data.from == "db") {
|
||||||
qjId.value = data.id;
|
|
||||||
dbFlag.value = true;
|
dbFlag.value = true;
|
||||||
if (getDb.dbZt === "B") {
|
|
||||||
setData({ id: data.id });
|
try {
|
||||||
let url = "/pages/view/hr/jsQj/detail"; // 使用新路径
|
// 优先从后端根据url中的id去查询Xxts
|
||||||
|
const xxtsRes = await xxtsFindByIdApi({ id: data.id });
|
||||||
|
if (xxtsRes && xxtsRes.result) {
|
||||||
|
const xxts = xxtsRes.result;
|
||||||
|
|
||||||
|
// 检查待办状态
|
||||||
|
if (xxts.dbZt === "B") {
|
||||||
|
setData({ id: xxts.xxzbId });
|
||||||
|
let url = "/pages/view/hr/jsQj/detail";
|
||||||
uni.navigateTo({ url });
|
uni.navigateTo({ url });
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
setXxts(xxts);
|
||||||
|
|
||||||
|
// 使用消息推送中的主表ID
|
||||||
|
qjId.value = xxts.xxzbId;
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("获取待办信息失败", error);
|
||||||
|
// 如果获取Xxts失败,回退到原来的逻辑
|
||||||
|
qjId.value = data.id;
|
||||||
|
const xxtsData = getXxts();
|
||||||
|
if (xxtsData && xxtsData.dbZt === "B") {
|
||||||
|
setData({ id: data.id });
|
||||||
|
let url = "/pages/view/hr/jsQj/detail";
|
||||||
|
uni.navigateTo({ url });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
qjId.value = getData.id;
|
qjId.value = getData.id;
|
||||||
dbFlag.value = false;
|
dbFlag.value = false;
|
||||||
|
|||||||
@ -48,15 +48,16 @@
|
|||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { jsQjJwcXtApi } from "@/api/base/jsQjApi";
|
import { jsQjJwcXtApi } from "@/api/base/jsQjApi";
|
||||||
|
import { xxtsFindByIdApi } from "@/api/base/server";
|
||||||
import { useDataStore } from "@/store/modules/data";
|
import { useDataStore } from "@/store/modules/data";
|
||||||
import { useUserStore } from "@/store/modules/user";
|
import { useUserStore } from "@/store/modules/user";
|
||||||
import { navigateBack, showToast } from "@/utils/uniapp";
|
import { navigateBack, showToast } from "@/utils/uniapp";
|
||||||
import { onLoad } from "@dcloudio/uni-app";
|
import { onLoad } from "@dcloudio/uni-app";
|
||||||
import { ref } from "vue";
|
import { ref, nextTick } from "vue";
|
||||||
import JsQjDetail from "./components/jsQjDetail.vue";
|
import JsQjDetail from "./components/jsQjDetail.vue";
|
||||||
import JsQjDkEdit from "./components/jsQjDkEdit.vue";
|
import JsQjDkEdit from "./components/jsQjDkEdit.vue";
|
||||||
const { getJs } = useUserStore();
|
const { getJs } = useUserStore();
|
||||||
const { setData, getData, getDb } = useDataStore();
|
const { setData, getData, setXxts, getXxts } = useDataStore();
|
||||||
|
|
||||||
const dkRef = ref<any>(null);
|
const dkRef = ref<any>(null);
|
||||||
|
|
||||||
@ -129,14 +130,38 @@ const submit = async () => {
|
|||||||
onLoad(async (data: any) => {
|
onLoad(async (data: any) => {
|
||||||
// 从待办过来的,需要从后端获取数据
|
// 从待办过来的,需要从后端获取数据
|
||||||
if (data && data.from && data.from == "db") {
|
if (data && data.from && data.from == "db") {
|
||||||
qjId.value = data.id;
|
|
||||||
dbFlag.value = true;
|
dbFlag.value = true;
|
||||||
if (getDb.dbZt === "B") {
|
|
||||||
setData({ id: data.id });
|
try {
|
||||||
let url = "/pages/view/hr/jsQj/detail"; // 使用新路径
|
// 优先从后端根据url中的id去查询Xxts
|
||||||
|
const xxtsRes = await xxtsFindByIdApi({ id: data.id });
|
||||||
|
if (xxtsRes && xxtsRes.result) {
|
||||||
|
const xxts = xxtsRes.result;
|
||||||
|
|
||||||
|
// 检查待办状态
|
||||||
|
if (xxts.dbZt === "B") {
|
||||||
|
setData({ id: xxts.xxzbId });
|
||||||
|
let url = "/pages/view/hr/jsQj/detail";
|
||||||
uni.navigateTo({ url });
|
uni.navigateTo({ url });
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
setXxts(xxts);
|
||||||
|
|
||||||
|
// 使用消息推送中的主表ID
|
||||||
|
qjId.value = xxts.xxzbId;
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("获取待办信息失败", error);
|
||||||
|
// 如果获取Xxts失败,回退到原来的逻辑
|
||||||
|
qjId.value = data.id;
|
||||||
|
const xxtsData = getXxts();
|
||||||
|
if (xxtsData && xxtsData.dbZt === "B") {
|
||||||
|
setData({ id: data.id });
|
||||||
|
let url = "/pages/view/hr/jsQj/detail";
|
||||||
|
uni.navigateTo({ url });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
qjId.value = getData.id;
|
qjId.value = getData.id;
|
||||||
dbFlag.value = false;
|
dbFlag.value = false;
|
||||||
|
|||||||
@ -47,6 +47,7 @@
|
|||||||
|
|
||||||
<script setup lang="ts">
|
<script setup lang="ts">
|
||||||
import { jsQjSpApi } from "@/api/base/jsQjApi";
|
import { jsQjSpApi } from "@/api/base/jsQjApi";
|
||||||
|
import { xxtsFindByIdApi } from "@/api/base/server";
|
||||||
import { useDataStore } from "@/store/modules/data";
|
import { useDataStore } from "@/store/modules/data";
|
||||||
import { useUserStore } from "@/store/modules/user";
|
import { useUserStore } from "@/store/modules/user";
|
||||||
import { navigateBack } from "@/utils/uniapp";
|
import { navigateBack } from "@/utils/uniapp";
|
||||||
@ -54,7 +55,7 @@ import { onLoad } from "@dcloudio/uni-app";
|
|||||||
import { ref } from "vue";
|
import { ref } from "vue";
|
||||||
import JsQjDetail from "./components/jsQjDetail.vue";
|
import JsQjDetail from "./components/jsQjDetail.vue";
|
||||||
const { getJs } = useUserStore();
|
const { getJs } = useUserStore();
|
||||||
const { setData, getData, getDb } = useDataStore();
|
const { setData, getData, setXxts, getXxts } = useDataStore();
|
||||||
|
|
||||||
const dbFlag = ref(false);
|
const dbFlag = ref(false);
|
||||||
|
|
||||||
@ -113,14 +114,38 @@ const handleReject = async () => {
|
|||||||
onLoad(async (data: any) => {
|
onLoad(async (data: any) => {
|
||||||
// 从待办过来的,需要从后端获取数据
|
// 从待办过来的,需要从后端获取数据
|
||||||
if (data && data.from && data.from == "db") {
|
if (data && data.from && data.from == "db") {
|
||||||
qjId.value = data.id;
|
|
||||||
dbFlag.value = true;
|
dbFlag.value = true;
|
||||||
if (getDb.dbZt === "B") {
|
|
||||||
setData({ id: data.id });
|
try {
|
||||||
let url = "/pages/view/hr/jsQj/detail"; // 使用新路径
|
// 优先从后端根据url中的id去查询Xxts
|
||||||
|
const xxtsRes = await xxtsFindByIdApi({ id: data.id });
|
||||||
|
if (xxtsRes && xxtsRes.result) {
|
||||||
|
const xxts = xxtsRes.result;
|
||||||
|
|
||||||
|
// 检查待办状态
|
||||||
|
if (xxts.dbZt === "B") {
|
||||||
|
setData({ id: xxts.xxzbId });
|
||||||
|
let url = "/pages/view/hr/jsQj/detail";
|
||||||
uni.navigateTo({ url });
|
uni.navigateTo({ url });
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
setXxts(xxts);
|
||||||
|
|
||||||
|
// 使用消息推送中的主表ID
|
||||||
|
qjId.value = xxts.xxzbId;
|
||||||
|
}
|
||||||
|
} catch (error) {
|
||||||
|
console.error("获取待办信息失败", error);
|
||||||
|
// 如果获取Xxts失败,回退到原来的逻辑
|
||||||
|
qjId.value = data.id;
|
||||||
|
const xxtsData = getXxts();
|
||||||
|
if (xxtsData && xxtsData.dbZt === "B") {
|
||||||
|
setData({ id: data.id });
|
||||||
|
let url = "/pages/view/hr/jsQj/detail";
|
||||||
|
uni.navigateTo({ url });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
qjId.value = getData.id;
|
qjId.value = getData.id;
|
||||||
dbFlag.value = false;
|
dbFlag.value = false;
|
||||||
|
|||||||
@ -5,6 +5,7 @@ export const useDataStore = defineStore({
|
|||||||
state: () => ({
|
state: () => ({
|
||||||
data: {},
|
data: {},
|
||||||
db: {},
|
db: {},
|
||||||
|
xxts: {}, // 添加xxts字段
|
||||||
global: {},
|
global: {},
|
||||||
file: {},
|
file: {},
|
||||||
}),
|
}),
|
||||||
@ -15,6 +16,9 @@ export const useDataStore = defineStore({
|
|||||||
getDb(): any {
|
getDb(): any {
|
||||||
return this.db;
|
return this.db;
|
||||||
},
|
},
|
||||||
|
getXxts(): any {
|
||||||
|
return this.xxts;
|
||||||
|
},
|
||||||
getGlobal(): any {
|
getGlobal(): any {
|
||||||
return this.global;
|
return this.global;
|
||||||
},
|
},
|
||||||
@ -29,6 +33,9 @@ export const useDataStore = defineStore({
|
|||||||
setDb(data: any) {
|
setDb(data: any) {
|
||||||
this.db = data;
|
this.db = data;
|
||||||
},
|
},
|
||||||
|
setXxts(data: any) {
|
||||||
|
this.xxts = data;
|
||||||
|
},
|
||||||
setGlobal(data: any) {
|
setGlobal(data: any) {
|
||||||
this.global = data;
|
this.global = data;
|
||||||
},
|
},
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user