diff --git a/apps/admin/src/App.vue b/apps/admin/src/App.vue index 625b410..120af2c 100644 --- a/apps/admin/src/App.vue +++ b/apps/admin/src/App.vue @@ -28,63 +28,88 @@ a { color: inherit; text-decoration: none; } button { cursor: pointer; font-family: inherit; } :root { - /* 质感绿:深底 + 渐变高光,避免扁平荧光绿 */ - --green-deep: #145c38; - --green-mid: #1f8a52; - --green-bright: #2fb56a; - --green-glow: #4dd68a; - --green-surface: rgba(20, 72, 46, 0.45); - --green-border: rgba(77, 214, 138, 0.28); - --green-text: #9ae8bc; - --primary: var(--green-mid); - --primary-dark: var(--green-deep); - --primary-light: var(--green-bright); - --primary-link: var(--green-text); - --primary-on: #ffffff; - --primary-grad: linear-gradient(165deg, #3cc474 0%, #248f54 42%, #1a6b40 100%); - --primary-grad-hover: linear-gradient(165deg, #4dd68a 0%, #2ea864 42%, #1f7a48 100%); - --primary-shadow: 0 1px 0 rgba(255, 255, 255, 0.14) inset, 0 2px 10px rgba(0, 0, 0, 0.45), 0 0 20px rgba(36, 143, 84, 0.18); - --bg-body: #000000; - --bg-card: rgba(20, 20, 20, 0.85); - --bg-elevated: rgba(28, 28, 28, 0.9); - --bg-hover: rgba(36, 143, 84, 0.1); - --text: #ffffff; - --text-muted: #8e8e93; - --border: #2a2a2a; - --border-soft: var(--green-border); - --radius: 12px; - --radius-sm: 8px; - --shadow: 0 4px 20px rgba(0, 0, 0, 0.55); + /* Monochrome admin — 克制、无渐变、无品牌色泛滥 */ + --accent: #f5f5f5; + --accent-muted: #a3a3a3; + --accent-dim: #737373; + --accent-subtle: rgba(255, 255, 255, 0.06); + --accent-border: rgba(255, 255, 255, 0.1); + --accent-hover: rgba(255, 255, 255, 0.04); + --accent-focus: rgba(255, 255, 255, 0.14); + /* 语义色:仅 success/warning/danger 场景使用 */ + --success-text: #7d9b8a; + --success-bg: rgba(255, 255, 255, 0.04); + --success-border: rgba(255, 255, 255, 0.08); + /* 兼容旧变量名 → 中性灰白 */ + --gold-deep: var(--accent-dim); + --gold-mid: var(--accent); + --gold-bright: var(--accent); + --gold-glow: var(--accent); + --gold-surface: var(--accent-subtle); + --gold-border: var(--accent-border); + --gold-text: var(--accent-muted); + --green-deep: var(--accent-dim); + --green-mid: var(--accent); + --green-bright: var(--accent); + --green-glow: var(--accent); + --green-surface: var(--accent-subtle); + --green-border: var(--accent-border); + --green-text: var(--accent-muted); + --primary: var(--accent); + --primary-dark: #e5e5e5; + --primary-light: #ffffff; + --primary-link: var(--accent-muted); + --primary-on: #0a0a0a; + --primary-grad: var(--accent); + --primary-grad-hover: #ffffff; + --primary-shadow: none; + --bg-body: #0a0a0a; + --bg-card: #111111; + --bg-elevated: #161616; + --bg-hover: var(--accent-hover); + --text: #f5f5f5; + --text-muted: #737373; + --border: rgba(255, 255, 255, 0.08); + --border-soft: var(--accent-border); + --radius: 8px; + --radius-sm: 6px; + --shadow: none; /* Element Plus dark overrides */ - --el-bg-color: #141414; - --el-bg-color-page: #000000; - --el-bg-color-overlay: #1c1c1c; - --el-text-color-primary: #ffffff; - --el-text-color-regular: #cccccc; - --el-text-color-secondary: #8e8e93; - --el-text-color-placeholder:#4a4a4a; - --el-border-color: #2a2a2a; - --el-border-color-light: #222; - --el-border-color-lighter: #1a1a1a; - --el-fill-color: #1a1a1a; - --el-fill-color-blank: #0d0d0d; - --el-fill-color-light: #141414; - --el-color-primary: #248f54; - --el-color-primary-light-3: rgba(47, 181, 106, 0.35); - --el-color-primary-light-5: rgba(47, 181, 106, 0.2); - --el-color-primary-light-7: rgba(47, 181, 106, 0.12); - --el-color-primary-light-9: rgba(47, 181, 106, 0.06); - --el-color-primary-dark-2: #1a6b40; + --el-bg-color: #111111; + --el-bg-color-page: #0a0a0a; + --el-bg-color-overlay: #161616; + --el-text-color-primary: #f5f5f5; + --el-text-color-regular: #d4d4d4; + --el-text-color-secondary: #737373; + --el-text-color-placeholder:#525252; + --el-border-color: rgba(255, 255, 255, 0.08); + --el-border-color-light: rgba(255, 255, 255, 0.06); + --el-border-color-lighter: rgba(255, 255, 255, 0.04); + --el-fill-color: #141414; + --el-fill-color-blank: #0a0a0a; + --el-fill-color-light: #111111; + --el-color-primary: #e5e5e5; + --el-color-primary-light-3: rgba(255, 255, 255, 0.22); + --el-color-primary-light-5: rgba(255, 255, 255, 0.12); + --el-color-primary-light-7: rgba(255, 255, 255, 0.07); + --el-color-primary-light-9: rgba(255, 255, 255, 0.04); + --el-color-primary-dark-2: #a3a3a3; + --el-color-success: #7d9b8a; + --el-color-success-light-3: rgba(125, 155, 138, 0.22); + --el-color-success-light-5: rgba(125, 155, 138, 0.12); + --el-color-success-light-7: rgba(125, 155, 138, 0.07); + --el-color-success-light-9: rgba(125, 155, 138, 0.04); + --el-color-success-dark-2: #5c7568; --el-table-bg-color: transparent; --el-table-tr-bg-color: transparent; - --el-table-header-bg-color: rgba(255,255,255,0.03); - --el-table-row-hover-bg-color: rgba(36, 143, 84, 0.08); - --el-table-border-color: #222; - --el-table-text-color: #ccc; - --el-table-header-text-color: #666; - --el-card-bg-color: rgba(20,20,20,0.85); - --el-card-border-color: #2a2a2a; + --el-table-header-bg-color: transparent; + --el-table-row-hover-bg-color: rgba(255, 255, 255, 0.03); + --el-table-border-color: rgba(255, 255, 255, 0.06); + --el-table-text-color: #d4d4d4; + --el-table-header-text-color: #737373; + --el-card-bg-color: #111111; + --el-card-border-color: rgba(255, 255, 255, 0.08); } html, body, #app { @@ -313,8 +338,8 @@ body::-webkit-scrollbar { border-radius: 10px; } .admin-list-page > .list-panel { - border: 1px solid rgba(255, 255, 255, 0.06); - background: #121212; + border: 1px solid var(--border); + background: var(--bg-card); padding: 0 10px 10px; } .admin-list-page > .data-card .el-card__body { @@ -361,16 +386,11 @@ body::-webkit-scrollbar { } body { - font-family: -apple-system, BlinkMacSystemFont, 'PingFang SC', 'Microsoft YaHei', sans-serif; - background: - url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.12'/%3E%3C/svg%3E"), - linear-gradient(rgba(0,0,0,0.97), rgba(0,0,0,0.97)), - radial-gradient(ellipse 90% 45% at 50% -8%, rgba(31, 138, 82, 0.14), transparent 55%), - radial-gradient(ellipse 60% 30% at 80% 100%, rgba(20, 92, 56, 0.08), transparent 50%); - background-size: 150px, cover, cover; - background-color: #000; - color: #fff; + font-family: -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang SC', 'Microsoft YaHei', sans-serif; + background: var(--bg-body); + color: var(--text); -webkit-font-smoothing: antialiased; + -moz-osx-font-smoothing: grayscale; } /* ── Element Plus 全局暗色覆盖 ── */ @@ -378,38 +398,38 @@ body { background: var(--bg-card) !important; border-color: var(--border) !important; border-radius: var(--radius) !important; - box-shadow: var(--shadow) !important; + box-shadow: none !important; } .el-card__header { - border-bottom-color: #1e1e1e !important; + border-bottom-color: var(--border) !important; color: var(--text-muted); - font-size: 11px; - font-weight: 700; - letter-spacing: 0.06em; - text-transform: uppercase; + font-size: 12px; + font-weight: 500; + letter-spacing: 0; + text-transform: none; } .el-table { background: transparent !important; color: #ccc !important; } .el-table::before { background-color: #222 !important; } .el-table th.el-table__cell { - background: rgba(255,255,255,0.02) !important; - color: #888 !important; - font-size: 11px; font-weight: 700; - letter-spacing: 0.06em; text-transform: uppercase; - border-bottom-color: #1e1e1e !important; + background: transparent !important; + color: var(--text-muted) !important; + font-size: 12px; font-weight: 500; + letter-spacing: 0; text-transform: none; + border-bottom-color: var(--border) !important; } -.el-table td.el-table__cell { border-bottom-color: #161616 !important; color: #bbb !important; } +.el-table td.el-table__cell { border-bottom-color: rgba(255, 255, 255, 0.04) !important; color: #d4d4d4 !important; } .el-table--striped .el-table__body tr.el-table__row--striped td { background: rgba(255,255,255,0.015) !important; } -.el-table__body tr:hover > td { background: rgba(36, 143, 84, 0.07) !important; } +.el-table__body tr:hover > td { background: rgba(255, 255, 255, 0.03) !important; } .el-input__wrapper { - background: #0d0d0d !important; - box-shadow: 0 0 0 1px #2a2a2a inset !important; + background: var(--bg-body) !important; + box-shadow: 0 0 0 1px var(--border) inset !important; border-radius: var(--radius-sm) !important; } -.el-input__wrapper:hover { box-shadow: 0 0 0 1px #3a3a3a inset !important; } +.el-input__wrapper:hover { box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.14) inset !important; } .el-input__wrapper.is-focus { - box-shadow: 0 0 0 1px var(--green-mid) inset, 0 0 0 3px rgba(47, 181, 106, 0.15) !important; + box-shadow: 0 0 0 1px rgba(255, 255, 255, 0.28) inset !important; } .el-input__inner { color: #fff !important; background: transparent !important; } .el-input__inner:-webkit-autofill, @@ -418,51 +438,48 @@ body { -webkit-text-fill-color: #fff !important; } -.el-button { background: #141414 !important; border-color: #2a2a2a !important; color: #aaa !important; transition: background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.15s !important; } -.el-button:hover { background: #1e1e1e !important; border-color: #3a3a3a !important; color: #fff !important; } +.el-button { background: transparent !important; border-color: var(--border) !important; color: #a3a3a3 !important; font-weight: 500 !important; transition: background 0.15s, border-color 0.15s, color 0.15s !important; } +.el-button:hover { background: var(--accent-hover) !important; border-color: rgba(255, 255, 255, 0.14) !important; color: #f5f5f5 !important; } .el-button--primary { - background: var(--primary-grad) !important; - border: 1px solid var(--green-border) !important; + background: var(--accent) !important; + border: 1px solid var(--accent) !important; color: var(--primary-on) !important; - font-weight: 700 !important; - box-shadow: var(--primary-shadow) !important; - text-shadow: 0 1px 1px rgba(0, 0, 0, 0.25); + font-weight: 500 !important; + box-shadow: none !important; } .el-button--primary:hover { - background: var(--primary-grad-hover) !important; - border-color: rgba(120, 230, 170, 0.4) !important; + background: #ffffff !important; + border-color: #ffffff !important; color: var(--primary-on) !important; - box-shadow: 0 1px 0 rgba(255, 255, 255, 0.18) inset, 0 4px 14px rgba(0, 0, 0, 0.5), 0 0 24px rgba(47, 181, 106, 0.28) !important; + box-shadow: none !important; } .el-button--success { - background: linear-gradient(165deg, #42b86e 0%, #248f54 52%, #1a6b40 100%) !important; - border: 1px solid rgba(77, 214, 138, 0.35) !important; - color: #ffffff !important; - font-weight: 700 !important; - box-shadow: 0 1px 0 rgba(255, 255, 255, 0.12) inset, 0 2px 8px rgba(0, 0, 0, 0.35) !important; - text-shadow: 0 1px 1px rgba(0, 0, 0, 0.2); + background: transparent !important; + border: 1px solid var(--success-border) !important; + color: var(--success-text) !important; + font-weight: 500 !important; + box-shadow: none !important; } .el-button--success:hover { - background: linear-gradient(165deg, #52cc7e 0%, #2ea864 52%, #1f7a48 100%) !important; - border-color: rgba(120, 230, 170, 0.45) !important; - color: #ffffff !important; - box-shadow: 0 1px 0 rgba(255, 255, 255, 0.16) inset, 0 4px 12px rgba(0, 0, 0, 0.4), 0 0 18px rgba(47, 181, 106, 0.22) !important; + background: var(--success-bg) !important; + border-color: rgba(255, 255, 255, 0.12) !important; + color: #a8c4b4 !important; + box-shadow: none !important; } .el-button--warning { - background: linear-gradient(165deg, #e8a820 0%, #c48412 52%, #9a6508 100%) !important; - border: 1px solid rgba(251, 191, 36, 0.4) !important; - color: #ffffff !important; - font-weight: 700 !important; - box-shadow: 0 1px 0 rgba(255, 255, 255, 0.1) inset, 0 2px 8px rgba(0, 0, 0, 0.35) !important; - text-shadow: 0 1px 1px rgba(0, 0, 0, 0.25); + background: transparent !important; + border: 1px solid rgba(255, 255, 255, 0.1) !important; + color: #d4a574 !important; + font-weight: 500 !important; + box-shadow: none !important; } .el-button--warning:hover { - background: linear-gradient(165deg, #f0b830 0%, #d49218 52%, #aa720a 100%) !important; - border-color: rgba(251, 191, 36, 0.55) !important; - color: #ffffff !important; - box-shadow: 0 1px 0 rgba(255, 255, 255, 0.14) inset, 0 4px 12px rgba(0, 0, 0, 0.4), 0 0 16px rgba(251, 191, 36, 0.18) !important; + background: rgba(255, 255, 255, 0.04) !important; + border-color: rgba(255, 255, 255, 0.14) !important; + color: #e0b888 !important; + box-shadow: none !important; } -.el-button--danger { background: rgba(255,69,58,0.1) !important; border-color: rgba(255,69,58,0.35) !important; color: #ff453a !important; } +.el-button--danger { background: transparent !important; border-color: rgba(255,69,58,0.25) !important; color: #ef4444 !important; } /* ── Disabled: muted ghost, clearly non-interactive ── */ .el-button.is-disabled, @@ -489,25 +506,25 @@ body { .el-button--primary.is-disabled, .el-button--primary.is-disabled:hover, .el-button--primary:disabled { - background: rgba(36, 143, 84, 0.1) !important; - border-color: rgba(36, 143, 84, 0.14) !important; - color: rgba(154, 232, 188, 0.32) !important; + background: rgba(255, 255, 255, 0.06) !important; + border-color: rgba(255, 255, 255, 0.06) !important; + color: rgba(255, 255, 255, 0.28) !important; } .el-button--primary.is-plain.is-disabled, .el-button--primary.is-plain.is-disabled:hover, .el-button--primary.is-plain:disabled { - background: rgba(36, 143, 84, 0.06) !important; - border-color: rgba(36, 143, 84, 0.12) !important; - color: rgba(154, 232, 188, 0.28) !important; + background: transparent !important; + border-color: rgba(255, 255, 255, 0.06) !important; + color: rgba(255, 255, 255, 0.24) !important; } .el-button--success.is-disabled, .el-button--success.is-disabled:hover, .el-button--success:disabled { - background: rgba(36, 143, 84, 0.08) !important; - border-color: rgba(36, 143, 84, 0.12) !important; - color: rgba(154, 232, 188, 0.28) !important; + background: transparent !important; + border-color: rgba(255, 255, 255, 0.06) !important; + color: rgba(255, 255, 255, 0.24) !important; } .el-button--warning.is-disabled, @@ -534,15 +551,15 @@ body { color: rgba(255, 107, 98, 0.28) !important; } .el-button--primary.is-plain { - background: rgba(36, 143, 84, 0.12) !important; - border-color: var(--green-border) !important; - color: var(--green-text) !important; + background: transparent !important; + border-color: var(--border) !important; + color: #d4d4d4 !important; box-shadow: none !important; } .el-button--primary.is-plain:hover { - background: rgba(36, 143, 84, 0.22) !important; - border-color: rgba(120, 230, 170, 0.45) !important; - color: #d4fde5 !important; + background: var(--accent-hover) !important; + border-color: rgba(255, 255, 255, 0.14) !important; + color: #f5f5f5 !important; } .el-button--danger.is-plain { background: rgba(255, 69, 58, 0.14) !important; @@ -558,50 +575,106 @@ body { } .el-button.is-text, .el-button.is-link.el-button--default { - color: var(--green-text) !important; + color: var(--accent-muted) !important; background: transparent !important; border-color: transparent !important; box-shadow: none !important; } .el-button.is-text:hover, .el-button.is-link.el-button--default:hover { - color: #d4fde5 !important; - background: rgba(36, 143, 84, 0.1) !important; + color: #f5f5f5 !important; + background: transparent !important; } -.el-tag { border-radius: 4px !important; font-size: 11px !important; font-weight: 600 !important; } +.el-tag { border-radius: 4px !important; font-size: 11px !important; font-weight: 500 !important; } .el-tag--success { - background: linear-gradient(135deg, rgba(36, 143, 84, 0.35), rgba(20, 92, 56, 0.5)) !important; - border: 1px solid var(--green-border) !important; - color: #c8f5d8 !important; - box-shadow: 0 1px 2px rgba(0, 0, 0, 0.2); + background: var(--success-bg) !important; + border: 1px solid var(--success-border) !important; + color: var(--success-text) !important; } .el-tag--warning { background: rgba(251,191,36,0.1) !important; border-color: rgba(251,191,36,0.3) !important; color: #fbbf24 !important; } .el-tag--danger { background: rgba(255,69,58,0.1) !important; border-color: rgba(255,69,58,0.3) !important; color: #ff453a !important; } .el-tag--info { background: rgba(255,255,255,0.06) !important; border-color: #3a3a3a !important; color: #aaa !important; } -/* 表格操作按钮:渐变绿 + 白字 */ +/* 表格操作:纯文字链 */ .el-button.is-link.el-button--primary, .el-button.is-link.el-button--success { - color: #ffffff !important; - background: var(--primary-grad) !important; - border: 1px solid var(--green-border) !important; - border-radius: 6px !important; - padding: 5px 11px !important; - box-shadow: 0 1px 0 rgba(255, 255, 255, 0.12) inset, 0 1px 6px rgba(0, 0, 0, 0.35) !important; - text-shadow: 0 1px 1px rgba(0, 0, 0, 0.2); + color: var(--accent-muted) !important; + background: transparent !important; + border: none !important; + border-radius: 0 !important; + padding: 0 4px !important; + box-shadow: none !important; + font-weight: 500 !important; } .el-button.is-link.el-button--primary:hover, .el-button.is-link.el-button--primary:focus, .el-button.is-link.el-button--success:hover, .el-button.is-link.el-button--success:focus { - color: #ffffff !important; - background: var(--primary-grad-hover) !important; - border-color: rgba(120, 230, 170, 0.45) !important; - box-shadow: 0 1px 0 rgba(255, 255, 255, 0.16) inset, 0 2px 10px rgba(0, 0, 0, 0.4), 0 0 16px rgba(47, 181, 106, 0.25) !important; + color: #f5f5f5 !important; + background: transparent !important; + border: none !important; + box-shadow: none !important; + text-decoration: underline; + text-underline-offset: 3px; +} +.el-button.is-link.el-button--warning { + color: #a3a3a3 !important; + background: transparent !important; + border: none !important; + border-radius: 0 !important; + padding: 0 4px !important; + box-shadow: none !important; + font-weight: 500 !important; +} +.el-button.is-link.el-button--warning:hover, +.el-button.is-link.el-button--warning:focus { + color: #d4a574 !important; + background: transparent !important; + border: none !important; + box-shadow: none !important; + text-decoration: underline; + text-underline-offset: 3px; } -.el-form-item__label { color: #aaa !important; font-size: 12px !important; font-weight: 600 !important; letter-spacing: 0.02em !important; } +/* 表格 link 操作按钮禁用:保留按钮形态,灰显不可点 */ +.el-button.is-link.is-disabled, +.el-button.is-link.is-disabled:hover, +.el-button.is-link.is-disabled:focus, +.el-button.is-link:disabled { + cursor: not-allowed !important; + pointer-events: none; + background: rgba(255, 255, 255, 0.04) !important; + border: 1px solid rgba(255, 255, 255, 0.1) !important; + color: rgba(255, 255, 255, 0.28) !important; + box-shadow: none !important; + text-shadow: none !important; + opacity: 1 !important; + transform: none !important; + filter: none; +} + +.el-button.is-link.el-button--primary.is-disabled, +.el-button.is-link.el-button--success.is-disabled { + background: transparent !important; + border: none !important; + color: rgba(255, 255, 255, 0.24) !important; + text-decoration: none !important; +} + +.el-button.is-link.el-button--danger.is-disabled { + background: rgba(255, 69, 58, 0.06) !important; + border-color: rgba(255, 69, 58, 0.1) !important; + color: rgba(255, 107, 98, 0.26) !important; +} + +.el-button.is-link.el-button--warning.is-disabled { + background: rgba(196, 132, 18, 0.08) !important; + border-color: rgba(196, 132, 18, 0.12) !important; + color: rgba(251, 191, 36, 0.26) !important; +} + +.el-form-item__label { color: var(--text-muted) !important; font-size: 13px !important; font-weight: 500 !important; letter-spacing: 0 !important; } /* ── Dialog / overlay:实心背景,避免噪点透底发糊 ── */ .el-overlay { @@ -609,10 +682,10 @@ body { backdrop-filter: none !important; } .el-dialog { - background: #1a1a1a !important; - border: 1px solid #333 !important; + background: #141414 !important; + border: 1px solid var(--border) !important; border-radius: var(--radius) !important; - box-shadow: 0 12px 40px rgba(0, 0, 0, 0.65) !important; + box-shadow: 0 24px 48px rgba(0, 0, 0, 0.5) !important; } .el-dialog__header { border-bottom: 1px solid #2a2a2a !important; @@ -664,8 +737,20 @@ body { overflow-y: auto; } -.el-statistic__head { color: #555 !important; font-size: 11px !important; font-weight: 700 !important; letter-spacing: 0.06em !important; text-transform: uppercase !important; } -.el-statistic__content .el-statistic__number { font-size: 26px !important; font-weight: 800 !important; color: #fff !important; } +.entity-detail-dialog .el-dialog__body { + padding: 12px 20px 16px !important; + max-height: none !important; + overflow: visible !important; +} + +.detail-actions { + margin-top: 10px; + padding-top: 10px; + border-top: 1px solid rgba(255, 255, 255, 0.06); +} + +.el-statistic__head { color: #737373 !important; font-size: 12px !important; font-weight: 500 !important; letter-spacing: 0 !important; text-transform: none !important; } +.el-statistic__content .el-statistic__number { font-size: 24px !important; font-weight: 500 !important; color: #f5f5f5 !important; } .el-input-number .el-input__wrapper { background: #0d0d0d !important; } .el-date-editor .el-input__wrapper { background: #0d0d0d !important; } diff --git a/apps/admin/src/components/AdminDetailGrid.vue b/apps/admin/src/components/AdminDetailGrid.vue new file mode 100644 index 0000000..f496a91 --- /dev/null +++ b/apps/admin/src/components/AdminDetailGrid.vue @@ -0,0 +1,24 @@ + + + + + diff --git a/apps/admin/src/components/AdminDetailItem.vue b/apps/admin/src/components/AdminDetailItem.vue new file mode 100644 index 0000000..b776245 --- /dev/null +++ b/apps/admin/src/components/AdminDetailItem.vue @@ -0,0 +1,75 @@ + + + + + diff --git a/apps/admin/src/components/AdminLocaleSwitcher.vue b/apps/admin/src/components/AdminLocaleSwitcher.vue index b9efca1..06f6d30 100644 --- a/apps/admin/src/components/AdminLocaleSwitcher.vue +++ b/apps/admin/src/components/AdminLocaleSwitcher.vue @@ -133,24 +133,24 @@ onUnmounted(() => document.removeEventListener('click', onDocClick)); /* 管理顶栏 */ .admin-locale.admin .admin-locale-trigger { - background: #0d0d0d; - color: var(--green-text); - border: 1px solid var(--green-border); + background: transparent; + color: #a3a3a3; + border: 1px solid rgba(255, 255, 255, 0.08); } .admin-locale.admin .admin-locale-menu { - background: #0f1411; - border: 1px solid var(--green-border); + background: #141414; + border: 1px solid rgba(255, 255, 255, 0.08); } .admin-locale.admin .admin-locale-option { - color: #8ab89a; + color: #a3a3a3; } .admin-locale.admin .admin-locale-option:hover, .admin-locale.admin .admin-locale-option.active { - background: var(--green-surface); - color: var(--green-text); + background: rgba(255, 255, 255, 0.06); + color: #f5f5f5; } /* 登录页:与玩家端金色主题一致 */ diff --git a/apps/admin/src/components/AdminPlayerRowActions.vue b/apps/admin/src/components/AdminPlayerRowActions.vue new file mode 100644 index 0000000..2a573b6 --- /dev/null +++ b/apps/admin/src/components/AdminPlayerRowActions.vue @@ -0,0 +1,82 @@ + + + + + diff --git a/apps/admin/src/components/AdminResponsiveRowActions.vue b/apps/admin/src/components/AdminResponsiveRowActions.vue new file mode 100644 index 0000000..8a60f39 --- /dev/null +++ b/apps/admin/src/components/AdminResponsiveRowActions.vue @@ -0,0 +1,55 @@ + + + + + diff --git a/apps/admin/src/components/AdminRowActionsDropdown.vue b/apps/admin/src/components/AdminRowActionsDropdown.vue new file mode 100644 index 0000000..f271c3c --- /dev/null +++ b/apps/admin/src/components/AdminRowActionsDropdown.vue @@ -0,0 +1,51 @@ + + + + + diff --git a/apps/admin/src/components/AdminSubNav.vue b/apps/admin/src/components/AdminSubNav.vue index a3f27bf..64fe12b 100644 --- a/apps/admin/src/components/AdminSubNav.vue +++ b/apps/admin/src/components/AdminSubNav.vue @@ -53,15 +53,15 @@ defineProps<{ line-height: 1.4; } .admin-subnav__link { - color: var(--green-text); - font-weight: 600; + color: #737373; + font-weight: 500; transition: color 0.15s; } .admin-subnav__link:hover { - color: #d4fde5; + color: #f5f5f5; } .admin-subnav__current { - color: #888; + color: #737373; } .admin-subnav__sep { color: #444; @@ -83,10 +83,10 @@ defineProps<{ } .admin-subnav__title { margin: 0; - font-size: 20px; - font-weight: 700; - color: #e8e8e8; - letter-spacing: 0.02em; + font-size: 18px; + font-weight: 500; + color: #f5f5f5; + letter-spacing: 0; } .admin-subnav__subtitle { font-size: 13px; diff --git a/apps/admin/src/components/AgentCreditContext.vue b/apps/admin/src/components/AgentCreditContext.vue index 0ddd418..19a4fad 100644 --- a/apps/admin/src/components/AgentCreditContext.vue +++ b/apps/admin/src/components/AgentCreditContext.vue @@ -122,7 +122,7 @@ function fmtFull(value: string | null | undefined) { color: #888; } .c-green { - color: #67c23a; + color: var(--gold-text); font-weight: 600; } .c-amber { diff --git a/apps/admin/src/components/DashboardSubNav.vue b/apps/admin/src/components/DashboardSubNav.vue index d9f42c9..358a361 100644 --- a/apps/admin/src/components/DashboardSubNav.vue +++ b/apps/admin/src/components/DashboardSubNav.vue @@ -47,14 +47,14 @@ function isActive(path: string) { .dashboard-subnav { display: flex; align-items: center; - gap: 4px; + gap: 2px; margin-bottom: 16px; - padding: 6px; - border-radius: 10px; + padding: 3px; + border-radius: 8px; background: rgba(255, 255, 255, 0.03); border: 1px solid rgba(255, 255, 255, 0.06); flex-shrink: 0; - min-height: 48px; + min-height: 40px; box-sizing: border-box; } .dashboard-subnav--embedded { @@ -68,24 +68,24 @@ function isActive(path: string) { box-sizing: border-box; } .dashboard-subnav__item { - padding: 0 14px; - height: 36px; + padding: 0 12px; + height: 32px; display: inline-flex; align-items: center; justify-content: center; box-sizing: border-box; - border-radius: 8px; + border-radius: 6px; font-size: 13px; - font-weight: 600; - color: #888; + font-weight: 500; + color: #737373; transition: color 0.15s, background 0.15s; } .dashboard-subnav__item:hover { - color: #ccc; + color: #d4d4d4; background: rgba(255, 255, 255, 0.04); } .dashboard-subnav__item--active { - color: var(--green-text); - background: rgba(0, 200, 83, 0.1); + color: #f5f5f5; + background: rgba(255, 255, 255, 0.08); } diff --git a/apps/admin/src/components/InviteCodePanel.vue b/apps/admin/src/components/InviteCodePanel.vue new file mode 100644 index 0000000..0ba4706 --- /dev/null +++ b/apps/admin/src/components/InviteCodePanel.vue @@ -0,0 +1,247 @@ + + + + + diff --git a/apps/admin/src/components/InviteHistoryPanel.vue b/apps/admin/src/components/InviteHistoryPanel.vue new file mode 100644 index 0000000..b2decd4 --- /dev/null +++ b/apps/admin/src/components/InviteHistoryPanel.vue @@ -0,0 +1,507 @@ + + + + + diff --git a/apps/admin/src/components/InviteManageDialog.vue b/apps/admin/src/components/InviteManageDialog.vue new file mode 100644 index 0000000..5756906 --- /dev/null +++ b/apps/admin/src/components/InviteManageDialog.vue @@ -0,0 +1,197 @@ + + + + + + + diff --git a/apps/admin/src/components/LogoUrlField.vue b/apps/admin/src/components/LogoUrlField.vue index 7cddae2..130fcc8 100644 --- a/apps/admin/src/components/LogoUrlField.vue +++ b/apps/admin/src/components/LogoUrlField.vue @@ -318,13 +318,13 @@ const oldUrl = ref(props.modelValue); } .drop-zone:hover { - border-color: rgba(47, 181, 106, 0.4); - background: rgba(47, 181, 106, 0.04); + border-color: rgba(212, 175, 55, 0.4); + background: rgba(212, 175, 55, 0.04); } .drop-zone.is-dragging { - border-color: #2fb56a; - background: rgba(47, 181, 106, 0.1); + border-color: var(--gold-mid); + background: rgba(212, 175, 55, 0.1); } .drop-preview { diff --git a/apps/admin/src/components/PlayerWalletLedgerDialog.vue b/apps/admin/src/components/PlayerWalletLedgerDialog.vue index 98ee75f..55574ca 100644 --- a/apps/admin/src/components/PlayerWalletLedgerDialog.vue +++ b/apps/admin/src/components/PlayerWalletLedgerDialog.vue @@ -5,7 +5,7 @@ import { useAdminLocale } from '../composables/useAdminLocale'; import api from '../api'; import AdminTableEmpty from './AdminTableEmpty.vue'; import { formatAmount, formatAmountFull } from '../utils/format-amount'; -import { walletTxTypeKey } from '../utils/walletTx'; +import { walletDepositMethodLabel, walletTxTypeKey } from '../utils/walletTx'; interface WalletTxRow { id: string; @@ -17,6 +17,8 @@ interface WalletTxRow { frozenBefore: string; frozenAfter: string; betNo: string | null; + depositMethodKey: string | null; + depositMethodName: string | null; operatorUsername: string | null; remark: string | null; createdAt: string; @@ -62,6 +64,10 @@ function walletTypeLabel(type: string) { return key ? t(key) : type; } +function depositMethodLabel(row: WalletTxRow) { + return walletDepositMethodLabel(row, t); +} + function formatTime(v: string) { return new Date(v).toLocaleString(localeTag.value, { year: 'numeric', @@ -133,7 +139,7 @@ watch( - + + + + + + + - + - - - - - - @@ -1408,6 +1479,12 @@ function creditTypeLabel(type: string) { + + + - + - - - @@ -1472,18 +1542,22 @@ function creditTypeLabel(type: string) { - + - + @@ -1545,14 +1619,14 @@ function creditTypeLabel(type: string) {
- + @@ -1635,13 +1722,14 @@ function creditTypeLabel(type: string) { :page-sizes="[10, 20, 50, 100]" layout="total, sizes, prev, pager, next" background - @current-change="(p) => onSubAgentPageChange(agentLevel, p)" - @size-change="(size) => onSubAgentSizeChange(agentLevel, size)" + @current-change="bindSubAgentPageChange(agentLevel)" + @size-change="bindSubAgentSizeChange(agentLevel)" />
+ @@ -1798,14 +1886,7 @@ function creditTypeLabel(type: string) {
{{ t('agent.hint.credit_limit') }}
- + @@ -1875,6 +1956,20 @@ function creditTypeLabel(type: string) { {{ affiliationLabel(editPlayerForm) }}
{{ t('user.hint.agent_readonly') }}
+ +
+ + {{ t('cashback.use_custom_rate') }} + + +

+ {{ t('cashback.use_default_rate', { rate: `${editPlayerForm.defaultCashbackRate.toFixed(2)}%` }) }} +

+
+
@@ -1928,7 +2023,7 @@ function creditTypeLabel(type: string) { - + @@ -2026,38 +2121,46 @@ function creditTypeLabel(type: string) {
- +