feat: 新增风险规则生成引擎与知识图谱可视化

后端新增风险规则自动生成和模板执行服务,支持从规则资产
批量生成并持久化风险规则文件;知识库入库日志增强图谱
查询和本地 RAG 回退,前端审计页面增加风险规则模型和流
程图组件,知识入库面板拆分为图谱可视化子组件,报销创
建页面增加引导式流程模型,更新知识库索引数据。
This commit is contained in:
caoxiaozhu
2026-05-23 19:54:42 +08:00
parent 5b388d08c0
commit 575f093c74
63 changed files with 35497 additions and 1517 deletions

View File

@@ -828,6 +828,64 @@
line-height: 1.55;
}
.shared-confirm-card:has(.risk-rule-create-form) {
width: min(680px, 100%);
}
.risk-rule-create-form {
display: grid;
grid-template-columns: repeat(2, minmax(0, 1fr));
gap: 12px;
}
.risk-rule-create-form label {
display: grid;
gap: 7px;
}
.risk-rule-create-form label.span-2 {
grid-column: 1 / -1;
}
.risk-rule-create-form label span {
color: #475569;
font-size: 12px;
font-weight: 850;
}
.risk-rule-create-form select,
.risk-rule-create-form textarea {
width: 100%;
border: 1px solid #cbd5e1;
border-radius: 10px;
background: #fff;
color: #0f172a;
font-size: 13px;
}
.risk-rule-create-form select {
min-height: 42px;
padding: 0 12px;
}
.risk-rule-create-form textarea {
min-height: 140px;
resize: vertical;
padding: 12px;
line-height: 1.6;
}
.risk-rule-create-form select:focus,
.risk-rule-create-form textarea:focus {
outline: 0;
border-color: rgba(16, 185, 129, 0.5);
box-shadow: 0 0 0 3px rgba(16, 185, 129, 0.12);
}
.risk-rule-create-form textarea::placeholder {
color: #94a3b8;
}
.publish-summary {
display: flex;
align-items: center;
@@ -1036,16 +1094,15 @@
transform: rotate(90deg);
}
.json-risk-summary-grid {
grid-template-columns: 1fr;
}
.field.span-2 {
grid-column: span 1;
}
}
.json-risk-skill-detail .detail-scroll {
display: grid;
grid-template-rows: auto minmax(0, 1fr);
}
.json-risk-editor-shell {
min-height: 0;
height: 100%;
@@ -1053,26 +1110,118 @@
flex-direction: column;
gap: 10px;
padding: 10px;
overflow: hidden;
}
.asset-detail-topbar {
display: flex;
align-items: center;
justify-content: space-between;
gap: 16px;
padding: 14px 0 10px;
border: 0;
border-radius: 0;
background: transparent;
box-shadow: none;
}
.asset-detail-topbar.panel {
padding: 14px 0 10px;
border: 0;
background: transparent;
box-shadow: none;
}
.asset-detail-topbar-main {
flex: 1 1 auto;
min-width: 0;
}
.asset-detail-topbar-main h2 {
margin: 0;
color: #0f172a;
font-size: 18px;
font-weight: 850;
line-height: 1.25;
}
.asset-detail-topbar-main p {
flex-basis: 100%;
margin: 0;
max-width: 860px;
color: #64748b;
font-size: 13px;
line-height: 1.5;
}
.asset-detail-topbar-meta {
flex: 0 0 auto;
justify-content: flex-end;
}
.asset-detail-topbar .hero-review-meta {
flex-basis: 100%;
margin-top: 2px;
}
.asset-detail-topbar .review-note-block {
flex-basis: 100%;
margin-top: 4px;
}
.asset-detail-topbar .hero-stats {
display: flex;
align-items: center;
flex-wrap: wrap;
}
.asset-detail-topbar .hero-stat {
min-height: 30px;
padding: 0 10px;
border-radius: 999px;
background: #f8fafc;
}
.asset-detail-topbar .hero-stat span {
display: none;
}
.asset-detail-topbar .hero-stat strong {
font-size: 12px;
font-weight: 800;
}
.json-risk-editor-head {
display: flex;
align-items: flex-start;
justify-content: space-between;
gap: 16px;
align-items: center;
padding-top: 4px;
padding-bottom: 8px;
}
.json-risk-editor-title {
min-width: 0;
display: flex;
align-items: flex-start;
align-items: center;
gap: 12px;
}
.json-risk-head-copy {
min-width: 0;
display: grid;
gap: 6px;
}
.json-risk-head-title-row {
min-width: 0;
display: flex;
align-items: center;
gap: 10px;
}
.json-risk-editor-title h2 {
color: #0f172a;
font-size: 18px;
font-weight: 850;
line-height: 1.25;
}
.json-risk-editor-title p {
@@ -1085,7 +1234,7 @@
.json-risk-head-subtitle {
display: -webkit-box;
margin: 6px 0 0;
margin: 0;
max-width: 760px;
overflow: hidden;
color: #64748b;
@@ -1095,11 +1244,24 @@
-webkit-line-clamp: 2;
}
.json-risk-head-category {
margin: 6px 0 0;
color: #be123c;
.json-risk-head-meta {
display: flex;
align-items: center;
gap: 8px;
flex-wrap: wrap;
}
.json-risk-head-meta span {
min-height: 24px;
display: inline-flex;
align-items: center;
padding: 0 8px;
border-radius: 999px;
background: #f8fafc;
color: #475569;
font-size: 12px;
font-weight: 600;
font-weight: 750;
border: 1px solid #e2e8f0;
}
.skill-name-cell .skill-list-subtitle {
@@ -1131,16 +1293,41 @@
font-weight: 800;
}
.json-risk-mode-pill.high {
background: #fef2f2;
color: #dc2626;
}
.json-risk-mode-pill.medium {
background: #fff7ed;
color: #ea580c;
}
.json-risk-mode-pill.low {
background: #ecfdf5;
color: #059669;
}
.json-risk-editor-body {
flex: 1 1 auto;
min-height: 0;
display: block;
overflow-y: auto;
overflow-x: hidden;
padding: 0 2px 2px 0;
}
.json-risk-main-stage {
min-width: 0;
min-height: 0;
display: grid;
gap: 12px;
padding-bottom: 2px;
}
.json-risk-flow-card {
min-width: 0;
overflow: hidden;
}
.json-risk-description-card {
@@ -1193,46 +1380,6 @@
letter-spacing: 0.04em;
}
.json-risk-flow-diagram {
display: grid;
grid-template-columns: minmax(0, 1fr) auto minmax(0, 1fr) auto minmax(0, 1fr);
gap: 10px;
align-items: center;
}
.json-risk-flow-column {
display: grid;
gap: 6px;
padding: 12px;
border-radius: 12px;
border: 1px solid #e2e8f0;
background: #f8fafc;
}
.json-risk-flow-column.center {
text-align: center;
background: #fff1f2;
border-color: #fecdd3;
}
.json-risk-flow-column code {
font-size: 11px;
color: #334155;
}
.json-risk-flow-label {
font-size: 11px;
font-weight: 800;
color: #64748b;
text-transform: uppercase;
}
.json-risk-flow-arrow {
color: #94a3b8;
font-size: 18px;
font-weight: 800;
}
.json-risk-editor-toolbar {
display: flex;
align-items: center;
@@ -1253,3 +1400,21 @@
border: 1px solid #e2e8f0;
background: #ffffff;
}
@media (max-width: 760px) {
.risk-rule-create-form,
.json-risk-summary-grid {
grid-template-columns: 1fr;
}
}
@media (max-width: 860px) {
.json-risk-editor-head {
flex-direction: column;
align-items: stretch;
}
.json-risk-editor-actions {
justify-content: flex-start;
}
}

View File

@@ -555,20 +555,33 @@ tbody tr:hover {
background: rgba(16, 185, 129, 0.08);
}
.detail-scroll {
height: 100%;
overflow: auto;
display: grid;
align-content: start;
gap: 16px;
}
.spreadsheet-skill-detail .detail-scroll {
min-height: 0;
overflow: hidden;
align-content: stretch;
grid-template-rows: minmax(0, 1fr);
}
.detail-scroll {
height: 100%;
overflow: auto;
display: grid;
align-content: start;
gap: 16px;
}
.spreadsheet-skill-detail .detail-scroll {
min-height: 0;
overflow: hidden;
align-content: stretch;
grid-template-rows: minmax(0, 1fr);
}
.json-risk-skill-detail .detail-scroll {
min-height: 0;
overflow: hidden;
align-content: stretch;
grid-template-rows: minmax(0, 1fr);
}
.detail-loading-state {
width: 100%;
min-height: 260px;
align-self: center;
}
.detail-hero {
display: grid;

View File

@@ -687,6 +687,13 @@
z-index: 1;
}
.insight-body.document-review-body {
display: flex;
flex-direction: column;
align-content: stretch;
overflow: hidden;
}
.review-side-card {
display: grid;
gap: 10px;
@@ -1186,6 +1193,10 @@
.review-ticket-drawer {
min-height: 0;
grid-template-rows: auto minmax(0, 1fr);
height: 100%;
flex: 1 1 auto;
overflow: hidden;
}
.review-document-switch-head {
@@ -1226,6 +1237,7 @@
.review-document-stage {
display: grid;
grid-template-rows: auto auto minmax(0, 1fr);
gap: 12px;
min-height: 0;
}
@@ -1292,7 +1304,8 @@
.review-document-scroll {
display: grid;
gap: 12px;
max-height: 430px;
max-height: none;
min-height: 0;
overflow-y: auto;
padding-right: 4px;
}
@@ -1320,8 +1333,15 @@
.review-document-preview-card.image img {
display: block;
width: 100%;
height: 188px;
object-fit: cover;
height: auto;
max-height: 260px;
object-fit: contain;
}
.review-document-preview-card.image {
display: grid;
place-items: center;
min-height: 220px;
}
.review-document-preview-placeholder {