Restyling light pastel: tema blanco/azul/verde + Inter self-hosted
- theme.css reescrito: paleta light (sky/emerald accents, slate neutrals), tokens de spacing/typography/radii/shadows, @font-face Inter + JetBrains Mono variable woff2 self-hosted. - ops-shell: header blanco con nav active=accent-soft + status pill pastel. - run-timeline: bubbles emerald-100 (user) / blue-100 (bot) sobre blanco. - home-dashboard: helpers cssVar + withAlpha, 6 charts coordinados a paleta pastel (--chart-blue/green/purple/orange/pink/gray). - 8 CRUDs (users, products, orders, conversations, aliases, recommendations, quantities, takeovers, settings, debug) migrados de hex hardcoded oscuros a var(--*). - modal.js + toast.js refactor a vars con fallbacks; modal blanco con shadow-lg y soft icon backgrounds. - test-panel: aliases :host apuntan a globals en vez de override dark. Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
@@ -18,87 +18,87 @@ class TakeoversCrud extends HTMLElement {
|
||||
:host { display:block; height:100%; padding:16px; overflow:hidden; }
|
||||
* { box-sizing:border-box; font-family:system-ui,Segoe UI,Roboto,Arial; }
|
||||
.container { display:grid; grid-template-columns:350px 1fr; gap:16px; height:100%; }
|
||||
.panel { background:#121823; border:1px solid #1e2a3a; border-radius:10px; padding:16px; overflow:hidden; display:flex; flex-direction:column; }
|
||||
.panel-title { font-size:14px; font-weight:700; color:#8aa0b5; text-transform:uppercase; letter-spacing:.4px; margin-bottom:12px; display:flex; align-items:center; gap:8px; }
|
||||
.panel-title .badge { background:#e74c3c; color:#fff; padding:2px 8px; border-radius:10px; font-size:11px; }
|
||||
.panel { background:var(--panel); border:1px solid var(--border); border-radius:10px; padding:16px; overflow:hidden; display:flex; flex-direction:column; }
|
||||
.panel-title { font-size:14px; font-weight:700; color:var(--text-muted); text-transform:uppercase; letter-spacing:.4px; margin-bottom:12px; display:flex; align-items:center; gap:8px; }
|
||||
.panel-title .badge { background:var(--err); color:#fff; padding:2px 8px; border-radius:10px; font-size:11px; }
|
||||
|
||||
input, select, textarea { background:#0f1520; color:#e7eef7; border:1px solid #253245; border-radius:8px; padding:8px 12px; font-size:13px; width:100%; }
|
||||
input:focus, select:focus, textarea:focus { outline:none; border-color:#1f6feb; }
|
||||
input, select, textarea { background:var(--panel-2); color:var(--text); border:1px solid var(--border-hi); border-radius:8px; padding:8px 12px; font-size:13px; width:100%; }
|
||||
input:focus, select:focus, textarea:focus { outline:none; border-color:var(--accent); }
|
||||
textarea { resize:vertical; min-height:100px; }
|
||||
button { cursor:pointer; background:#1f6feb; color:#fff; border:none; border-radius:8px; padding:8px 16px; font-size:13px; }
|
||||
button:hover { background:#1a5fd0; }
|
||||
button { cursor:pointer; background:var(--accent); color:#fff; border:none; border-radius:8px; padding:8px 16px; font-size:13px; }
|
||||
button:hover { background:var(--accent-hover); }
|
||||
button:disabled { opacity:.5; cursor:not-allowed; }
|
||||
button.secondary { background:#253245; }
|
||||
button.secondary:hover { background:#2d3e52; }
|
||||
button.danger { background:#e74c3c; }
|
||||
button.danger:hover { background:#c0392b; }
|
||||
button.secondary { background:var(--border-hi); }
|
||||
button.secondary:hover { background:var(--border-hi); }
|
||||
button.danger { background:var(--err); }
|
||||
button.danger:hover { background:var(--err); }
|
||||
|
||||
.list { flex:1; overflow-y:auto; }
|
||||
.item { background:#0f1520; border:1px solid #253245; border-radius:8px; padding:12px; margin-bottom:8px; cursor:pointer; transition:all .15s; }
|
||||
.item:hover { border-color:#1f6feb; }
|
||||
.item.active { border-color:#1f6feb; background:#111b2a; }
|
||||
.item-query { font-weight:600; color:#f39c12; margin-bottom:4px; font-size:14px; }
|
||||
.item-reason { font-size:12px; color:#8aa0b5; margin-bottom:4px; }
|
||||
.item-time { font-size:11px; color:#6c7a89; }
|
||||
.item-chat { font-size:11px; color:#1f6feb; }
|
||||
.item { background:var(--panel-2); border:1px solid var(--border-hi); border-radius:8px; padding:12px; margin-bottom:8px; cursor:pointer; transition:all .15s; }
|
||||
.item:hover { border-color:var(--accent); }
|
||||
.item.active { border-color:var(--accent); background:var(--accent-soft); }
|
||||
.item-query { font-weight:600; color:var(--warn); margin-bottom:4px; font-size:14px; }
|
||||
.item-reason { font-size:12px; color:var(--text-muted); margin-bottom:4px; }
|
||||
.item-time { font-size:11px; color:var(--text-muted); }
|
||||
.item-chat { font-size:11px; color:var(--accent); }
|
||||
|
||||
.form { flex:1; overflow-y:auto; display:flex; flex-direction:column; gap:16px; }
|
||||
.form-empty { color:#8aa0b5; text-align:center; padding:40px; }
|
||||
.form-empty { color:var(--text-muted); text-align:center; padding:40px; }
|
||||
.field { }
|
||||
.field label { display:block; font-size:12px; color:#8aa0b5; margin-bottom:4px; text-transform:uppercase; letter-spacing:.4px; }
|
||||
.field label { display:block; font-size:12px; color:var(--text-muted); margin-bottom:4px; text-transform:uppercase; letter-spacing:.4px; }
|
||||
|
||||
.actions { display:flex; gap:8px; margin-top:16px; }
|
||||
.loading { text-align:center; padding:40px; color:#8aa0b5; }
|
||||
.loading { text-align:center; padding:40px; color:var(--text-muted); }
|
||||
|
||||
.conversation-history { background:#0f1520; border:1px solid #253245; border-radius:8px; padding:12px; max-height:200px; overflow-y:auto; }
|
||||
.conversation-history { background:var(--panel-2); border:1px solid var(--border-hi); border-radius:8px; padding:12px; max-height:200px; overflow-y:auto; }
|
||||
.msg { margin-bottom:8px; padding:8px; border-radius:6px; font-size:12px; }
|
||||
.msg.user { background:#1a2a3a; border-left:3px solid #1f6feb; }
|
||||
.msg.assistant { background:#1a2535; border-left:3px solid #2ecc71; }
|
||||
.msg-role { font-size:10px; color:#8aa0b5; margin-bottom:4px; text-transform:uppercase; }
|
||||
.msg-content { color:#e7eef7; white-space:pre-wrap; }
|
||||
.msg.user { background:var(--accent-soft); border-left:3px solid var(--accent); }
|
||||
.msg.assistant { background:var(--panel-2); border-left:3px solid var(--ok); }
|
||||
.msg-role { font-size:10px; color:var(--text-muted); margin-bottom:4px; text-transform:uppercase; }
|
||||
.msg-content { color:var(--text); white-space:pre-wrap; }
|
||||
|
||||
.query-highlight { background:#f39c1230; border:1px solid #f39c12; border-radius:8px; padding:12px; margin-bottom:16px; }
|
||||
.query-highlight label { color:#f39c12; }
|
||||
.query-highlight .query { font-size:16px; font-weight:600; color:#f39c12; margin-top:4px; }
|
||||
.query-highlight { background:var(--warn)30; border:1px solid var(--warn); border-radius:8px; padding:12px; margin-bottom:16px; }
|
||||
.query-highlight label { color:var(--warn); }
|
||||
.query-highlight .query { font-size:16px; font-weight:600; color:var(--warn); margin-top:4px; }
|
||||
|
||||
.alias-section { background:#0f1520; border:1px solid #253245; border-radius:8px; padding:12px; margin-top:12px; }
|
||||
.alias-section h4 { margin:0 0 12px; font-size:13px; color:#8aa0b5; }
|
||||
.alias-section { background:var(--panel-2); border:1px solid var(--border-hi); border-radius:8px; padding:12px; margin-top:12px; }
|
||||
.alias-section h4 { margin:0 0 12px; font-size:13px; color:var(--text-muted); }
|
||||
.checkbox-row { display:flex; align-items:center; gap:8px; margin-bottom:12px; }
|
||||
.checkbox-row input[type="checkbox"] { width:auto; }
|
||||
.checkbox-row label { font-size:13px; color:#e7eef7; text-transform:none; }
|
||||
.checkbox-row label { font-size:13px; color:var(--text); text-transform:none; }
|
||||
|
||||
.product-selector { position:relative; }
|
||||
.product-dropdown {
|
||||
position:absolute; top:100%; left:0; right:0; z-index:100;
|
||||
background:#0f1520; border:1px solid #253245; border-radius:8px;
|
||||
background:var(--panel-2); border:1px solid var(--border-hi); border-radius:8px;
|
||||
max-height:200px; overflow-y:auto; display:none;
|
||||
}
|
||||
.product-dropdown.open { display:block; }
|
||||
.product-option {
|
||||
padding:8px 12px; cursor:pointer; font-size:13px; color:#e7eef7;
|
||||
padding:8px 12px; cursor:pointer; font-size:13px; color:var(--text);
|
||||
display:flex; justify-content:space-between; align-items:center;
|
||||
}
|
||||
.product-option:hover { background:#1a2535; }
|
||||
.product-option .price { font-size:11px; color:#8aa0b5; }
|
||||
.product-option:hover { background:var(--panel-2); }
|
||||
.product-option .price { font-size:11px; color:var(--text-muted); }
|
||||
|
||||
.cart-section { background:#0d2818; border:1px solid #2ecc71; border-radius:8px; padding:12px; margin-bottom:12px; }
|
||||
.cart-section h4 { margin:0 0 12px; font-size:13px; color:#2ecc71; display:flex; align-items:center; gap:8px; }
|
||||
.cart-section h4 svg { width:16px; height:16px; fill:#2ecc71; }
|
||||
.cart-section { background:var(--ok-soft); border:1px solid var(--ok); border-radius:8px; padding:12px; margin-bottom:12px; }
|
||||
.cart-section h4 { margin:0 0 12px; font-size:13px; color:var(--ok); display:flex; align-items:center; gap:8px; }
|
||||
.cart-section h4 svg { width:16px; height:16px; fill:var(--ok); }
|
||||
.cart-items-list { margin-bottom:12px; }
|
||||
.cart-item-row { display:flex; align-items:center; gap:8px; padding:8px; background:#0f1520; border-radius:6px; margin-bottom:6px; }
|
||||
.cart-item-row .name { flex:1; font-size:13px; color:#e7eef7; }
|
||||
.cart-item-row { display:flex; align-items:center; gap:8px; padding:8px; background:var(--panel-2); border-radius:6px; margin-bottom:6px; }
|
||||
.cart-item-row .name { flex:1; font-size:13px; color:var(--text); }
|
||||
.cart-item-row .qty { width:60px; text-align:center; }
|
||||
.cart-item-row .unit-select { width:80px; }
|
||||
.cart-item-row .remove-btn { background:#e74c3c; color:#fff; border:none; border-radius:4px; padding:4px 8px; cursor:pointer; font-size:11px; }
|
||||
.cart-item-row .remove-btn:hover { background:#c0392b; }
|
||||
.cart-item-row .remove-btn { background:var(--err); color:#fff; border:none; border-radius:4px; padding:4px 8px; cursor:pointer; font-size:11px; }
|
||||
.cart-item-row .remove-btn:hover { background:var(--err); }
|
||||
.add-cart-row { display:flex; gap:8px; align-items:flex-end; }
|
||||
.add-cart-row .product-selector { flex:1; }
|
||||
.add-cart-row .qty-input { width:70px; }
|
||||
.add-cart-row .unit-select { width:80px; }
|
||||
.add-cart-row button { white-space:nowrap; }
|
||||
|
||||
.no-pending { text-align:center; padding:60px 20px; color:#2ecc71; }
|
||||
.no-pending svg { width:48px; height:48px; fill:#2ecc71; margin-bottom:16px; }
|
||||
.no-pending { text-align:center; padding:60px 20px; color:var(--ok); }
|
||||
.no-pending svg { width:48px; height:48px; fill:var(--ok); margin-bottom:16px; }
|
||||
</style>
|
||||
|
||||
<div class="container">
|
||||
@@ -349,7 +349,7 @@ class TakeoversCrud extends HTMLElement {
|
||||
if (!container) return;
|
||||
|
||||
if (this.cartItemsToAdd.length === 0) {
|
||||
container.innerHTML = `<div style="font-size:12px;color:#8aa0b5;padding:8px;">Sin items agregados</div>`;
|
||||
container.innerHTML = `<div style="font-size:12px;color:var(--text-muted);padding:8px;">Sin items agregados</div>`;
|
||||
return;
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user