| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664 |
- .scraper-page {
- padding: 16px;
- padding-bottom: 52px;
- height: calc(100vh - 64px);
- box-sizing: border-box;
- overflow-y: auto;
- }
- .scraper-layout {
- display: grid;
- grid-template-columns: 280px 1fr;
- gap: 16px;
- min-height: 100%;
- align-items: start;
- }
- /* 左侧模型列表 */
- .model-sidebar {
- display: flex;
- flex-direction: column;
- gap: 10px;
- background: var(--bg-card);
- border: 1px solid var(--bg-border);
- border-radius: 4px;
- padding: 14px;
- box-sizing: border-box;
- position: sticky;
- top: 0;
- max-height: calc(100vh - 64px - 32px);
- overflow-y: auto;
- }
- .sidebar-header {
- display: flex;
- justify-content: space-between;
- align-items: center;
- }
- .sidebar-title {
- font-size: 12px;
- color: var(--text-muted);
- letter-spacing: 0.08em;
- }
- .icon-btn {
- background: transparent;
- border: 1px solid var(--neon-cyan);
- color: var(--neon-cyan);
- width: 24px;
- height: 24px;
- border-radius: 4px;
- font-size: 16px;
- line-height: 1;
- cursor: pointer;
- display: flex;
- align-items: center;
- justify-content: center;
- }
- .icon-btn:hover { background: rgba(0, 212, 255, 0.1); }
- .add-form {
- display: flex;
- flex-direction: column;
- gap: 6px;
- padding: 10px;
- background: var(--bg-panel, #0d1117);
- border: 1px solid var(--bg-border);
- border-radius: 4px;
- }
- .add-input {
- background: var(--bg-card);
- border: 1px solid var(--bg-border);
- border-radius: 3px;
- color: var(--text-primary);
- font-family: var(--font-mono);
- font-size: 12px;
- padding: 6px 8px;
- outline: none;
- }
- .add-input:focus { border-color: var(--neon-cyan); }
- .add-error { color: var(--neon-red); font-size: 11px; }
- .add-actions { display: flex; gap: 6px; }
- .add-confirm-btn {
- flex: 1;
- background: transparent;
- border: 1px solid var(--neon-green);
- color: var(--neon-green);
- padding: 5px;
- font-size: 11px;
- border-radius: 3px;
- cursor: pointer;
- }
- .add-confirm-btn:hover { background: rgba(0, 255, 136, 0.1); }
- .add-cancel-btn {
- flex: 1;
- background: transparent;
- border: 1px solid var(--bg-border);
- color: var(--text-muted);
- padding: 5px;
- font-size: 11px;
- border-radius: 3px;
- cursor: pointer;
- }
- .model-list-header {
- display: flex;
- justify-content: space-between;
- align-items: center;
- font-size: 11px;
- color: var(--text-muted);
- padding-bottom: 6px;
- border-bottom: 1px solid var(--bg-border);
- }
- .check-label {
- display: flex;
- align-items: center;
- gap: 6px;
- cursor: pointer;
- font-size: 12px;
- }
- .selected-count { color: var(--neon-cyan); font-size: 11px; }
- .model-list {
- list-style: none;
- flex: 1;
- overflow-y: auto;
- display: flex;
- flex-direction: column;
- gap: 4px;
- min-height: 0;
- max-height: 100%;
- }
- .model-item {
- display: flex;
- align-items: center;
- justify-content: space-between;
- padding: 6px 8px;
- border-radius: 3px;
- border: 1px solid transparent;
- transition: border-color 0.15s;
- flex-shrink: 0;
- }
- .model-item:hover { border-color: var(--bg-border); }
- .model-item--selected { border-color: var(--neon-cyan) !important; background: rgba(0, 212, 255, 0.05); }
- .model-name {
- font-size: 12px;
- color: var(--text-primary);
- overflow: hidden;
- text-overflow: ellipsis;
- white-space: nowrap;
- max-width: 170px;
- }
- .del-btn {
- background: transparent;
- border: none;
- color: var(--text-muted);
- font-size: 11px;
- cursor: pointer;
- padding: 2px 4px;
- border-radius: 2px;
- flex-shrink: 0;
- }
- .del-btn:hover { color: var(--neon-red); }
- .scrape-btn {
- width: 100%;
- text-align: center;
- flex-shrink: 0;
- align-self: auto;
- }
- /* 右侧主区域 */
- .scraper-main {
- display: flex;
- flex-direction: column;
- gap: 12px;
- min-width: 0;
- }
- .scraper-header {
- margin-bottom: 16px;
- }
- .scraper-title {
- font-size: 13px;
- color: var(--text-muted);
- letter-spacing: 0.1em;
- }
- .scraper-input-area {
- display: flex;
- flex-direction: column;
- gap: 10px;
- margin-bottom: 16px;
- }
- .url-input {
- background: var(--bg-card);
- border: 1px solid var(--bg-border);
- border-radius: 4px;
- color: var(--text-primary);
- font-family: var(--font-mono);
- font-size: 12px;
- padding: 10px;
- resize: vertical;
- outline: none;
- transition: border-color 0.2s;
- }
- .url-input:focus {
- border-color: var(--neon-cyan);
- }
- .submit-btn {
- background: transparent;
- border: 1px solid var(--neon-green);
- color: var(--neon-green);
- padding: 10px 20px;
- font-size: 13px;
- letter-spacing: 0.1em;
- border-radius: 4px;
- transition: background 0.2s, box-shadow 0.2s;
- align-self: flex-start;
- }
- .submit-btn:hover:not(:disabled) {
- background: rgba(0, 255, 136, 0.1);
- box-shadow: 0 0 10px rgba(0, 255, 136, 0.3);
- }
- .submit-btn:disabled {
- opacity: 0.5;
- cursor: not-allowed;
- }
- .error-banner {
- background: rgba(255, 68, 102, 0.1);
- border: 1px solid var(--neon-red);
- color: var(--neon-red);
- padding: 10px;
- border-radius: 4px;
- font-size: 12px;
- margin-bottom: 12px;
- }
- .job-status {
- display: flex;
- justify-content: space-between;
- align-items: center;
- padding: 10px 14px;
- border-radius: 4px;
- font-size: 12px;
- margin-bottom: 12px;
- border: 1px solid var(--bg-border);
- background: var(--bg-card);
- }
- .job-badge {
- font-weight: bold;
- letter-spacing: 0.08em;
- }
- .job-status--pending .job-badge,
- .job-status--running .job-badge { color: #ffaa00; }
- .job-status--done .job-badge { color: var(--neon-green); }
- .job-status--failed .job-badge { color: var(--neon-red); }
- .error-card {
- background: rgba(255, 68, 102, 0.08);
- border: 1px solid var(--neon-red);
- border-radius: 4px;
- padding: 14px;
- margin-bottom: 16px;
- }
- .error-card-title {
- color: var(--neon-red);
- font-size: 12px;
- margin-bottom: 8px;
- letter-spacing: 0.08em;
- }
- .error-detail {
- color: var(--text-muted);
- font-size: 11px;
- white-space: pre-wrap;
- word-break: break-all;
- max-height: 200px;
- overflow-y: auto;
- }
- .results-section {
- display: flex;
- flex-direction: column;
- gap: 12px;
- margin-bottom: 20px;
- }
- .price-card {
- background: var(--bg-card);
- border: 1px solid var(--bg-border);
- border-radius: 4px;
- padding: 14px;
- }
- .price-card-title {
- color: var(--neon-cyan);
- font-size: 14px;
- font-weight: bold;
- margin-bottom: 4px;
- }
- .price-card-url {
- color: var(--text-muted);
- font-size: 10px;
- margin-bottom: 10px;
- word-break: break-all;
- }
- .price-entries {
- display: flex;
- flex-direction: column;
- gap: 6px;
- margin-bottom: 10px;
- }
- .price-entry {
- display: flex;
- justify-content: space-between;
- font-size: 12px;
- padding: 4px 0;
- border-bottom: 1px solid var(--bg-border);
- }
- .price-key { color: var(--text-muted); }
- .price-val { color: var(--neon-green); }
- .no-price { color: var(--text-muted); font-size: 12px; }
- .price-time {
- color: var(--text-muted);
- font-size: 10px;
- }
- .history-section {
- margin-top: 20px;
- }
- .section-title {
- font-size: 11px;
- color: var(--text-muted);
- letter-spacing: 0.1em;
- margin-bottom: 10px;
- }
- .history-list {
- list-style: none;
- display: flex;
- flex-direction: column;
- gap: 6px;
- }
- .history-item {
- display: flex;
- flex-direction: column;
- background: var(--bg-card);
- border: 1px solid var(--bg-border);
- border-radius: 4px;
- font-size: 11px;
- transition: border-color 0.2s;
- overflow: hidden;
- }
- .history-item:hover { border-color: var(--neon-cyan); }
- .history-row {
- display: grid;
- grid-template-columns: 100px 80px 1fr auto;
- align-items: center;
- gap: 10px;
- padding: 8px 12px;
- cursor: pointer;
- }
- .history-toggle {
- color: var(--text-muted);
- font-size: 10px;
- }
- .history-detail {
- border-top: 1px solid var(--bg-border);
- padding: 12px;
- display: flex;
- flex-direction: column;
- gap: 10px;
- }
- .history-id { color: var(--neon-cyan); }
- .history-time { color: var(--text-muted); text-align: right; }
- .history-item--done .history-status { color: var(--neon-green); }
- .history-item--failed .history-status { color: var(--neon-red); }
- .history-item--running .history-status,
- .history-item--pending .history-status { color: #ffaa00; }
- /* 定时爬取配置 */
- .schedule-box {
- border: 1px solid var(--bg-border);
- border-radius: 4px;
- padding: 10px;
- display: flex;
- flex-direction: column;
- gap: 8px;
- flex-shrink: 0;
- }
- .schedule-header {
- display: flex;
- justify-content: space-between;
- align-items: center;
- }
- .schedule-title {
- font-size: 11px;
- color: var(--text-muted);
- letter-spacing: 0.08em;
- }
- .toggle-btn {
- font-size: 11px;
- padding: 3px 10px;
- border-radius: 20px;
- border: 1px solid var(--bg-border);
- background: transparent;
- color: var(--text-muted);
- cursor: pointer;
- transition: all 0.2s;
- }
- .toggle-btn--on {
- border-color: var(--neon-green);
- color: var(--neon-green);
- background: rgba(0, 255, 136, 0.08);
- }
- .toggle-btn:disabled { opacity: 0.5; cursor: not-allowed; }
- .schedule-row {
- display: flex;
- align-items: center;
- gap: 6px;
- }
- .schedule-label {
- font-size: 11px;
- color: var(--text-muted);
- white-space: nowrap;
- width: 36px;
- }
- .schedule-input {
- background: var(--bg-card);
- border: 1px solid var(--bg-border);
- border-radius: 3px;
- color: var(--text-primary);
- font-family: var(--font-mono);
- font-size: 12px;
- padding: 4px 6px;
- width: 52px;
- outline: none;
- text-align: center;
- }
- .schedule-input--sm { width: 52px; }
- .schedule-input:focus { border-color: var(--neon-cyan); }
- .schedule-unit {
- font-size: 11px;
- color: var(--text-muted);
- }
- /* 模型详情卡片各区块 */
- .info-section {
- margin-top: 10px;
- padding-top: 10px;
- border-top: 1px solid var(--bg-border);
- }
- .info-section-title {
- font-size: 10px;
- color: var(--text-muted);
- letter-spacing: 0.08em;
- margin-bottom: 6px;
- }
- .info-desc {
- font-size: 11px;
- color: var(--text-primary);
- line-height: 1.5;
- margin-bottom: 6px;
- }
- .tag-row {
- display: flex;
- flex-wrap: wrap;
- gap: 4px;
- margin-bottom: 6px;
- }
- .tag {
- font-size: 10px;
- padding: 2px 7px;
- border-radius: 10px;
- border: 1px solid var(--neon-cyan);
- color: var(--neon-cyan);
- }
- .modality-row {
- display: flex;
- gap: 12px;
- margin-bottom: 6px;
- }
- .modality {
- font-size: 11px;
- color: var(--text-muted);
- }
- .feature-grid {
- display: flex;
- flex-wrap: wrap;
- gap: 4px;
- margin-top: 4px;
- }
- .feature-item {
- font-size: 10px;
- padding: 2px 7px;
- border-radius: 3px;
- border: 1px solid var(--bg-border);
- }
- .feature-item--on { color: var(--neon-green); border-color: var(--neon-green); }
- .feature-item--off { color: var(--text-muted); opacity: 0.5; }
- .kv-grid {
- display: grid;
- grid-template-columns: repeat(2, 1fr);
- gap: 4px 12px;
- }
- .kv-item {
- display: flex;
- justify-content: space-between;
- font-size: 11px;
- padding: 3px 0;
- border-bottom: 1px solid var(--bg-border);
- }
- .kv-key { color: var(--text-muted); }
- .kv-val { color: var(--neon-cyan); }
- .price-note { color: var(--text-muted); font-size: 10px; }
- /* 历史记录分页 */
- .pagination {
- display: flex;
- align-items: center;
- justify-content: center;
- gap: 8px;
- font-size: 12px;
- color: var(--text-muted);
- position: fixed;
- bottom: 0;
- left: 64px;
- right: 0;
- background: var(--bg-panel, #0d1117);
- padding: 10px 0;
- border-top: 1px solid var(--bg-border);
- z-index: 10;
- }
- .pagination-info { color: var(--text-muted); }
- .page-size-select {
- background: var(--bg-card);
- border: 1px solid var(--bg-border);
- border-radius: 3px;
- color: var(--text-primary);
- font-size: 12px;
- padding: 2px 4px;
- outline: none;
- cursor: pointer;
- }
- .page-size-select:focus { border-color: var(--neon-cyan); }
- .page-btn {
- background: transparent;
- border: 1px solid var(--bg-border);
- color: var(--text-muted);
- padding: 3px 10px;
- border-radius: 3px;
- font-size: 12px;
- cursor: pointer;
- transition: all 0.15s;
- }
- .page-btn:hover:not(:disabled) {
- border-color: var(--neon-cyan);
- color: var(--neon-cyan);
- }
- .page-btn:disabled { opacity: 0.4; cursor: not-allowed; }
- .page-num {
- background: var(--neon-cyan);
- color: #000;
- border: 1px solid var(--neon-cyan);
- padding: 3px 10px;
- border-radius: 3px;
- font-size: 12px;
- font-weight: bold;
- min-width: 28px;
- text-align: center;
- }
- /* 模型管理跳转链接 */
- .sidebar-manage-link {
- font-size: 11px;
- color: var(--neon-cyan);
- text-decoration: none;
- border: 1px solid var(--neon-cyan);
- padding: 2px 8px;
- border-radius: 3px;
- transition: background 0.15s;
- }
- .sidebar-manage-link:hover {
- background: rgba(0, 212, 255, 0.1);
- }
- /* API Key 徽章 */
- .model-key-badge {
- font-size: 11px;
- flex-shrink: 0;
- opacity: 0.8;
- cursor: default;
- }
|