UNPKG

@wonderwhy-er/desktop-commander

Version:

MCP server for terminal operations and file editing

588 lines (506 loc) 11.7 kB
/* * Global UI design tokens and base element styling shared by all MCP tool apps. It establishes color, spacing, typography, and accessibility-friendly defaults. */ :root { color-scheme: light dark; /* Spec variables with light-dark() fallbacks (following customer-segmentation pattern). When a host provides --color-* via applyHostStyleVariables, the var() picks it up; otherwise the light-dark() fallback keeps the UI legible. */ --bg: transparent; --panel: var(--color-background-primary, light-dark(#ffffff, #1e1e2e)); --panel-subtle: var(--color-background-tertiary, light-dark(#f5f5f5, #2a2a3c)); --panel-muted: var(--color-background-tertiary, light-dark(#f5f5f5, #2a2a3c)); --text: var(--color-text-primary, light-dark(#1a1a2e, #e4e4ef)); --text-secondary: var(--color-text-secondary, light-dark(#4a4a5a, #a0a0b8)); --muted: var(--color-text-tertiary, light-dark(#94a3b8, #64748b)); --border: var(--color-border-primary, light-dark(#e2e8f0, #334155)); --accent: var(--color-text-info, light-dark(#2563eb, #60a5fa)); --accent-hover: var(--color-text-info, var(--accent)); --accent-soft: var(--color-background-info, var(--panel-subtle)); --focus-ring: var(--color-border-primary, var(--accent)); --shadow-sm: var(--shadow-sm, none); --success-bg: var(--color-background-success, var(--panel-subtle)); --success-border: var(--color-border-success, var(--border)); --success-text: var(--color-text-success, light-dark(#059669, #34d399)); --error-bg: var(--color-background-danger, var(--panel-subtle)); --error-border: var(--color-border-danger, var(--border)); --error-text: var(--color-text-danger, light-dark(#dc2626, #f87171)); --warning-bg: var(--color-background-warning, var(--panel-subtle)); --warning-border: var(--color-border-warning, var(--border)); --warning-text: var(--color-text-warning, light-dark(#d97706, #fbbf24)); } html { background: var(--bg); } * { box-sizing: border-box; } body { margin: 0; background: var(--bg); color: var(--text); font-family: var(--font-sans, system-ui, sans-serif); max-height: 32px; overflow: hidden; } body.dc-ready { max-height: none; overflow: auto; overflow: clip; } #app { min-height: 0; } .shell { max-width: none; margin: 0; padding: 6px; } .tool-shell.collapsed .panel { display: none; } .hidden { display: none !important; } .compact-row { display: flex; align-items: center; gap: 6px; padding: 6px 2px; font-size: 13px; color: var(--muted); line-height: 1; user-select: none; } .compact-row--ready { cursor: pointer; border-radius: 8px; transition: color 150ms ease; } .compact-row--ready:hover { color: var(--text-secondary); } .compact-row--ready:hover .compact-chevron { color: var(--text-secondary); } .compact-chevron { width: 14px; height: 14px; fill: currentColor; color: var(--muted); flex-shrink: 0; transition: transform 200ms ease, color 150ms ease; } .tool-shell.expanded .compact-chevron { transform: rotate(90deg); } .compact-label { color: inherit; } .compact-filename { color: var(--text); font-weight: 600; } .compact-row--ready .compact-label::after { content: ' · '; } .compact-row--loading { animation: fade-pulse 1.5s ease-in-out infinite; } @keyframes fade-pulse { 0%, 100% { opacity: 0.5; } 50% { opacity: 1; } } :root { --cfg-bg: var(--bg); --cfg-surface: var(--panel); --cfg-text: var(--text); --cfg-muted: var(--text-secondary); --cfg-border: var(--border); --cfg-toggle-knob: var(--panel); --cfg-toggle-knob-ring: color-mix(in srgb, var(--text) 72%, transparent); --cfg-toggle-on: var( --color-text-info, var(--color-background-info, var(--color-background-success, color-mix(in srgb, var(--accent) 72%, var(--cfg-border)))) ); } body { margin: 0; font-family: var(--font-sans, "IBM Plex Sans", "Avenir Next", "Segoe UI", sans-serif); background: var(--cfg-bg); color: var(--cfg-text); } .config-shell { max-width: none; min-height: 0; padding: 8px; opacity: 0; transform: translateY(4px); animation: cfg-fade-in 180ms ease-out forwards; } @keyframes cfg-fade-in { from { opacity: 0; transform: translateY(4px); } to { opacity: 1; transform: translateY(0); } } .config-card { margin-top: 6px; background: var(--cfg-surface); border: 1px solid color-mix(in srgb, var(--cfg-border) 50%, transparent); border-radius: 16px; overflow: hidden; } .panel-content-wrapper { padding: 10px; display: block; overflow: hidden; min-height: 0; background: inherit; } .settings-stack { display: grid; gap: 0; overflow: visible; background: inherit; } .setting-row { border-bottom: none; background: transparent; padding: 10px 4px; display: grid; grid-template-columns: minmax(0, 1fr) auto; gap: 12px; align-items: center; } .setting-row + .setting-row { border-top: 1px solid color-mix(in srgb, var(--cfg-border) 40%, transparent); } .setting-info h3 { margin: 0; font-size: 14px; font-weight: 600; } .setting-info p { margin: 2px 0 0; font-size: 12px; color: var(--cfg-muted); line-height: 1.45; } .setting-info .setting-summary { margin-top: 6px; font-size: 11px; color: var(--cfg-muted); font-weight: 500; } .setting-control { min-width: 180px; justify-self: end; display: flex; justify-content: flex-end; align-items: center; gap: 8px; } .setting-inline-input { width: 120px; box-sizing: border-box; border: 1px solid var(--cfg-border); border-radius: 10px; padding: 8px 10px; font: inherit; font-size: 13px; color: var(--cfg-text); background: transparent; } .setting-inline-action { border: 1px solid var(--cfg-border); background: transparent; color: var(--cfg-text); border-radius: 10px; padding: 7px 12px; font: inherit; font-size: 12px; cursor: pointer; } .setting-inline-select { width: 120px; box-sizing: border-box; border: 1px solid var(--cfg-border); border-radius: 10px; padding: 8px 10px; font: inherit; font-size: 13px; color: var(--cfg-text); background: transparent; } .setting-shell-control { display: grid; gap: 6px; justify-items: end; } .setting-shell-custom { width: 120px; } .hidden { display: none; } .config-tooltip[hidden] { display: none; } .config-tooltip { position: fixed; right: 12px; bottom: 12px; z-index: 40; max-width: min(420px, calc(100vw - 24px)); padding: 8px 10px; border-radius: 10px; border: 1px solid color-mix(in srgb, var(--cfg-border) 70%, transparent); background: color-mix(in srgb, var(--panel) 90%, var(--cfg-border)); color: var(--cfg-text); font-size: 12px; line-height: 1.35; box-shadow: 0 10px 30px color-mix(in srgb, var(--cfg-border) 26%, transparent); } .config-tooltip--error { border-color: color-mix(in srgb, var(--error-text) 55%, var(--cfg-border)); background: color-mix(in srgb, var(--error-text) 10%, var(--panel)); } .config-tooltip--success { border-color: color-mix(in srgb, var(--success-text) 55%, var(--cfg-border)); background: color-mix(in srgb, var(--success-text) 8%, var(--panel)); } .setting-inline-static { font-size: 12px; color: var(--cfg-muted); } .setting-switch { display: inline-flex; align-items: center; position: relative; width: 40px; height: 24px; cursor: pointer; } .setting-switch input { position: absolute; inset: 0; width: 100%; height: 100%; opacity: 0; pointer-events: auto; cursor: pointer; } .array-modal[hidden] { display: none; } .array-modal { position: fixed; inset: 0; background: rgba(0, 0, 0, 0.24); display: grid; place-items: center; z-index: 20; } .array-modal-card { width: min(760px, calc(100vw - 32px)); max-height: min(88vh, 900px); background: var(--panel); border: 1px solid var(--cfg-border); border-radius: 14px; padding: 12px; box-sizing: border-box; display: grid; grid-template-rows: auto auto auto auto minmax(0, 1fr); gap: 8px; overflow: hidden; } .array-modal-card header { display: flex; align-items: center; justify-content: space-between; } .array-modal-card header h3 { margin: 0; font-size: 14px; } .array-modal-description { margin: 0; font-size: 12px; line-height: 1.4; color: var(--cfg-muted); } .array-modal-hint { margin: 0; font-size: 11px; line-height: 1.35; color: var(--cfg-muted); } .array-modal-actions { display: flex; align-items: center; gap: 6px; } .array-modal-card header button { border: 1px solid var(--cfg-border); background: transparent; color: var(--cfg-text); border-radius: 8px; width: 30px; height: 30px; padding: 0; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; } .array-modal-card header button svg { width: 14px; height: 14px; fill: none; stroke: currentcolor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; } .array-modal-error { margin: 0; font-size: 12px; line-height: 1.35; color: var(--error-text); } .array-modal-list { display: grid; gap: 8px; min-height: 0; overflow: auto; } .array-modal-row { display: flex; align-items: center; gap: 8px; } .array-modal-row input { flex: 1; min-width: 0; box-sizing: border-box; border: 1px solid var(--cfg-border); border-radius: 9px; padding: 8px 10px; background: transparent; color: var(--cfg-text); font: inherit; font-size: 13px; } .array-modal-item-remove { border: 1px solid var(--cfg-border); background: transparent; color: var(--cfg-text); border-radius: 8px; width: 30px; height: 30px; padding: 0; display: inline-flex; align-items: center; justify-content: center; cursor: pointer; } .array-modal-item-remove svg { width: 14px; height: 14px; fill: none; stroke: currentcolor; stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; } .config-boolean-slider { width: 40px; height: 24px; border-radius: 999px; background: color-mix(in srgb, var(--cfg-border) 80%, transparent); position: relative; transition: background 150ms ease; } .config-boolean-slider::after { content: ''; width: 18px; height: 18px; border-radius: 50%; background: var(--cfg-toggle-knob); border: 1px solid var(--cfg-toggle-knob-ring); box-sizing: border-box; position: absolute; top: 3px; left: 3px; transition: transform 150ms ease; } .setting-switch input:checked + .config-boolean-slider { background: var(--cfg-toggle-on); } .setting-switch input:checked + .config-boolean-slider::after { transform: translateX(16px); } .config-shell.host-framed { max-width: none; min-height: 0; padding: 0; background: var(--cfg-surface); opacity: 1; transform: none; animation: none; } .config-shell.host-framed .config-card { margin-top: 0; border: none; border-radius: 0; background: var(--cfg-surface); box-shadow: none; padding: 0; } .config-shell.host-framed .panel-content-wrapper { padding: 6px 0; } .config-shell.host-framed .compact-row { display: none; } .config-shell.compact { min-height: 0; } @media (max-width: 640px) { .config-shell { padding: 12px; min-height: 0; } .panel-content-wrapper { padding: 12px; } .setting-row { grid-template-columns: 1fr; align-items: start; gap: 8px; } .setting-control { justify-self: stretch; justify-content: flex-start; min-width: 0; } .setting-inline-input, .setting-inline-select, .setting-shell-custom { width: 100%; } .array-modal-card { width: calc(100vw - 24px); max-height: calc(100vh - 24px); } }