fix(hub): align trend pullback card with instance layout

Match strategy page plan card: 3x3 metrics, DCA table, breakeven row, snapshot footer; PnL percent on plan margin.

Co-authored-by: Cursor <cursoragent@cursor.com>
This commit is contained in:
dekun
2026-06-04 10:51:13 +08:00
parent 3fb2023efb
commit 7037dc2334
3 changed files with 314 additions and 142 deletions
+164 -81
View File
@@ -1320,139 +1320,222 @@ body.market-chart-fs-open {
border-color: rgba(0, 255, 157, 0.38);
}
.hub-trend-plan-list {
/* 趋势回调:与四所实例 strategy_trend_panel 同款卡片 */
.hub-trend-running-title {
margin: 0 0 10px;
font-size: 0.95rem;
color: #b8c4ff;
font-weight: 600;
}
.hub-trend-plan-list.running-plans-stack {
display: flex;
flex-direction: column;
gap: 12px;
}
.hub-trend-plan-card {
.hub-trend-plan-card.plan-position-card {
background: #141a2a;
border: 1px solid #2a3150;
border-radius: 12px;
padding: 12px 14px;
background: rgba(0, 0, 0, 0.28);
border: 1px solid var(--border-soft);
border-radius: 10px;
}
.hub-trend-plan-head {
.hub-trend-plan-card .plan-card-head {
display: flex;
align-items: center;
align-items: flex-start;
justify-content: space-between;
gap: 8px;
gap: 10px;
flex-wrap: wrap;
margin-bottom: 8px;
}
.hub-trend-plan-title {
font-size: 14px;
font-weight: 600;
}
.hub-trend-plan-status {
font-size: 11px;
color: var(--muted);
}
.hub-trend-plan-meta {
.hub-trend-plan-card .plan-card-title {
display: flex;
align-items: center;
gap: 8px;
flex-wrap: wrap;
gap: 8px 14px;
font-size: 12px;
color: var(--muted);
font-size: 1rem;
font-weight: 700;
color: #f0f2ff;
}
.hub-trend-plan-card .plan-card-meta {
font-size: 0.76rem;
color: #8892b0;
line-height: 1.55;
margin-bottom: 10px;
}
.hub-trend-plan-meta .pos-meta-accent,
.hub-trend-plan-meta strong {
.hub-trend-plan-card .plan-card-meta .accent {
color: #6ab8ff;
}
.hub-trend-plan-card .plan-card-meta strong {
color: var(--accent);
}
.hub-trend-plan-foot {
margin-top: 10px;
font-size: 11px;
color: var(--muted);
.hub-trend-plan-card .plan-card-grid {
display: grid;
grid-template-columns: repeat(3, minmax(0, 1fr));
gap: 10px 14px;
margin-bottom: 10px;
}
.pos-value.pos-tp-program {
color: #8fc8ff;
}
.hub-trend-plan-card--horizontal {
.hub-trend-plan-card .plan-cell {
display: flex;
flex-wrap: wrap;
gap: 14px 18px;
align-items: flex-start;
background: linear-gradient(145deg, rgba(12, 18, 32, 0.92), rgba(8, 12, 22, 0.88));
border-color: rgba(0, 212, 255, 0.22);
box-shadow: 0 4px 18px rgba(0, 0, 0, 0.35);
flex-direction: column;
gap: 3px;
}
.hub-trend-plan-body {
flex: 1 1 320px;
min-width: 0;
.hub-trend-plan-card .plan-cell .lbl {
font-size: 0.72rem;
color: #8b95b8;
}
.hub-trend-plan-side {
flex: 1 1 220px;
min-width: 200px;
max-width: 100%;
.hub-trend-plan-card .plan-cell .val {
color: #f0f2ff;
font-size: 0.88rem;
font-weight: 500;
}
.hub-trend-dca-block {
padding: 8px 10px;
background: rgba(0, 0, 0, 0.22);
border: 1px solid var(--border-soft);
.hub-trend-plan-card .plan-cell .val.pnl-profit {
color: #4cd97f;
}
.hub-trend-plan-card .plan-cell .val.pnl-loss {
color: #ff6666;
}
.hub-trend-plan-card .plan-cell .val.pnl-neutral {
color: #cfd3ef;
}
.hub-trend-plan-card .btn-close-plan {
padding: 7px 14px;
background: #5c1e2a;
color: #ffb4b4;
border: none;
border-radius: 8px;
cursor: pointer;
font-size: 0.82rem;
font-weight: 600;
text-decoration: none;
white-space: nowrap;
display: inline-block;
}
.hub-trend-dca-title {
font-size: 11px;
color: var(--muted);
margin-bottom: 6px;
.hub-trend-plan-card .btn-close-plan:hover {
filter: brightness(1.08);
}
.hub-trend-dca-table {
.hub-trend-plan-card .plan-dca-block {
margin-top: 12px;
padding-top: 10px;
border-top: 1px dashed #2a3558;
}
.hub-trend-plan-card .plan-dca-title {
font-size: 0.74rem;
color: #8b95b8;
margin-bottom: 8px;
}
.hub-trend-plan-card .plan-dca-table {
width: 100%;
border-collapse: collapse;
font-size: 11px;
font-size: 0.76rem;
}
.hub-trend-dca-table th,
.hub-trend-dca-table td {
padding: 4px 6px;
border-bottom: 1px solid rgba(255, 255, 255, 0.06);
.hub-trend-plan-card .plan-dca-table th,
.hub-trend-plan-card .plan-dca-table td {
padding: 6px 8px;
border-bottom: 1px solid #243050;
text-align: left;
}
.hub-trend-dca-table th {
color: var(--muted);
.hub-trend-plan-card .plan-dca-table th {
color: #6a7598;
font-weight: 600;
}
.hub-trend-dca-table .dca-done {
color: var(--green);
.hub-trend-plan-card .plan-dca-table .st-done {
color: #4cd97f;
}
.hub-trend-dca-table .dca-pending {
color: var(--muted);
.hub-trend-plan-card .plan-dca-table .st-pending {
color: #9aa3c4;
}
.exchange-fullscreen .hub-trend-plan-list {
display: block;
.hub-trend-plan-card .hub-plan-breakeven-row {
display: flex;
flex-wrap: wrap;
align-items: center;
gap: 8px 12px;
margin-top: 8px;
}
.hub-trend-plan-card .hub-plan-be-label {
font-size: 0.78rem;
color: #cfd3ef;
display: flex;
align-items: center;
gap: 6px;
}
.hub-trend-plan-card .hub-plan-be-input {
width: 72px;
padding: 4px 8px;
border-radius: 6px;
border: 1px solid #304164;
background: #0f1424;
color: #cfd3ef;
opacity: 0.85;
}
.hub-trend-plan-card .hub-plan-be-btn {
padding: 6px 12px;
background: #1f4a3a;
color: #8fc8ff;
border-radius: 8px;
font-size: 0.78rem;
text-decoration: none;
cursor: pointer;
white-space: nowrap;
}
.hub-trend-plan-card .hub-plan-be-btn--static {
cursor: default;
}
.hub-trend-plan-card .hub-plan-be-done {
color: #6ab88a;
font-size: 0.75rem;
}
.hub-trend-plan-card .hub-plan-account-foot {
margin-bottom: 0;
}
.hub-trend-plan-card .badge.direction-long {
color: #4cd97f;
border-color: rgba(76, 217, 127, 0.45);
}
.hub-trend-plan-card .badge.direction-short {
color: #ff6666;
border-color: rgba(255, 102, 102, 0.45);
}
.exchange-fullscreen .hub-trend-plan-card.plan-position-card {
width: 100%;
max-width: 100%;
}
.exchange-fullscreen .hub-trend-plan-card--horizontal {
width: 100%;
}
.exchange-fullscreen .hub-trend-plan-metrics-row {
display: flex;
flex-wrap: wrap;
align-items: flex-end;
gap: 10px 16px;
}
.exchange-fullscreen .hub-trend-plan-grid {
flex: 1 1 280px;
@media (max-width: 720px) {
.hub-trend-plan-card .plan-card-grid {
grid-template-columns: 1fr;
}
}
/* 顺势加仓 */