feat: 新增归档中心页面并完善知识库与报销查询能力
新增前端归档中心视图及相关工具函数,扩充知识库文档分类和 提取器支持多种格式,增强编排器报销查询的多维度检索,优 化本体规则和用户代理审核消息,前端完善报销创建和审批详 情交互细节,补充单元测试覆盖。
This commit is contained in:
54
web/src/assets/styles/views/archive-center-view.css
Normal file
54
web/src/assets/styles/views/archive-center-view.css
Normal file
@@ -0,0 +1,54 @@
|
||||
.archive-page .status-tag.archived {
|
||||
color: #0f766e;
|
||||
background: rgba(16, 185, 129, 0.12);
|
||||
border: 1px solid rgba(16, 185, 129, 0.22);
|
||||
}
|
||||
|
||||
.archive-page .risk-tag.none {
|
||||
background: #f1f5f9;
|
||||
color: #64748b;
|
||||
}
|
||||
|
||||
.archive-dropdown-filter {
|
||||
position: relative;
|
||||
}
|
||||
|
||||
.archive-dropdown-menu {
|
||||
position: absolute;
|
||||
top: calc(100% + 8px);
|
||||
left: 0;
|
||||
z-index: 12;
|
||||
min-width: 148px;
|
||||
max-height: 280px;
|
||||
padding: 6px;
|
||||
border: 1px solid #d7e0ea;
|
||||
border-radius: 10px;
|
||||
background: #fff;
|
||||
box-shadow: 0 16px 32px rgba(15, 23, 42, 0.12);
|
||||
overflow-y: auto;
|
||||
}
|
||||
|
||||
.archive-dropdown-option {
|
||||
display: block;
|
||||
width: 100%;
|
||||
min-height: 36px;
|
||||
padding: 0 12px;
|
||||
border: 0;
|
||||
border-radius: 8px;
|
||||
background: transparent;
|
||||
color: #334155;
|
||||
font-size: 13px;
|
||||
font-weight: 600;
|
||||
text-align: left;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.archive-dropdown-option:hover,
|
||||
.archive-dropdown-option.active {
|
||||
background: rgba(16, 185, 129, 0.1);
|
||||
color: #047857;
|
||||
}
|
||||
|
||||
.archive-page .hint {
|
||||
color: #475569;
|
||||
}
|
||||
@@ -1089,23 +1089,3 @@
|
||||
gap: 12px;
|
||||
flex-wrap: wrap;
|
||||
}
|
||||
|
||||
.review-upload-decision-modal {
|
||||
display: grid;
|
||||
gap: 18px;
|
||||
}
|
||||
|
||||
.review-upload-decision-copy {
|
||||
display: grid;
|
||||
gap: 10px;
|
||||
}
|
||||
|
||||
.review-upload-decision-actions {
|
||||
justify-content: stretch;
|
||||
}
|
||||
|
||||
.review-upload-decision-actions .primary-dialog-btn,
|
||||
.review-upload-decision-actions .secondary-dialog-btn {
|
||||
flex: 1 1 168px;
|
||||
}
|
||||
|
||||
|
||||
@@ -453,10 +453,6 @@
|
||||
justify-content: stretch;
|
||||
}
|
||||
|
||||
.review-upload-decision-actions {
|
||||
width: 100%;
|
||||
}
|
||||
|
||||
.primary-dialog-btn,
|
||||
.secondary-dialog-btn,
|
||||
.danger-dialog-btn {
|
||||
|
||||
@@ -740,6 +740,38 @@
|
||||
color: #475569;
|
||||
}
|
||||
|
||||
.message-answer-markdown :deep(.markdown-attachment-card) {
|
||||
margin: 10px 0 12px;
|
||||
padding: 12px 14px;
|
||||
border: 1px solid #dbe4ee;
|
||||
border-left: 4px solid #2563eb;
|
||||
border-radius: 8px;
|
||||
background: #f8fafc;
|
||||
color: #334155;
|
||||
}
|
||||
|
||||
.message-answer-markdown :deep(.markdown-attachment-card + .markdown-attachment-card) {
|
||||
margin-top: 12px;
|
||||
}
|
||||
|
||||
.message-answer-markdown :deep(.markdown-attachment-card p) {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.message-answer-markdown :deep(.markdown-attachment-card p:first-child) {
|
||||
color: #0f172a;
|
||||
font-weight: 820;
|
||||
}
|
||||
|
||||
.message-answer-markdown :deep(.markdown-attachment-card ul) {
|
||||
margin-top: 8px;
|
||||
padding-left: 18px;
|
||||
}
|
||||
|
||||
.message-answer-markdown :deep(.markdown-attachment-card li + li) {
|
||||
margin-top: 4px;
|
||||
}
|
||||
|
||||
.message-answer-markdown :deep(code) {
|
||||
padding: 2px 6px;
|
||||
border-radius: 6px;
|
||||
@@ -766,6 +798,22 @@
|
||||
text-decoration: underline;
|
||||
}
|
||||
|
||||
.message-answer-markdown :deep(.markdown-action-paragraph) {
|
||||
margin-top: 34px;
|
||||
color: #475569;
|
||||
}
|
||||
|
||||
.message-answer-markdown :deep(.markdown-action-link) {
|
||||
color: #2563eb;
|
||||
font-weight: 850;
|
||||
text-decoration-thickness: 1.5px;
|
||||
text-underline-offset: 3px;
|
||||
}
|
||||
|
||||
.message-answer-markdown :deep(.markdown-action-link:hover) {
|
||||
color: #1d4ed8;
|
||||
}
|
||||
|
||||
.message-answer-markdown :deep(.markdown-table-wrap) {
|
||||
width: 100%;
|
||||
max-width: 100%;
|
||||
@@ -1237,6 +1285,71 @@
|
||||
font-weight: 700;
|
||||
}
|
||||
|
||||
.expense-query-risk-row {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
gap: 6px;
|
||||
margin-top: 4px;
|
||||
}
|
||||
|
||||
.expense-query-risk-chip {
|
||||
max-width: 100%;
|
||||
min-height: 24px;
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
gap: 5px;
|
||||
padding: 0 8px;
|
||||
border: 1px solid #fecaca;
|
||||
border-radius: 999px;
|
||||
background: #fff7ed;
|
||||
color: #9a3412;
|
||||
font: inherit;
|
||||
font-size: 11px;
|
||||
cursor: pointer;
|
||||
}
|
||||
|
||||
.expense-query-risk-chip span,
|
||||
.expense-query-risk-chip em {
|
||||
overflow: hidden;
|
||||
text-overflow: ellipsis;
|
||||
white-space: nowrap;
|
||||
}
|
||||
|
||||
.expense-query-risk-chip span {
|
||||
max-width: 86px;
|
||||
color: #7c2d12;
|
||||
}
|
||||
|
||||
.expense-query-risk-chip strong {
|
||||
flex-shrink: 0;
|
||||
font-weight: 850;
|
||||
}
|
||||
|
||||
.expense-query-risk-chip em {
|
||||
max-width: 120px;
|
||||
font-style: normal;
|
||||
}
|
||||
|
||||
.expense-query-risk-chip.high {
|
||||
border-color: #fecaca;
|
||||
background: #fef2f2;
|
||||
color: #b91c1c;
|
||||
}
|
||||
|
||||
.expense-query-risk-chip.medium,
|
||||
.expense-query-risk-chip.warning {
|
||||
border-color: #fed7aa;
|
||||
background: #fff7ed;
|
||||
color: #c2410c;
|
||||
}
|
||||
|
||||
.expense-query-risk-chip.low,
|
||||
.expense-query-risk-chip.info {
|
||||
border-color: #bfdbfe;
|
||||
background: #eff6ff;
|
||||
color: #1d4ed8;
|
||||
}
|
||||
|
||||
.expense-query-pager {
|
||||
display: flex;
|
||||
align-items: center;
|
||||
@@ -1513,4 +1626,3 @@
|
||||
font-size: 13px;
|
||||
font-weight: 900;
|
||||
}
|
||||
|
||||
|
||||
@@ -606,54 +606,6 @@
|
||||
gap: 8px;
|
||||
}
|
||||
|
||||
.detail-note-tag-list,
|
||||
.risk-card-tag-list {
|
||||
display: flex;
|
||||
flex-wrap: wrap;
|
||||
gap: 6px;
|
||||
}
|
||||
|
||||
.risk-note-tag {
|
||||
display: inline-flex;
|
||||
align-items: center;
|
||||
min-height: 22px;
|
||||
padding: 0 8px;
|
||||
border-radius: 999px;
|
||||
font-size: 11px;
|
||||
font-weight: 850;
|
||||
line-height: 1;
|
||||
}
|
||||
|
||||
.risk-note-tag.high {
|
||||
background: #fef2f2;
|
||||
color: #dc2626;
|
||||
}
|
||||
|
||||
.risk-note-tag.medium {
|
||||
background: #fff7ed;
|
||||
color: #c2410c;
|
||||
}
|
||||
|
||||
.risk-note-tag.low {
|
||||
background: #eff6ff;
|
||||
color: #2563eb;
|
||||
}
|
||||
|
||||
.risk-note-tag.hotel {
|
||||
background: #fdf2f8;
|
||||
color: #be185d;
|
||||
}
|
||||
|
||||
.risk-note-tag.traffic {
|
||||
background: #ecfeff;
|
||||
color: #0e7490;
|
||||
}
|
||||
|
||||
.risk-note-tag.neutral {
|
||||
background: #f1f5f9;
|
||||
color: #475569;
|
||||
}
|
||||
|
||||
.leader-approval-card {
|
||||
border-color: rgba(5, 150, 105, .18);
|
||||
background: linear-gradient(180deg, #ffffff 0%, #f7fdfb 100%);
|
||||
|
||||
Reference in New Issue
Block a user