Files
ccdi/ruoyi-ui/src/views/ccdiProject/components/detail/PreliminaryCheck.vue

213 lines
6.1 KiB
Vue
Raw Normal View History

<template>
<div class="preliminary-check-container">
2026-03-19 10:35:40 +08:00
<div v-if="pageState === 'loading'" class="preliminary-check-state">
2026-03-19 10:39:24 +08:00
<div class="state-card">
<el-skeleton animated :rows="6" />
</div>
2026-03-19 10:35:40 +08:00
</div>
<div v-else-if="pageState === 'empty'" class="preliminary-check-state">
2026-03-19 10:39:24 +08:00
<div class="state-card">
<el-empty description="暂无结果总览数据" />
</div>
2026-03-19 10:35:40 +08:00
</div>
<div v-else class="preliminary-check-page">
2026-03-19 10:39:24 +08:00
<overview-stats :summary="currentData.summary" />
<risk-people-section
:section-data="currentData.riskPeople"
:selected-model-codes="selectedModelCodes"
@view-project-analysis="handleRiskPeopleProjectAnalysis"
/>
<risk-model-section
:section-data="currentData.riskModels"
@selection-change="handleRiskModelSelectionChange"
@view-project-analysis="handleRiskModelProjectAnalysis"
/>
2026-03-19 10:39:24 +08:00
<risk-detail-section :section-data="currentData.riskDetails" />
</div>
<project-analysis-dialog
:visible.sync="projectAnalysisDialogVisible"
:person="currentProjectAnalysisPerson"
:source="projectAnalysisSource"
:project-name="projectInfo.projectName"
@close="handleProjectAnalysisDialogClose"
/>
</div>
</template>
<script>
2026-03-19 15:40:43 +08:00
import {
createOverviewLoadedData,
mockOverviewData,
mockOverviewStateData,
} from "./preliminaryCheck.mock";
import {
getOverviewDashboard,
getOverviewRiskPeople,
getOverviewRiskModelCards,
2026-03-19 15:40:43 +08:00
} from "@/api/ccdi/projectOverview";
import OverviewStats from "./OverviewStats";
import RiskPeopleSection from "./RiskPeopleSection";
import RiskModelSection from "./RiskModelSection";
import RiskDetailSection from "./RiskDetailSection";
import ProjectAnalysisDialog from "./ProjectAnalysisDialog";
2026-03-19 10:35:40 +08:00
export default {
name: "PreliminaryCheck",
2026-03-19 10:35:40 +08:00
components: {
OverviewStats,
RiskPeopleSection,
RiskModelSection,
RiskDetailSection,
ProjectAnalysisDialog,
2026-03-19 10:35:40 +08:00
},
props: {
projectId: {
type: [String, Number],
default: null,
},
projectInfo: {
type: Object,
default: () => ({
projectName: "",
updateTime: "",
projectStatus: "0",
}),
},
},
2026-03-19 10:35:40 +08:00
data() {
return {
2026-03-19 15:40:43 +08:00
pageState: "loading",
selectedModelCodes: [],
2026-03-19 10:35:40 +08:00
mockData: mockOverviewData,
2026-03-19 10:39:24 +08:00
stateDataMap: mockOverviewStateData,
2026-03-19 15:40:43 +08:00
realData: mockOverviewData,
projectAnalysisDialogVisible: false,
currentProjectAnalysisPerson: null,
projectAnalysisSource: "riskPeople",
2026-03-19 10:35:40 +08:00
};
},
2026-03-19 10:39:24 +08:00
computed: {
currentData() {
2026-03-19 15:40:43 +08:00
if (this.pageState === "loaded") {
return this.realData;
}
return this.stateDataMap[this.pageState] || this.realData;
},
},
watch: {
projectId(newVal) {
if (newVal) {
this.loadOverviewData();
return;
}
this.realData = this.stateDataMap.empty;
this.pageState = "empty";
this.selectedModelCodes = [];
this.resetProjectAnalysisDialog();
2026-03-19 15:40:43 +08:00
},
},
created() {
if (this.projectId) {
this.loadOverviewData();
return;
}
this.realData = this.stateDataMap.empty;
this.pageState = "empty";
this.resetProjectAnalysisDialog();
2026-03-19 15:40:43 +08:00
},
methods: {
handleRiskModelSelectionChange(modelCodes) {
this.selectedModelCodes = Array.isArray(modelCodes) ? [...modelCodes] : [];
},
handleRiskPeopleProjectAnalysis(row) {
this.openProjectAnalysisDialog("riskPeople", row);
},
handleRiskModelProjectAnalysis(row) {
this.openProjectAnalysisDialog("riskModelPeople", row);
},
openProjectAnalysisDialog(source, person) {
this.projectAnalysisSource = source || "riskPeople";
this.currentProjectAnalysisPerson = person || null;
this.projectAnalysisDialogVisible = true;
},
handleProjectAnalysisDialogClose() {
this.projectAnalysisDialogVisible = false;
this.resetProjectAnalysisDialog();
},
resetProjectAnalysisDialog() {
this.projectAnalysisDialogVisible = false;
this.currentProjectAnalysisPerson = null;
this.projectAnalysisSource = "riskPeople";
},
2026-03-19 15:40:43 +08:00
async loadOverviewData() {
if (!this.projectId) {
this.realData = this.stateDataMap.empty;
this.pageState = "empty";
this.selectedModelCodes = [];
this.resetProjectAnalysisDialog();
2026-03-19 15:40:43 +08:00
return;
}
this.pageState = "loading";
this.selectedModelCodes = [];
this.resetProjectAnalysisDialog();
2026-03-19 15:40:43 +08:00
try {
const [dashboardRes, riskPeopleRes, riskModelCardsRes] = await Promise.all([
2026-03-19 15:40:43 +08:00
getOverviewDashboard(this.projectId),
getOverviewRiskPeople(this.projectId),
getOverviewRiskModelCards(this.projectId),
2026-03-19 15:40:43 +08:00
]);
const dashboardData = (dashboardRes && dashboardRes.data) || {};
const riskPeopleData = (riskPeopleRes && riskPeopleRes.data) || {};
const riskModelCardsData = (riskModelCardsRes && riskModelCardsRes.data) || {};
2026-03-19 15:40:43 +08:00
this.realData = createOverviewLoadedData({
projectId: this.projectId,
2026-03-19 15:40:43 +08:00
dashboardData,
riskPeopleData,
riskModelCardsData,
2026-03-19 15:40:43 +08:00
});
const hasOverviewData = Boolean(
(Array.isArray(dashboardData.stats) && dashboardData.stats.length) ||
(Array.isArray(riskPeopleData.overviewList) && riskPeopleData.overviewList.length) ||
(Array.isArray(riskModelCardsData.cardList) && riskModelCardsData.cardList.length)
2026-03-19 15:40:43 +08:00
);
this.pageState = hasOverviewData ? "loaded" : "empty";
} catch (error) {
this.realData = this.stateDataMap.empty;
this.pageState = "empty";
this.selectedModelCodes = [];
this.resetProjectAnalysisDialog();
2026-03-19 15:40:43 +08:00
console.error("加载结果总览失败", error);
}
2026-03-19 10:39:24 +08:00
},
},
};
</script>
<style lang="scss" scoped>
.preliminary-check-container {
min-height: 400px;
padding: 0 0 24px;
}
2026-03-19 10:35:40 +08:00
.preliminary-check-state {
2026-03-19 10:39:24 +08:00
min-height: 400px;
}
.state-card {
padding: 32px 24px;
border-radius: 0;
2026-03-19 10:35:40 +08:00
background: #fff;
2026-03-19 10:39:24 +08:00
box-shadow: 0 8px 24px rgba(15, 23, 42, 0.06);
2026-03-19 10:35:40 +08:00
}
2026-03-19 10:35:40 +08:00
.preliminary-check-page {
min-height: 400px;
}
</style>