@hileeon/mcc 0.1.9 → 0.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +6 -1
- package/dist/accounts/store.d.ts +11 -0
- package/dist/accounts/store.d.ts.map +1 -1
- package/dist/accounts/store.js.map +1 -1
- package/dist/commands/launch.d.ts.map +1 -1
- package/dist/commands/launch.js +8 -4
- package/dist/commands/launch.js.map +1 -1
- package/dist/commands/mcp.d.ts +11 -0
- package/dist/commands/mcp.d.ts.map +1 -1
- package/dist/commands/mcp.js +179 -1
- package/dist/commands/mcp.js.map +1 -1
- package/dist/commands/profile-test.d.ts +17 -0
- package/dist/commands/profile-test.d.ts.map +1 -0
- package/dist/commands/profile-test.js +188 -0
- package/dist/commands/profile-test.js.map +1 -0
- package/dist/core/model-router.d.ts.map +1 -1
- package/dist/core/model-router.js +31 -1
- package/dist/core/model-router.js.map +1 -1
- package/dist/dashboard/server.js +118 -30
- package/dist/dashboard/server.js.map +1 -1
- package/dist/mcc.js +15 -0
- package/dist/mcc.js.map +1 -1
- package/dist/mcp/external-registry.d.ts +6 -3
- package/dist/mcp/external-registry.d.ts.map +1 -1
- package/dist/mcp/external-registry.js.map +1 -1
- package/dist/mcp/installer.d.ts.map +1 -1
- package/dist/mcp/installer.js +25 -10
- package/dist/mcp/installer.js.map +1 -1
- package/dist/mcp/mcp-config.d.ts +17 -3
- package/dist/mcp/mcp-config.d.ts.map +1 -1
- package/dist/mcp/mcp-config.js +38 -19
- package/dist/mcp/mcp-config.js.map +1 -1
- package/dist/mcp/registry.d.ts +4 -2
- package/dist/mcp/registry.d.ts.map +1 -1
- package/dist/mcp/registry.js.map +1 -1
- package/dist/proxy/proxy-daemon.d.ts +1 -1
- package/dist/proxy/proxy-daemon.d.ts.map +1 -1
- package/dist/proxy/proxy-daemon.js +10 -5
- package/dist/proxy/proxy-daemon.js.map +1 -1
- package/dist/proxy/proxy-entry.js +6 -1
- package/dist/proxy/proxy-entry.js.map +1 -1
- package/dist/proxy/proxy-paths.d.ts +1 -0
- package/dist/proxy/proxy-paths.d.ts.map +1 -1
- package/dist/proxy/proxy-paths.js.map +1 -1
- package/dist/proxy/proxy-server.d.ts +1 -0
- package/dist/proxy/proxy-server.d.ts.map +1 -1
- package/dist/proxy/proxy-server.js +84 -2
- package/dist/proxy/proxy-server.js.map +1 -1
- package/dist/shared/config.d.ts +1 -0
- package/dist/shared/config.d.ts.map +1 -1
- package/dist/shared/config.js +1 -0
- package/dist/shared/config.js.map +1 -1
- package/dist/shared/provider-preset-catalog.d.ts +2 -0
- package/dist/shared/provider-preset-catalog.d.ts.map +1 -1
- package/dist/shared/provider-preset-catalog.js +31 -22
- package/dist/shared/provider-preset-catalog.js.map +1 -1
- package/dist/shared/test-image.d.ts +15 -0
- package/dist/shared/test-image.d.ts.map +1 -0
- package/dist/shared/test-image.js +89 -0
- package/dist/shared/test-image.js.map +1 -0
- package/dist/ui/assets/{index-ClqmrjNk.js → index-7kowlJw9.js} +7 -7
- package/dist/ui/assets/{index-CwMwQ-Z4.css → index-DnC-lskL.css} +1 -1
- package/dist/ui/index.html +2 -2
- package/dist/update.d.ts +16 -5
- package/dist/update.d.ts.map +1 -1
- package/dist/update.js +149 -37
- package/dist/update.js.map +1 -1
- package/lib/mcp-hooks/image-analysis-runtime.cjs +58 -5
- package/lib/shared/logger.cjs +5 -1
- package/package.json +2 -4
|
@@ -1 +1 @@
|
|
|
1
|
-
:root{--paper-50: #fbf7ee;--paper-100: #f5efe1;--paper-200: #ede5d2;--paper-300: #ddd2b6;--paper-400: #c4b896;--ink-50: #f6f4ee;--ink-200: #a09c92;--ink-400: #5e5b54;--ink-600: #2c2b27;--ink-900: #16161a;--arcade-tangerine: #ff8a3d;--arcade-tangerine-soft: #ffd9bc;--arcade-tangerine-ink: #6b2f00;--arcade-lagoon: #2bbfd9;--arcade-lagoon-soft: #bff0f8;--arcade-lagoon-ink: #0a4a57;--arcade-leaf: #5fb84f;--arcade-leaf-soft: #cdebc4;--arcade-leaf-ink: #1d4a17;--arcade-hibiscus: #ff5470;--arcade-hibiscus-soft: #ffd1da;--arcade-hibiscus-ink: #71132a;--arcade-sunshine: #ffc83a;--arcade-sunshine-soft: #ffe9a8;--arcade-sunshine-ink: #6b4500;--arcade-lilac: #a875ff;--arcade-lilac-soft: #e0d0ff;--arcade-lilac-ink: #391a72;--white: #ffffff;--black: #000000;--pixel-grid: rgba(22, 22, 26, .06);--space-0: 0px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--font-2xs: 10px;--font-xs: 11px;--font-sm: 13px;--font-base: 14px;--font-md: 15px;--font-lg: 18px;--font-xl: 22px;--font-2xl: 28px;--font-3xl: 38px;--radius-none: 0px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-black: 800;--font-sans: "Inter Tight", -apple-system, BlinkMacSystemFont, "SF Pro Text", "PingFang SC", "Hiragino Sans GB", system-ui, sans-serif;--font-rounded: ui-rounded, "SF Pro Rounded", "Plus Jakarta Sans", "Inter Tight", -apple-system, sans-serif;--font-pixel: "Silkscreen", "VT323", "Press Start 2P", ui-monospace, monospace;--font-mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--shadow-soft-1: 0 1px 1px rgba(22, 22, 26, .04), 0 4px 12px rgba(22, 22, 26, .06);--shadow-soft-2: 0 1px 1px rgba(22, 22, 26, .05), 0 12px 28px rgba(22, 22, 26, .1);--shadow-soft-3: 0 2px 4px rgba(22, 22, 26, .06), 0 24px 48px rgba(22, 22, 26, .14);--shadow-pixel-1: 2px 2px 0 0 var(--ink-900);--shadow-pixel-2: 4px 4px 0 0 var(--ink-900);--shadow-pixel-3: 6px 6px 0 0 var(--ink-900);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .7), inset 0 -1px 0 rgba(22, 22, 26, .06);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--dur-fast: .12s;--dur-base: .2s;--dur-slow: .32s}:root{--color-bg-base: var(--paper-100);--color-bg-surface: var(--paper-50);--color-bg-surface-muted: var(--paper-200);--color-bg-overlay: rgb(22 22 26 / .42);--color-bg-elevated: var(--white);--color-text-primary: var(--ink-900);--color-text-secondary: var(--ink-600);--color-text-muted: var(--ink-400);--color-text-faint: var(--ink-200);--color-text-inverse: var(--paper-50);--color-text-mono: var(--ink-900);--color-accent: var(--arcade-tangerine);--color-accent-hover: #f0782b;--color-accent-soft: var(--arcade-tangerine-soft);--color-accent-on-soft: var(--arcade-tangerine-ink);--color-accent-foreground: var(--ink-900);--color-success: var(--arcade-leaf);--color-success-soft: var(--arcade-leaf-soft);--color-success-on-soft: var(--arcade-leaf-ink);--color-success-dot: var(--arcade-leaf);--color-warning: var(--arcade-sunshine);--color-warning-soft: var(--arcade-sunshine-soft);--color-warning-on-soft: var(--arcade-sunshine-ink);--color-warning-border: var(--arcade-sunshine);--color-danger: var(--arcade-hibiscus);--color-danger-hover: #ef3357;--color-danger-soft: var(--arcade-hibiscus-soft);--color-danger-on-soft: var(--arcade-hibiscus-ink);--color-info: var(--arcade-lagoon);--color-info-soft: var(--arcade-lagoon-soft);--color-info-on-soft: var(--arcade-lagoon-ink);--color-special: var(--arcade-lilac);--color-special-soft: var(--arcade-lilac-soft);--color-special-on-soft: var(--arcade-lilac-ink);--color-border: var(--paper-300);--color-border-muted: var(--paper-200);--color-border-strong: var(--ink-900);--color-focus-ring: var(--arcade-lagoon);--space-inline: var(--space-2);--space-block: var(--space-4);--space-section: var(--space-6);--radius-control: var(--radius-md);--radius-card: var(--radius-lg);--radius-pill: var(--radius-full)}:root{--app-bg: var(--color-bg-base);--app-text: var(--color-text-primary);--card-bg: var(--color-bg-surface);--card-bg-raised: var(--color-bg-elevated);--card-border: var(--color-border-strong);--card-border-soft: var(--color-border);--card-text: var(--color-text-primary);--card-text-muted: var(--color-text-muted);--card-radius: var(--radius-card);--card-padding: var(--space-block);--card-shadow: var(--shadow-soft-1);--card-shadow-raised: var(--shadow-pixel-2);--card-shadow-press: var(--shadow-pixel-1);--button-bg: var(--color-accent);--button-bg-hover: var(--color-accent-hover);--button-text: var(--color-accent-foreground);--button-radius: var(--radius-control);--button-padding: var(--space-2) var(--space-4);--button-border: var(--ink-900);--button-shadow: var(--shadow-pixel-1);--button-shadow-hover: var(--shadow-pixel-2);--button-danger-bg: var(--color-danger);--button-danger-bg-hover: var(--color-danger-hover);--button-danger-text: var(--color-text-inverse);--button-ghost-text: var(--color-text-secondary);--button-ghost-hover-bg: var(--paper-200);--input-bg: var(--color-bg-elevated);--input-border: var(--color-border);--input-border-strong: var(--ink-900);--input-text: var(--color-text-primary);--input-placeholder: var(--color-text-faint);--input-radius: var(--radius-control);--input-shadow: var(--shadow-inset);--input-focus-ring: var(--color-focus-ring);--badge-bg: var(--color-bg-surface-muted);--badge-text: var(--color-text-muted);--badge-radius: var(--radius-pill);--badge-success-bg: var(--color-success-soft);--badge-success-text: var(--color-success-on-soft);--badge-warning-bg: var(--color-warning-soft);--badge-warning-text: var(--color-warning-on-soft);--badge-info-bg: var(--color-info-soft);--badge-info-text: var(--color-info-on-soft);--badge-special-bg: var(--color-special-soft);--badge-special-text: var(--color-special-on-soft);--status-online-text: var(--color-success-on-soft);--status-online-dot: var(--color-success-dot);--status-offline-text: var(--color-danger-on-soft);--status-offline-dot: var(--color-danger);--banner-warning-bg: var(--color-warning-soft);--banner-warning-border: var(--color-warning-border);--banner-warning-text: var(--color-warning-on-soft);--banner-success-bg: var(--color-success-soft);--banner-success-border: var(--color-success);--banner-success-text: var(--color-success-on-soft);--banner-error-bg: var(--color-danger-soft);--banner-error-border: var(--color-danger);--banner-error-text: var(--color-danger-on-soft);--banner-info-bg: var(--color-info-soft);--banner-info-border: var(--color-info);--banner-info-text: var(--color-info-on-soft);--code-text: var(--color-text-mono);--code-text-faint: var(--color-text-faint);--code-bg: var(--paper-200);--tabs-bg: transparent;--tabs-trigger-text: var(--color-text-secondary);--tabs-trigger-active-bg: var(--color-bg-elevated);--tabs-trigger-active-text: var(--color-text-primary);--tabs-trigger-active-border: var(--ink-900);--sheet-bg: var(--color-bg-elevated);--sheet-overlay: var(--color-bg-overlay)}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter Tight,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,ui-monospace,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 40 53% 92%;--foreground: 240 10% 9%;--card: 38 56% 96%;--card-foreground: 240 10% 9%;--popover: 38 56% 96%;--popover-foreground: 240 10% 9%;--primary: 23 100% 62%;--primary-foreground: 240 10% 9%;--secondary: 40 39% 82%;--secondary-foreground: 240 10% 9%;--muted: 40 39% 88%;--muted-foreground: 36 5% 36%;--accent: 40 39% 86%;--accent-foreground: 240 10% 9%;--destructive: 350 100% 66%;--destructive-foreground: 0 0% 100%;--border: 38 26% 78%;--input: 38 26% 78%;--ring: 188 70% 51%;--radius: .875rem}html,body,#root{height:100%}*{border-color:hsl(var(--border))}body{background:var(--app-bg);color:var(--app-text);font-family:var(--font-sans);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{background-color:var(--paper-100);background-image:radial-gradient(ellipse 80% 60% at 12% 8%,rgba(255,138,61,.16),transparent 60%),radial-gradient(ellipse 70% 60% at 92% 18%,rgba(43,191,217,.16),transparent 60%),radial-gradient(ellipse 65% 55% at 80% 95%,rgba(168,117,255,.12),transparent 60%),linear-gradient(var(--pixel-grid) 1px,transparent 1px),linear-gradient(90deg,var(--pixel-grid) 1px,transparent 1px);background-size:auto,auto,auto,20px 20px,20px 20px;background-position:0 0,0 0,0 0,-1px -1px,-1px -1px;background-attachment:fixed}::-moz-selection{background:var(--arcade-sunshine);color:var(--ink-900)}::selection{background:var(--arcade-sunshine);color:var(--ink-900)}.container{width:100%;margin-right:auto;margin-left:auto;padding-right:2rem;padding-left:2rem}@media(min-width:1400px){.container{max-width:1400px}}.font-pixel{font-family:var(--font-pixel);letter-spacing:.02em}.font-rounded{font-family:var(--font-rounded);letter-spacing:-.01em}.font-mono{font-family:var(--font-mono)}.arcade-card{background:var(--card-bg);border:1.5px solid var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow-raised);transition:box-shadow var(--dur-base) var(--ease-out-quart),transform var(--dur-base) var(--ease-out-quart)}.arcade-card-soft{background:var(--card-bg);border:1px solid var(--card-border-soft);border-radius:var(--card-radius);box-shadow:var(--card-shadow)}.arcade-card-press:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-pixel-3)}.arcade-card-press:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--ink-900)}.arcade-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--button-padding);font-family:var(--font-rounded);font-weight:var(--weight-semibold);font-size:var(--font-sm);color:var(--button-text);background:var(--button-bg);border:1.5px solid var(--button-border);border-radius:var(--button-radius);box-shadow:var(--button-shadow);cursor:pointer;transition:transform var(--dur-fast) var(--ease-out-quart),box-shadow var(--dur-fast) var(--ease-out-quart),background var(--dur-fast) var(--ease-out-quart);-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap}.arcade-btn:hover{background:var(--button-bg-hover);transform:translate(-1px,-1px);box-shadow:var(--button-shadow-hover)}.arcade-btn:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--ink-900)}.arcade-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.arcade-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:var(--button-shadow)}.arcade-btn-ghost{background:transparent;border-color:transparent;box-shadow:none;color:var(--button-ghost-text)}.arcade-btn-ghost:hover{background:var(--button-ghost-hover-bg);transform:none;box-shadow:none}.arcade-btn-ghost:active{transform:none;box-shadow:none}.arcade-btn-outline{background:var(--color-bg-elevated);color:var(--ink-900)}.arcade-btn-outline:hover{background:var(--paper-100)}.arcade-btn-danger{background:var(--button-danger-bg);color:var(--button-danger-text)}.arcade-btn-danger:hover{background:var(--button-danger-bg-hover)}.arcade-btn-sm{font-size:var(--font-xs);padding:var(--space-1) var(--space-3)}.pixel-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px 8px;font-family:var(--font-pixel);font-size:var(--font-2xs);letter-spacing:.06em;text-transform:uppercase;background:var(--badge-bg);color:var(--badge-text);border-radius:var(--radius-sm);border:1px solid var(--color-border);line-height:1.4}.pixel-chip-success{background:var(--badge-success-bg);color:var(--badge-success-text);border-color:var(--color-success)}.pixel-chip-info{background:var(--badge-info-bg);color:var(--badge-info-text);border-color:var(--arcade-lagoon)}.pixel-chip-tangerine{background:var(--arcade-tangerine-soft);color:var(--arcade-tangerine-ink);border-color:var(--arcade-tangerine)}.arcade-input{width:100%;background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--input-radius);padding:var(--space-2) var(--space-3);font-family:var(--font-sans);font-size:var(--font-sm);color:var(--input-text);transition:border-color var(--dur-fast) var(--ease-out-quart),box-shadow var(--dur-fast) var(--ease-out-quart)}.arcade-input::-moz-placeholder{color:var(--input-placeholder)}.arcade-input::placeholder{color:var(--input-placeholder)}.arcade-input:focus,.arcade-input:focus-visible{outline:none;border-color:var(--input-border-strong);box-shadow:var(--shadow-pixel-1)}.arcade-input:disabled{background:var(--paper-200);color:var(--color-text-muted)}.status-online{color:var(--status-online-text)}.status-online-dot{background:var(--status-online-dot);box-shadow:0 0 0 3px #5fb84f33;animation:pulse-online 2s ease-in-out infinite}.status-offline{color:var(--status-offline-text)}.status-offline-dot{background:var(--status-offline-dot);box-shadow:0 0 0 3px #ff547033}@keyframes pulse-online{0%,to{box-shadow:0 0 0 3px #5fb84f2e}50%{box-shadow:0 0 0 6px #5fb84f0f}}.banner-warning{background:var(--banner-warning-bg);border:1.5px solid var(--banner-warning-border);color:var(--banner-warning-text);border-radius:var(--radius-md)}.banner-success{background:var(--banner-success-bg);border:1.5px solid var(--banner-success-border);color:var(--banner-success-text);border-radius:var(--radius-md)}.banner-error{background:var(--banner-error-bg);border:1.5px solid var(--banner-error-border);color:var(--banner-error-text);border-radius:var(--radius-md)}.code-mono{font-family:var(--font-mono);color:var(--code-text)}.arcade-tabs-list{display:inline-flex;gap:var(--space-1);padding:var(--space-1);background:var(--color-bg-surface-muted);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-inset)}.arcade-tabs-trigger{padding:var(--space-2) var(--space-4);font-family:var(--font-rounded);font-weight:var(--weight-semibold);font-size:var(--font-sm);color:var(--tabs-trigger-text);border-radius:var(--radius-lg);transition:all var(--dur-base) var(--ease-out-quart);cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-2)}.arcade-tabs-trigger[data-state=active]{background:var(--tabs-trigger-active-bg);color:var(--tabs-trigger-active-text);box-shadow:var(--shadow-soft-1)}.arcade-tabs-trigger:hover{color:var(--tabs-trigger-active-text)}.provider-halo{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-lg);border:1.5px solid var(--ink-900);background:var(--paper-50);box-shadow:var(--shadow-pixel-1);flex-shrink:0}.provider-halo-sm{width:40px;height:40px;border-radius:var(--radius-md)}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--sheet-overlay);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:40;animation:fade-in var(--dur-base) var(--ease-out-quart)}.sheet-panel{position:fixed;z-index:50;background:var(--sheet-bg);border:1.5px solid var(--ink-900);border-radius:var(--radius-2xl);box-shadow:var(--shadow-pixel-3),var(--shadow-soft-3)}.sheet-panel-center{top:50%;left:50%;transform:translate(-50%,-50%);width:min(92vw,540px);max-height:88vh;overflow-y:auto;animation:sheet-pop var(--dur-base) var(--ease-spring)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes sheet-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.92)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.crt-scanline{position:relative;overflow:hidden}.crt-scanline:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:repeating-linear-gradient(0deg,rgba(22,22,26,.05) 0,rgba(22,22,26,.05) 1px,transparent 1px,transparent 4px);opacity:.4}.section-kicker{font-family:var(--font-pixel);font-size:var(--font-2xs);letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted)}.section-title{font-family:var(--font-rounded);font-weight:var(--weight-bold);font-size:var(--font-2xl);line-height:1.1;letter-spacing:-.02em;color:var(--color-text-primary)}.section-sub{font-family:var(--font-sans);font-size:var(--font-sm);color:var(--color-text-muted);line-height:1.5}.pointer-events-none{pointer-events:none}.absolute{position:absolute}.relative{position:relative}.inset-x-0{left:0;right:0}.-bottom-5{bottom:-1.25rem}.bottom-0{bottom:0}.left-0{left:0}.left-3{left:.75rem}.left-4{left:1rem}.right-0{right:0}.right-1\.5{right:.375rem}.right-2{right:.5rem}.right-3{right:.75rem}.top-0{top:0}.top-1\/2{top:50%}.top-3{top:.75rem}.z-20{z-index:20}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-1{margin-left:.25rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-6{margin-top:1.5rem}.mt-auto{margin-top:auto}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-14{height:3.5rem}.h-2{height:.5rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-9{height:2.25rem}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-screen{height:100vh}.max-h-48{max-height:12rem}.max-h-96{max-height:24rem}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-2{width:.5rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-9{width:2.25rem}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-6xl{max-width:72rem}.max-w-lg{max-width:32rem}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-t-\[26px\]{border-top-left-radius:26px;border-top-right-radius:26px}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-arcade-hibiscus{border-color:var(--arcade-hibiscus)}.border-arcade-leaf{border-color:var(--arcade-leaf)}.border-ink-900{border-color:var(--ink-900)}.border-input{border-color:hsl(var(--input))}.border-paper-300{border-color:var(--paper-300)}.border-transparent{border-color:transparent}.bg-arcade-lagoon{background-color:var(--arcade-lagoon)}.bg-arcade-sunshine{background-color:var(--arcade-sunshine)}.bg-background{background-color:hsl(var(--background))}.bg-paper-400{background-color:var(--paper-400)}.bg-paper-50{background-color:var(--paper-50)}.bg-transparent{background-color:transparent}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-10{padding:2.5rem}.p-2\.5{padding:.625rem}.p-3\.5{padding:.875rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pb-16{padding-bottom:4rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-8{padding-bottom:2rem}.pl-2{padding-left:.5rem}.pl-9{padding-left:2.25rem}.pr-10{padding-right:2.5rem}.pr-8{padding-right:2rem}.pt-1{padding-top:.25rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.pt-7{padding-top:1.75rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:JetBrains Mono,ui-monospace,monospace}.font-pixel{font-family:Silkscreen,VT323,monospace}.font-rounded{font-family:Plus Jakarta Sans,ui-rounded,sans-serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.leading-none{line-height:1}.leading-tight{line-height:1.25}.tracking-\[0\.22em\]{letter-spacing:.22em}.tracking-\[0\.3em\]{letter-spacing:.3em}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-arcade-hibiscus{color:var(--arcade-hibiscus)}.text-arcade-lagoon{color:var(--arcade-lagoon)}.text-arcade-leaf{color:var(--arcade-leaf)}.text-arcade-sunshine{color:var(--arcade-sunshine)}.text-current{color:currentColor}.text-ink-400{color:var(--ink-400)}.text-ink-600{color:var(--ink-600)}.text-ink-900{color:var(--ink-900)}.text-muted-foreground{color:hsl(var(--muted-foreground))}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-pixel1{--tw-shadow: var(--shadow-pixel-1);--tw-shadow-colored: var(--shadow-pixel-1);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-0{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.pixelated{image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;shape-rendering:crispEdges}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.last\:border-b-0:last-child{border-bottom-width:0px}.hover\:border-ink-400:hover{border-color:var(--ink-400)}.hover\:border-ink-900:hover{border-color:var(--ink-900)}.hover\:bg-paper-200:hover{background-color:var(--paper-200)}.hover\:text-arcade-hibiscus:hover{color:var(--arcade-hibiscus)}.hover\:text-ink-900:hover{color:var(--ink-900)}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-pixel1:hover{--tw-shadow: var(--shadow-pixel-1);--tw-shadow-colored: var(--shadow-pixel-1);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--ring))}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: hsl(var(--background))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:translate-x-0\.5{--tw-translate-x: .125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:translate-x-4[data-state=checked]{--tw-translate-x: 1rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked]{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:hsl(var(--primary))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:hsl(var(--input))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}@media(min-width:640px){.sm\:inline{display:inline}.sm\:w-72{width:18rem}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-end{align-items:flex-end}.sm\:justify-between{justify-content:space-between}.sm\:px-8{padding-left:2rem;padding-right:2rem}.sm\:pt-10{padding-top:2.5rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media(min-width:1024px){.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:col-span-3{grid-column:span 3 / span 3}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}
|
|
1
|
+
:root{--paper-50: #fbf7ee;--paper-100: #f5efe1;--paper-200: #ede5d2;--paper-300: #ddd2b6;--paper-400: #c4b896;--ink-50: #f6f4ee;--ink-200: #a09c92;--ink-400: #5e5b54;--ink-600: #2c2b27;--ink-900: #16161a;--arcade-tangerine: #ff8a3d;--arcade-tangerine-soft: #ffd9bc;--arcade-tangerine-ink: #6b2f00;--arcade-lagoon: #2bbfd9;--arcade-lagoon-soft: #bff0f8;--arcade-lagoon-ink: #0a4a57;--arcade-leaf: #5fb84f;--arcade-leaf-soft: #cdebc4;--arcade-leaf-ink: #1d4a17;--arcade-hibiscus: #ff5470;--arcade-hibiscus-soft: #ffd1da;--arcade-hibiscus-ink: #71132a;--arcade-sunshine: #ffc83a;--arcade-sunshine-soft: #ffe9a8;--arcade-sunshine-ink: #6b4500;--arcade-lilac: #a875ff;--arcade-lilac-soft: #e0d0ff;--arcade-lilac-ink: #391a72;--white: #ffffff;--black: #000000;--pixel-grid: rgba(22, 22, 26, .06);--space-0: 0px;--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-7: 28px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--space-16: 64px;--font-2xs: 10px;--font-xs: 11px;--font-sm: 13px;--font-base: 14px;--font-md: 15px;--font-lg: 18px;--font-xl: 22px;--font-2xl: 28px;--font-3xl: 38px;--radius-none: 0px;--radius-xs: 4px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-2xl: 28px;--radius-full: 9999px;--weight-regular: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--weight-black: 800;--font-sans: "Inter Tight", -apple-system, BlinkMacSystemFont, "SF Pro Text", "PingFang SC", "Hiragino Sans GB", system-ui, sans-serif;--font-rounded: ui-rounded, "SF Pro Rounded", "Plus Jakarta Sans", "Inter Tight", -apple-system, sans-serif;--font-pixel: "Silkscreen", "VT323", "Press Start 2P", ui-monospace, monospace;--font-mono: "JetBrains Mono", "IBM Plex Mono", ui-monospace, SFMono-Regular, Menlo, monospace;--shadow-soft-1: 0 1px 1px rgba(22, 22, 26, .04), 0 4px 12px rgba(22, 22, 26, .06);--shadow-soft-2: 0 1px 1px rgba(22, 22, 26, .05), 0 12px 28px rgba(22, 22, 26, .1);--shadow-soft-3: 0 2px 4px rgba(22, 22, 26, .06), 0 24px 48px rgba(22, 22, 26, .14);--shadow-pixel-1: 2px 2px 0 0 var(--ink-900);--shadow-pixel-2: 4px 4px 0 0 var(--ink-900);--shadow-pixel-3: 6px 6px 0 0 var(--ink-900);--shadow-inset: inset 0 1px 0 rgba(255, 255, 255, .7), inset 0 -1px 0 rgba(22, 22, 26, .06);--ease-out-quart: cubic-bezier(.25, 1, .5, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--dur-fast: .12s;--dur-base: .2s;--dur-slow: .32s}:root{--color-bg-base: var(--paper-100);--color-bg-surface: var(--paper-50);--color-bg-surface-muted: var(--paper-200);--color-bg-overlay: rgb(22 22 26 / .42);--color-bg-elevated: var(--white);--color-text-primary: var(--ink-900);--color-text-secondary: var(--ink-600);--color-text-muted: var(--ink-400);--color-text-faint: var(--ink-200);--color-text-inverse: var(--paper-50);--color-text-mono: var(--ink-900);--color-accent: var(--arcade-tangerine);--color-accent-hover: #f0782b;--color-accent-soft: var(--arcade-tangerine-soft);--color-accent-on-soft: var(--arcade-tangerine-ink);--color-accent-foreground: var(--ink-900);--color-success: var(--arcade-leaf);--color-success-soft: var(--arcade-leaf-soft);--color-success-on-soft: var(--arcade-leaf-ink);--color-success-dot: var(--arcade-leaf);--color-warning: var(--arcade-sunshine);--color-warning-soft: var(--arcade-sunshine-soft);--color-warning-on-soft: var(--arcade-sunshine-ink);--color-warning-border: var(--arcade-sunshine);--color-danger: var(--arcade-hibiscus);--color-danger-hover: #ef3357;--color-danger-soft: var(--arcade-hibiscus-soft);--color-danger-on-soft: var(--arcade-hibiscus-ink);--color-info: var(--arcade-lagoon);--color-info-soft: var(--arcade-lagoon-soft);--color-info-on-soft: var(--arcade-lagoon-ink);--color-special: var(--arcade-lilac);--color-special-soft: var(--arcade-lilac-soft);--color-special-on-soft: var(--arcade-lilac-ink);--color-border: var(--paper-300);--color-border-muted: var(--paper-200);--color-border-strong: var(--ink-900);--color-focus-ring: var(--arcade-lagoon);--space-inline: var(--space-2);--space-block: var(--space-4);--space-section: var(--space-6);--radius-control: var(--radius-md);--radius-card: var(--radius-lg);--radius-pill: var(--radius-full)}:root{--app-bg: var(--color-bg-base);--app-text: var(--color-text-primary);--card-bg: var(--color-bg-surface);--card-bg-raised: var(--color-bg-elevated);--card-border: var(--color-border-strong);--card-border-soft: var(--color-border);--card-text: var(--color-text-primary);--card-text-muted: var(--color-text-muted);--card-radius: var(--radius-card);--card-padding: var(--space-block);--card-shadow: var(--shadow-soft-1);--card-shadow-raised: var(--shadow-pixel-2);--card-shadow-press: var(--shadow-pixel-1);--button-bg: var(--color-accent);--button-bg-hover: var(--color-accent-hover);--button-text: var(--color-accent-foreground);--button-radius: var(--radius-control);--button-padding: var(--space-2) var(--space-4);--button-border: var(--ink-900);--button-shadow: var(--shadow-pixel-1);--button-shadow-hover: var(--shadow-pixel-2);--button-danger-bg: var(--color-danger);--button-danger-bg-hover: var(--color-danger-hover);--button-danger-text: var(--color-text-inverse);--button-ghost-text: var(--color-text-secondary);--button-ghost-hover-bg: var(--paper-200);--input-bg: var(--color-bg-elevated);--input-border: var(--color-border);--input-border-strong: var(--ink-900);--input-text: var(--color-text-primary);--input-placeholder: var(--color-text-faint);--input-radius: var(--radius-control);--input-shadow: var(--shadow-inset);--input-focus-ring: var(--color-focus-ring);--badge-bg: var(--color-bg-surface-muted);--badge-text: var(--color-text-muted);--badge-radius: var(--radius-pill);--badge-success-bg: var(--color-success-soft);--badge-success-text: var(--color-success-on-soft);--badge-warning-bg: var(--color-warning-soft);--badge-warning-text: var(--color-warning-on-soft);--badge-info-bg: var(--color-info-soft);--badge-info-text: var(--color-info-on-soft);--badge-special-bg: var(--color-special-soft);--badge-special-text: var(--color-special-on-soft);--status-online-text: var(--color-success-on-soft);--status-online-dot: var(--color-success-dot);--status-offline-text: var(--color-danger-on-soft);--status-offline-dot: var(--color-danger);--banner-warning-bg: var(--color-warning-soft);--banner-warning-border: var(--color-warning-border);--banner-warning-text: var(--color-warning-on-soft);--banner-success-bg: var(--color-success-soft);--banner-success-border: var(--color-success);--banner-success-text: var(--color-success-on-soft);--banner-error-bg: var(--color-danger-soft);--banner-error-border: var(--color-danger);--banner-error-text: var(--color-danger-on-soft);--banner-info-bg: var(--color-info-soft);--banner-info-border: var(--color-info);--banner-info-text: var(--color-info-on-soft);--code-text: var(--color-text-mono);--code-text-faint: var(--color-text-faint);--code-bg: var(--paper-200);--tabs-bg: transparent;--tabs-trigger-text: var(--color-text-secondary);--tabs-trigger-active-bg: var(--color-bg-elevated);--tabs-trigger-active-text: var(--color-text-primary);--tabs-trigger-active-border: var(--ink-900);--sheet-bg: var(--color-bg-elevated);--sheet-overlay: var(--color-bg-overlay)}*,:before,:after{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }::backdrop{--tw-border-spacing-x: 0;--tw-border-spacing-y: 0;--tw-translate-x: 0;--tw-translate-y: 0;--tw-rotate: 0;--tw-skew-x: 0;--tw-skew-y: 0;--tw-scale-x: 1;--tw-scale-y: 1;--tw-pan-x: ;--tw-pan-y: ;--tw-pinch-zoom: ;--tw-scroll-snap-strictness: proximity;--tw-gradient-from-position: ;--tw-gradient-via-position: ;--tw-gradient-to-position: ;--tw-ordinal: ;--tw-slashed-zero: ;--tw-numeric-figure: ;--tw-numeric-spacing: ;--tw-numeric-fraction: ;--tw-ring-inset: ;--tw-ring-offset-width: 0px;--tw-ring-offset-color: #fff;--tw-ring-color: rgb(59 130 246 / .5);--tw-ring-offset-shadow: 0 0 #0000;--tw-ring-shadow: 0 0 #0000;--tw-shadow: 0 0 #0000;--tw-shadow-colored: 0 0 #0000;--tw-blur: ;--tw-brightness: ;--tw-contrast: ;--tw-grayscale: ;--tw-hue-rotate: ;--tw-invert: ;--tw-saturate: ;--tw-sepia: ;--tw-drop-shadow: ;--tw-backdrop-blur: ;--tw-backdrop-brightness: ;--tw-backdrop-contrast: ;--tw-backdrop-grayscale: ;--tw-backdrop-hue-rotate: ;--tw-backdrop-invert: ;--tw-backdrop-opacity: ;--tw-backdrop-saturate: ;--tw-backdrop-sepia: ;--tw-contain-size: ;--tw-contain-layout: ;--tw-contain-paint: ;--tw-contain-style: }*,:before,:after{box-sizing:border-box;border-width:0;border-style:solid;border-color:#e5e7eb}:before,:after{--tw-content: ""}html,:host{line-height:1.5;-webkit-text-size-adjust:100%;-moz-tab-size:4;-o-tab-size:4;tab-size:4;font-family:Inter Tight,system-ui,sans-serif;font-feature-settings:normal;font-variation-settings:normal;-webkit-tap-highlight-color:transparent}body{margin:0;line-height:inherit}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:JetBrains Mono,ui-monospace,monospace;font-feature-settings:normal;font-variation-settings:normal;font-size:1em}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}button,input,optgroup,select,textarea{font-family:inherit;font-feature-settings:inherit;font-variation-settings:inherit;font-size:100%;font-weight:inherit;line-height:inherit;letter-spacing:inherit;color:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dl,dd,h1,h2,h3,h4,h5,h6,hr,figure,p,pre{margin:0}fieldset{margin:0;padding:0}legend{padding:0}ol,ul,menu{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::-moz-placeholder,textarea::-moz-placeholder{opacity:1;color:#9ca3af}input::placeholder,textarea::placeholder{opacity:1;color:#9ca3af}button,[role=button]{cursor:pointer}:disabled{cursor:default}img,svg,video,canvas,audio,iframe,embed,object{display:block;vertical-align:middle}img,video{max-width:100%;height:auto}[hidden]:where(:not([hidden=until-found])){display:none}:root{--background: 40 53% 92%;--foreground: 240 10% 9%;--card: 38 56% 96%;--card-foreground: 240 10% 9%;--popover: 38 56% 96%;--popover-foreground: 240 10% 9%;--primary: 23 100% 62%;--primary-foreground: 240 10% 9%;--secondary: 40 39% 82%;--secondary-foreground: 240 10% 9%;--muted: 40 39% 88%;--muted-foreground: 36 5% 36%;--accent: 40 39% 86%;--accent-foreground: 240 10% 9%;--destructive: 350 100% 66%;--destructive-foreground: 0 0% 100%;--border: 38 26% 78%;--input: 38 26% 78%;--ring: 188 70% 51%;--radius: .875rem}html,body,#root{height:100%}*{border-color:hsl(var(--border))}body{background:var(--app-bg);color:var(--app-text);font-family:var(--font-sans);font-feature-settings:"ss01","cv11";-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}body{background-color:var(--paper-100);background-image:radial-gradient(ellipse 80% 60% at 12% 8%,rgba(255,138,61,.16),transparent 60%),radial-gradient(ellipse 70% 60% at 92% 18%,rgba(43,191,217,.16),transparent 60%),radial-gradient(ellipse 65% 55% at 80% 95%,rgba(168,117,255,.12),transparent 60%),linear-gradient(var(--pixel-grid) 1px,transparent 1px),linear-gradient(90deg,var(--pixel-grid) 1px,transparent 1px);background-size:auto,auto,auto,20px 20px,20px 20px;background-position:0 0,0 0,0 0,-1px -1px,-1px -1px;background-attachment:fixed}::-moz-selection{background:var(--arcade-sunshine);color:var(--ink-900)}::selection{background:var(--arcade-sunshine);color:var(--ink-900)}.container{width:100%;margin-right:auto;margin-left:auto;padding-right:2rem;padding-left:2rem}@media(min-width:1400px){.container{max-width:1400px}}.font-pixel{font-family:var(--font-pixel);letter-spacing:.02em}.font-rounded{font-family:var(--font-rounded);letter-spacing:-.01em}.font-mono{font-family:var(--font-mono)}.arcade-card{background:var(--card-bg);border:1.5px solid var(--card-border);border-radius:var(--card-radius);box-shadow:var(--card-shadow-raised);transition:box-shadow var(--dur-base) var(--ease-out-quart),transform var(--dur-base) var(--ease-out-quart)}.arcade-card-soft{background:var(--card-bg);border:1px solid var(--card-border-soft);border-radius:var(--card-radius);box-shadow:var(--card-shadow)}.arcade-card-press:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow-pixel-3)}.arcade-card-press:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--ink-900)}.arcade-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--button-padding);font-family:var(--font-rounded);font-weight:var(--weight-semibold);font-size:var(--font-sm);color:var(--button-text);background:var(--button-bg);border:1.5px solid var(--button-border);border-radius:var(--button-radius);box-shadow:var(--button-shadow);cursor:pointer;transition:transform var(--dur-fast) var(--ease-out-quart),box-shadow var(--dur-fast) var(--ease-out-quart),background var(--dur-fast) var(--ease-out-quart);-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap}.arcade-btn:hover{background:var(--button-bg-hover);transform:translate(-1px,-1px);box-shadow:var(--button-shadow-hover)}.arcade-btn:active{transform:translate(2px,2px);box-shadow:0 0 0 0 var(--ink-900)}.arcade-btn:focus-visible{outline:2px solid var(--color-focus-ring);outline-offset:2px}.arcade-btn:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:var(--button-shadow)}.arcade-btn-ghost{background:transparent;border-color:transparent;box-shadow:none;color:var(--button-ghost-text)}.arcade-btn-ghost:hover{background:var(--button-ghost-hover-bg);transform:none;box-shadow:none}.arcade-btn-ghost:active{transform:none;box-shadow:none}.arcade-btn-outline{background:var(--color-bg-elevated);color:var(--ink-900)}.arcade-btn-outline:hover{background:var(--paper-100)}.arcade-btn-danger{background:var(--button-danger-bg);color:var(--button-danger-text)}.arcade-btn-danger:hover{background:var(--button-danger-bg-hover)}.arcade-btn-sm{font-size:var(--font-xs);padding:var(--space-1) var(--space-3)}.pixel-chip{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px 8px;font-family:var(--font-pixel);font-size:var(--font-2xs);letter-spacing:.06em;text-transform:uppercase;background:var(--badge-bg);color:var(--badge-text);border-radius:var(--radius-sm);border:1px solid var(--color-border);line-height:1.4}.pixel-chip-success{background:var(--badge-success-bg);color:var(--badge-success-text);border-color:var(--color-success)}.pixel-chip-info{background:var(--badge-info-bg);color:var(--badge-info-text);border-color:var(--arcade-lagoon)}.pixel-chip-tangerine{background:var(--arcade-tangerine-soft);color:var(--arcade-tangerine-ink);border-color:var(--arcade-tangerine)}.arcade-input{width:100%;background:var(--input-bg);border:1.5px solid var(--input-border);border-radius:var(--input-radius);padding:var(--space-2) var(--space-3);font-family:var(--font-sans);font-size:var(--font-sm);color:var(--input-text);transition:border-color var(--dur-fast) var(--ease-out-quart),box-shadow var(--dur-fast) var(--ease-out-quart)}.arcade-input::-moz-placeholder{color:var(--input-placeholder)}.arcade-input::placeholder{color:var(--input-placeholder)}.arcade-input:focus,.arcade-input:focus-visible{outline:none;border-color:var(--input-border-strong);box-shadow:var(--shadow-pixel-1)}.arcade-input:disabled{background:var(--paper-200);color:var(--color-text-muted)}.status-online{color:var(--status-online-text)}.status-online-dot{background:var(--status-online-dot);box-shadow:0 0 0 3px #5fb84f33;animation:pulse-online 2s ease-in-out infinite}.status-offline{color:var(--status-offline-text)}.status-offline-dot{background:var(--status-offline-dot);box-shadow:0 0 0 3px #ff547033}@keyframes pulse-online{0%,to{box-shadow:0 0 0 3px #5fb84f2e}50%{box-shadow:0 0 0 6px #5fb84f0f}}.banner-warning{background:var(--banner-warning-bg);border:1.5px solid var(--banner-warning-border);color:var(--banner-warning-text);border-radius:var(--radius-md)}.banner-success{background:var(--banner-success-bg);border:1.5px solid var(--banner-success-border);color:var(--banner-success-text);border-radius:var(--radius-md)}.banner-error{background:var(--banner-error-bg);border:1.5px solid var(--banner-error-border);color:var(--banner-error-text);border-radius:var(--radius-md)}.code-mono{font-family:var(--font-mono);color:var(--code-text)}.arcade-tabs-list{display:inline-flex;gap:var(--space-1);padding:var(--space-1);background:var(--color-bg-surface-muted);border:1.5px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-inset)}.arcade-tabs-trigger{padding:var(--space-2) var(--space-4);font-family:var(--font-rounded);font-weight:var(--weight-semibold);font-size:var(--font-sm);color:var(--tabs-trigger-text);border-radius:var(--radius-lg);transition:all var(--dur-base) var(--ease-out-quart);cursor:pointer;display:inline-flex;align-items:center;gap:var(--space-2)}.arcade-tabs-trigger[data-state=active]{background:var(--tabs-trigger-active-bg);color:var(--tabs-trigger-active-text);box-shadow:var(--shadow-soft-1)}.arcade-tabs-trigger:hover{color:var(--tabs-trigger-active-text)}.provider-halo{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-lg);border:1.5px solid var(--ink-900);background:var(--paper-50);box-shadow:var(--shadow-pixel-1);flex-shrink:0}.provider-halo-sm{width:40px;height:40px;border-radius:var(--radius-md)}.sheet-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:var(--sheet-overlay);backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);z-index:40;animation:fade-in var(--dur-base) var(--ease-out-quart)}.sheet-panel{position:fixed;z-index:50;background:var(--sheet-bg);border:1.5px solid var(--ink-900);border-radius:var(--radius-2xl);box-shadow:var(--shadow-pixel-3),var(--shadow-soft-3)}.sheet-panel-center{top:50%;left:50%;transform:translate(-50%,-50%);width:min(92vw,540px);max-height:88vh;overflow-y:auto;animation:sheet-pop var(--dur-base) var(--ease-spring)}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes sheet-pop{0%{opacity:0;transform:translate(-50%,-50%) scale(.92)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.crt-scanline{position:relative;overflow:hidden}.crt-scanline:after{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:repeating-linear-gradient(0deg,rgba(22,22,26,.05) 0,rgba(22,22,26,.05) 1px,transparent 1px,transparent 4px);opacity:.4}.section-kicker{font-family:var(--font-pixel);font-size:var(--font-2xs);letter-spacing:.18em;text-transform:uppercase;color:var(--color-text-muted)}.section-title{font-family:var(--font-rounded);font-weight:var(--weight-bold);font-size:var(--font-2xl);line-height:1.1;letter-spacing:-.02em;color:var(--color-text-primary)}.section-sub{font-family:var(--font-sans);font-size:var(--font-sm);color:var(--color-text-muted);line-height:1.5}.pointer-events-none{pointer-events:none}.absolute{position:absolute}.relative{position:relative}.inset-x-0{left:0;right:0}.-bottom-5{bottom:-1.25rem}.bottom-0{bottom:0}.left-0{left:0}.left-3{left:.75rem}.left-4{left:1rem}.right-0{right:0}.right-1\.5{right:.375rem}.right-2{right:.5rem}.right-3{right:.75rem}.top-0{top:0}.top-1\/2{top:50%}.top-3{top:.75rem}.z-20{z-index:20}.z-50{z-index:50}.mx-auto{margin-left:auto;margin-right:auto}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-6{margin-bottom:1.5rem}.ml-1{margin-left:.25rem}.mr-2{margin-right:.5rem}.mt-0\.5{margin-top:.125rem}.mt-1{margin-top:.25rem}.mt-12{margin-top:3rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-6{margin-top:1.5rem}.mt-auto{margin-top:auto}.line-clamp-2{overflow:hidden;display:-webkit-box;-webkit-box-orient:vertical;-webkit-line-clamp:2}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.hidden{display:none}.h-1\.5{height:.375rem}.h-10{height:2.5rem}.h-14{height:3.5rem}.h-2{height:.5rem}.h-3\.5{height:.875rem}.h-4{height:1rem}.h-5{height:1.25rem}.h-9{height:2.25rem}.h-\[var\(--radix-select-trigger-height\)\]{height:var(--radix-select-trigger-height)}.h-full{height:100%}.h-screen{height:100vh}.max-h-48{max-height:12rem}.max-h-96{max-height:24rem}.min-h-screen{min-height:100vh}.w-1\.5{width:.375rem}.w-12{width:3rem}.w-14{width:3.5rem}.w-2{width:.5rem}.w-3\.5{width:.875rem}.w-4{width:1rem}.w-9{width:2.25rem}.w-full{width:100%}.min-w-0{min-width:0px}.min-w-\[8rem\]{min-width:8rem}.min-w-\[var\(--radix-select-trigger-width\)\]{min-width:var(--radix-select-trigger-width)}.max-w-6xl{max-width:72rem}.max-w-lg{max-width:32rem}.max-w-sm{max-width:24rem}.flex-1{flex:1 1 0%}.flex-shrink-0,.shrink-0{flex-shrink:0}.-translate-y-1\/2{--tw-translate-y: -50%;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.transform{transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.select-none{-webkit-user-select:none;-moz-user-select:none;user-select:none}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}.grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-baseline{align-items:baseline}.items-stretch{align-items:stretch}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:.25rem}.gap-1\.5{gap:.375rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-4{gap:1rem}.gap-5{gap:1.25rem}.space-y-0\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.125rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.125rem * var(--tw-space-y-reverse))}.space-y-1>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.25rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.25rem * var(--tw-space-y-reverse))}.space-y-1\.5>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.375rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.375rem * var(--tw-space-y-reverse))}.space-y-3>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(.75rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(.75rem * var(--tw-space-y-reverse))}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(1rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(1rem * var(--tw-space-y-reverse))}.space-y-8>:not([hidden])~:not([hidden]){--tw-space-y-reverse: 0;margin-top:calc(2rem * calc(1 - var(--tw-space-y-reverse)));margin-bottom:calc(2rem * var(--tw-space-y-reverse))}.overflow-hidden{overflow:hidden}.overflow-y-auto{overflow-y:auto}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.whitespace-nowrap{white-space:nowrap}.break-all{word-break:break-all}.rounded-2xl{border-radius:1rem}.rounded-full{border-radius:9999px}.rounded-lg{border-radius:var(--radius)}.rounded-md{border-radius:calc(var(--radius) - 2px)}.rounded-sm{border-radius:calc(var(--radius) - 4px)}.rounded-xl{border-radius:.75rem}.rounded-t-\[26px\]{border-top-left-radius:26px;border-top-right-radius:26px}.border{border-width:1px}.border-2{border-width:2px}.border-b{border-bottom-width:1px}.border-t{border-top-width:1px}.border-dashed{border-style:dashed}.border-arcade-hibiscus{border-color:var(--arcade-hibiscus)}.border-arcade-leaf{border-color:var(--arcade-leaf)}.border-ink-900{border-color:var(--ink-900)}.border-input{border-color:hsl(var(--input))}.border-paper-300{border-color:var(--paper-300)}.border-transparent{border-color:transparent}.bg-arcade-lagoon{background-color:var(--arcade-lagoon)}.bg-arcade-sunshine{background-color:var(--arcade-sunshine)}.bg-background{background-color:hsl(var(--background))}.bg-paper-400{background-color:var(--paper-400)}.bg-paper-50{background-color:var(--paper-50)}.bg-transparent{background-color:transparent}.p-0{padding:0}.p-1{padding:.25rem}.p-1\.5{padding:.375rem}.p-10{padding:2.5rem}.p-2\.5{padding:.625rem}.p-3\.5{padding:.875rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.px-1{padding-left:.25rem;padding-right:.25rem}.px-2\.5{padding-left:.625rem;padding-right:.625rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.px-5{padding-left:1.25rem;padding-right:1.25rem}.px-6{padding-left:1.5rem;padding-right:1.5rem}.py-1{padding-top:.25rem;padding-bottom:.25rem}.py-1\.5{padding-top:.375rem;padding-bottom:.375rem}.py-10{padding-top:2.5rem;padding-bottom:2.5rem}.py-2{padding-top:.5rem;padding-bottom:.5rem}.py-2\.5{padding-top:.625rem;padding-bottom:.625rem}.py-3{padding-top:.75rem;padding-bottom:.75rem}.py-4{padding-top:1rem;padding-bottom:1rem}.pb-16{padding-bottom:4rem}.pb-3{padding-bottom:.75rem}.pb-4{padding-bottom:1rem}.pb-8{padding-bottom:2rem}.pl-2{padding-left:.5rem}.pl-9{padding-left:2.25rem}.pr-10{padding-right:2.5rem}.pr-8{padding-right:2rem}.pt-1{padding-top:.25rem}.pt-2{padding-top:.5rem}.pt-3{padding-top:.75rem}.pt-5{padding-top:1.25rem}.pt-6{padding-top:1.5rem}.pt-7{padding-top:1.75rem}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.font-mono{font-family:JetBrains Mono,ui-monospace,monospace}.font-pixel{font-family:Silkscreen,VT323,monospace}.font-rounded{font-family:Plus Jakarta Sans,ui-rounded,sans-serif}.text-2xl{font-size:1.5rem;line-height:2rem}.text-\[10px\]{font-size:10px}.text-\[11px\]{font-size:11px}.text-base{font-size:1rem;line-height:1.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.text-sm{font-size:.875rem;line-height:1.25rem}.text-xl{font-size:1.25rem;line-height:1.75rem}.text-xs{font-size:.75rem;line-height:1rem}.font-bold{font-weight:700}.font-medium{font-weight:500}.font-semibold{font-weight:600}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.leading-none{line-height:1}.leading-tight{line-height:1.25}.tracking-\[0\.22em\]{letter-spacing:.22em}.tracking-\[0\.3em\]{letter-spacing:.3em}.tracking-tight{letter-spacing:-.025em}.tracking-widest{letter-spacing:.1em}.text-arcade-hibiscus{color:var(--arcade-hibiscus)}.text-arcade-lagoon{color:var(--arcade-lagoon)}.text-arcade-leaf{color:var(--arcade-leaf)}.text-arcade-sunshine{color:var(--arcade-sunshine)}.text-current{color:currentColor}.text-ink-400{color:var(--ink-400)}.text-ink-600{color:var(--ink-600)}.text-ink-900{color:var(--ink-900)}.text-muted-foreground{color:hsl(var(--muted-foreground))}.underline{text-decoration-line:underline}.underline-offset-4{text-underline-offset:4px}.opacity-70{opacity:.7}.opacity-80{opacity:.8}.shadow{--tw-shadow: 0 1px 3px 0 rgb(0 0 0 / .1), 0 1px 2px -1px rgb(0 0 0 / .1);--tw-shadow-colored: 0 1px 3px 0 var(--tw-shadow-color), 0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-lg{--tw-shadow: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--tw-shadow-colored: 0 10px 15px -3px var(--tw-shadow-color), 0 4px 6px -4px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-md{--tw-shadow: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--tw-shadow-colored: 0 4px 6px -1px var(--tw-shadow-color), 0 2px 4px -2px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-pixel1{--tw-shadow: var(--shadow-pixel-1);--tw-shadow-colored: var(--shadow-pixel-1);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.shadow-sm{--tw-shadow: 0 1px 2px 0 rgb(0 0 0 / .05);--tw-shadow-colored: 0 1px 2px 0 var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.outline-none{outline:2px solid transparent;outline-offset:2px}.outline{outline-style:solid}.ring-0{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(0px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-2{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.ring-offset-background{--tw-ring-offset-color: hsl(var(--background))}.filter{filter:var(--tw-blur) var(--tw-brightness) var(--tw-contrast) var(--tw-grayscale) var(--tw-hue-rotate) var(--tw-invert) var(--tw-saturate) var(--tw-sepia) var(--tw-drop-shadow)}.transition-all{transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-colors{transition-property:color,background-color,border-color,text-decoration-color,fill,stroke;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-opacity{transition-property:opacity;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.transition-transform{transition-property:transform;transition-timing-function:cubic-bezier(.4,0,.2,1);transition-duration:.15s}.pixelated{image-rendering:pixelated;image-rendering:-moz-crisp-edges;image-rendering:crisp-edges;shape-rendering:crispEdges}.placeholder\:text-muted-foreground::-moz-placeholder{color:hsl(var(--muted-foreground))}.placeholder\:text-muted-foreground::placeholder{color:hsl(var(--muted-foreground))}.last\:border-b-0:last-child{border-bottom-width:0px}.hover\:border-ink-400:hover{border-color:var(--ink-400)}.hover\:border-ink-900:hover{border-color:var(--ink-900)}.hover\:bg-paper-200:hover{background-color:var(--paper-200)}.hover\:text-arcade-hibiscus:hover{color:var(--arcade-hibiscus)}.hover\:text-ink-900:hover{color:var(--ink-900)}.hover\:opacity-100:hover{opacity:1}.hover\:shadow-pixel1:hover{--tw-shadow: var(--shadow-pixel-1);--tw-shadow-colored: var(--shadow-pixel-1);box-shadow:var(--tw-ring-offset-shadow, 0 0 #0000),var(--tw-ring-shadow, 0 0 #0000),var(--tw-shadow)}.focus\:bg-accent:focus{background-color:hsl(var(--accent))}.focus\:text-accent-foreground:focus{color:hsl(var(--accent-foreground))}.focus\:outline-none:focus{outline:2px solid transparent;outline-offset:2px}.focus\:ring-2:focus{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus\:ring-ring:focus{--tw-ring-color: hsl(var(--ring))}.focus-visible\:outline-none:focus-visible{outline:2px solid transparent;outline-offset:2px}.focus-visible\:ring-2:focus-visible{--tw-ring-offset-shadow: var(--tw-ring-inset) 0 0 0 var(--tw-ring-offset-width) var(--tw-ring-offset-color);--tw-ring-shadow: var(--tw-ring-inset) 0 0 0 calc(2px + var(--tw-ring-offset-width)) var(--tw-ring-color);box-shadow:var(--tw-ring-offset-shadow),var(--tw-ring-shadow),var(--tw-shadow, 0 0 #0000)}.focus-visible\:ring-ring:focus-visible{--tw-ring-color: hsl(var(--ring))}.focus-visible\:ring-offset-2:focus-visible{--tw-ring-offset-width: 2px}.focus-visible\:ring-offset-background:focus-visible{--tw-ring-offset-color: hsl(var(--background))}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.disabled\:opacity-50:disabled{opacity:.5}.group:hover .group-hover\:translate-x-0\.5{--tw-translate-x: .125rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.peer:disabled~.peer-disabled\:cursor-not-allowed{cursor:not-allowed}.peer:disabled~.peer-disabled\:opacity-70{opacity:.7}.data-\[disabled\]\:pointer-events-none[data-disabled]{pointer-events:none}.data-\[side\=bottom\]\:translate-y-1[data-side=bottom]{--tw-translate-y: .25rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:translate-x-4[data-state=checked]{--tw-translate-x: 1rem;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=unchecked\]\:translate-x-0[data-state=unchecked]{--tw-translate-x: 0px;transform:translate(var(--tw-translate-x),var(--tw-translate-y)) rotate(var(--tw-rotate)) skew(var(--tw-skew-x)) skewY(var(--tw-skew-y)) scaleX(var(--tw-scale-x)) scaleY(var(--tw-scale-y))}.data-\[state\=checked\]\:bg-primary[data-state=checked]{background-color:hsl(var(--primary))}.data-\[state\=unchecked\]\:bg-input[data-state=unchecked]{background-color:hsl(var(--input))}.data-\[disabled\]\:opacity-50[data-disabled]{opacity:.5}@media(min-width:640px){.sm\:inline{display:inline}.sm\:w-72{width:18rem}.sm\:grid-cols-2{grid-template-columns:repeat(2,minmax(0,1fr))}.sm\:flex-row{flex-direction:row}.sm\:items-end{align-items:flex-end}.sm\:justify-between{justify-content:space-between}.sm\:px-8{padding-left:2rem;padding-right:2rem}.sm\:pt-10{padding-top:2.5rem}.sm\:text-3xl{font-size:1.875rem;line-height:2.25rem}.sm\:text-sm{font-size:.875rem;line-height:1.25rem}}@media(min-width:1024px){.lg\:col-span-2{grid-column:span 2 / span 2}.lg\:col-span-3{grid-column:span 3 / span 3}.lg\:grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.lg\:grid-cols-5{grid-template-columns:repeat(5,minmax(0,1fr))}}
|
package/dist/ui/index.html
CHANGED
|
@@ -12,8 +12,8 @@
|
|
|
12
12
|
href="https://fonts.googleapis.com/css2?family=Inter+Tight:wght@400;500;600;700;800&family=Plus+Jakarta+Sans:wght@500;600;700;800&family=Silkscreen:wght@400;700&family=VT323&family=JetBrains+Mono:wght@400;500;600&display=swap"
|
|
13
13
|
rel="stylesheet"
|
|
14
14
|
/>
|
|
15
|
-
<script type="module" crossorigin src="./assets/index-
|
|
16
|
-
<link rel="stylesheet" crossorigin href="./assets/index-
|
|
15
|
+
<script type="module" crossorigin src="./assets/index-7kowlJw9.js"></script>
|
|
16
|
+
<link rel="stylesheet" crossorigin href="./assets/index-DnC-lskL.css">
|
|
17
17
|
</head>
|
|
18
18
|
<body>
|
|
19
19
|
<div id="root"></div>
|
package/dist/update.d.ts
CHANGED
|
@@ -1,11 +1,22 @@
|
|
|
1
1
|
/**
|
|
2
2
|
* Update checker + one-shot upgrade command.
|
|
3
3
|
*
|
|
4
|
-
*
|
|
5
|
-
*
|
|
6
|
-
*
|
|
7
|
-
*
|
|
8
|
-
*
|
|
4
|
+
* Why not `update-notifier`? Its background-check path proved unreliable here:
|
|
5
|
+
* the detached child it spawns to query the registry never persisted a result
|
|
6
|
+
* to configstore, so the "update available" banner effectively never fired —
|
|
7
|
+
* and even when it works it's deferred by one run and rate-limited to once/day,
|
|
8
|
+
* so a freshly published version isn't noticed for up to a day. We replaced it
|
|
9
|
+
* with a self-managed check:
|
|
10
|
+
*
|
|
11
|
+
* - checkForUpdates() runs at startup. It reads a small cache
|
|
12
|
+
* (~/.mcc/update-cache.json). If the cache already knows a newer version, the
|
|
13
|
+
* banner prints on THIS run (registered at process 'exit' so it lands on the
|
|
14
|
+
* clean shell prompt after Claude's TUI closes — not buried under it). If the
|
|
15
|
+
* cache is stale, it kicks off an in-process registry fetch that writes the
|
|
16
|
+
* cache. The fetch's socket is unref'd, so it never delays a fast command
|
|
17
|
+
* like `mcc -v`; on the long-lived `mcc <profile>` launch path the spawned
|
|
18
|
+
* `claude` keeps the event loop alive, so the fetch completes and the cache
|
|
19
|
+
* refreshes for next time.
|
|
9
20
|
*
|
|
10
21
|
* - runUpdate() detects how the binary was installed (npm/pnpm/yarn/bun) and
|
|
11
22
|
* invokes the matching `add -g` command. Detection is a path heuristic; the
|
package/dist/update.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"update.d.ts","sourceRoot":"","sources":["../src/update.ts"],"names":[],"mappings":"AAAA
|
|
1
|
+
{"version":3,"file":"update.d.ts","sourceRoot":"","sources":["../src/update.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;AASH,KAAK,cAAc,GAAG,KAAK,GAAG,MAAM,GAAG,MAAM,GAAG,KAAK,CAAC;AAmHtD,wBAAgB,eAAe,CAAC,cAAc,EAAE,MAAM,GAAG,IAAI,CAuB5D;AAED;;;;;;;GAOG;AACH,wBAAgB,oBAAoB,IAAI,cAAc,CASrD;AAYD,wBAAsB,SAAS,CAAC,IAAI,GAAE;IAAE,SAAS,CAAC,EAAE,OAAO,CAAC;IAAC,UAAU,CAAC,EAAE,cAAc,CAAA;CAAO,GAAG,OAAO,CAAC,IAAI,CAAC,CAkD9G;AAYD,wBAAgB,iBAAiB,CAAC,GAAG,EAAE,MAAM,GAAG,SAAS,GAAG,IAAI,CAc/D"}
|
package/dist/update.js
CHANGED
|
@@ -2,11 +2,22 @@
|
|
|
2
2
|
/**
|
|
3
3
|
* Update checker + one-shot upgrade command.
|
|
4
4
|
*
|
|
5
|
-
*
|
|
6
|
-
*
|
|
7
|
-
*
|
|
8
|
-
*
|
|
9
|
-
*
|
|
5
|
+
* Why not `update-notifier`? Its background-check path proved unreliable here:
|
|
6
|
+
* the detached child it spawns to query the registry never persisted a result
|
|
7
|
+
* to configstore, so the "update available" banner effectively never fired —
|
|
8
|
+
* and even when it works it's deferred by one run and rate-limited to once/day,
|
|
9
|
+
* so a freshly published version isn't noticed for up to a day. We replaced it
|
|
10
|
+
* with a self-managed check:
|
|
11
|
+
*
|
|
12
|
+
* - checkForUpdates() runs at startup. It reads a small cache
|
|
13
|
+
* (~/.mcc/update-cache.json). If the cache already knows a newer version, the
|
|
14
|
+
* banner prints on THIS run (registered at process 'exit' so it lands on the
|
|
15
|
+
* clean shell prompt after Claude's TUI closes — not buried under it). If the
|
|
16
|
+
* cache is stale, it kicks off an in-process registry fetch that writes the
|
|
17
|
+
* cache. The fetch's socket is unref'd, so it never delays a fast command
|
|
18
|
+
* like `mcc -v`; on the long-lived `mcc <profile>` launch path the spawned
|
|
19
|
+
* `claude` keeps the event loop alive, so the fetch completes and the cache
|
|
20
|
+
* refreshes for next time.
|
|
10
21
|
*
|
|
11
22
|
* - runUpdate() detects how the binary was installed (npm/pnpm/yarn/bun) and
|
|
12
23
|
* invokes the matching `add -g` command. Detection is a path heuristic; the
|
|
@@ -54,34 +65,138 @@ exports.detectPackageManager = detectPackageManager;
|
|
|
54
65
|
exports.runUpdate = runUpdate;
|
|
55
66
|
exports.setUpdateCheckCmd = setUpdateCheckCmd;
|
|
56
67
|
const child_process_1 = require("child_process");
|
|
68
|
+
const fs = __importStar(require("fs"));
|
|
69
|
+
const https = __importStar(require("https"));
|
|
57
70
|
const path = __importStar(require("path"));
|
|
58
71
|
const picocolors_1 = __importDefault(require("picocolors"));
|
|
59
|
-
const update_notifier_1 = __importDefault(require("update-notifier"));
|
|
60
72
|
const config_1 = require("./shared/config");
|
|
61
73
|
const PKG_NAME = '@hileeon/mcc';
|
|
74
|
+
// How long a cached registry result is trusted before we refresh in the
|
|
75
|
+
// background. The refresh is free (backgrounded + unref'd), so this is just a
|
|
76
|
+
// politeness throttle on registry hits, not a freshness ceiling the user feels.
|
|
77
|
+
const CHECK_INTERVAL_MS = 1000 * 60 * 60; // 1 hour
|
|
78
|
+
function getCachePath() {
|
|
79
|
+
return path.join((0, config_1.getMccHome)(), 'update-cache.json');
|
|
80
|
+
}
|
|
81
|
+
function readCache() {
|
|
82
|
+
try {
|
|
83
|
+
return JSON.parse(fs.readFileSync(getCachePath(), 'utf8'));
|
|
84
|
+
}
|
|
85
|
+
catch {
|
|
86
|
+
return null;
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
function writeCache(cache) {
|
|
90
|
+
try {
|
|
91
|
+
const home = (0, config_1.getMccHome)();
|
|
92
|
+
if (!fs.existsSync(home))
|
|
93
|
+
fs.mkdirSync(home, { recursive: true });
|
|
94
|
+
fs.writeFileSync(getCachePath(), JSON.stringify(cache));
|
|
95
|
+
}
|
|
96
|
+
catch {
|
|
97
|
+
// Cache is best-effort; a write failure just means we re-check next run.
|
|
98
|
+
}
|
|
99
|
+
}
|
|
100
|
+
/** Strict-enough semver compare for this project's plain x.y.z versions. */
|
|
101
|
+
function parseVersion(v) {
|
|
102
|
+
return v.split('-')[0].split('.').map((n) => parseInt(n, 10) || 0);
|
|
103
|
+
}
|
|
104
|
+
function isNewer(latest, current) {
|
|
105
|
+
const a = parseVersion(latest);
|
|
106
|
+
const b = parseVersion(current);
|
|
107
|
+
for (let i = 0; i < 3; i++) {
|
|
108
|
+
const x = a[i] ?? 0;
|
|
109
|
+
const y = b[i] ?? 0;
|
|
110
|
+
if (x > y)
|
|
111
|
+
return true;
|
|
112
|
+
if (x < y)
|
|
113
|
+
return false;
|
|
114
|
+
}
|
|
115
|
+
return false;
|
|
116
|
+
}
|
|
117
|
+
/**
|
|
118
|
+
* Fetch the latest published version straight from the npm registry over native
|
|
119
|
+
* https — no transitive dependency, no detached child. Resolves to null on any
|
|
120
|
+
* failure (offline, registry error, timeout).
|
|
121
|
+
*
|
|
122
|
+
* `background: true` unref's the socket so a pending request never keeps a
|
|
123
|
+
* fast-exiting command (e.g. `mcc -v`) alive — used by the startup check, where
|
|
124
|
+
* the result is fire-and-forget. The awaited `mcc update --check` path must NOT
|
|
125
|
+
* unref: with the promise suspended, an unref'd socket is the only thing left to
|
|
126
|
+
* keep the loop alive, so Node would exit 0 before the fetch resolves.
|
|
127
|
+
*/
|
|
128
|
+
function fetchLatest(opts = {}) {
|
|
129
|
+
const { timeoutMs = 5000, background = false } = opts;
|
|
130
|
+
return new Promise((resolve) => {
|
|
131
|
+
// The `/latest` endpoint returns the latest dist-tag's manifest, which has
|
|
132
|
+
// `.version`. Note: do NOT send the abbreviated-metadata Accept header here —
|
|
133
|
+
// that content-type only applies to the full packument, and `/latest`
|
|
134
|
+
// answers it with 406 Not Acceptable.
|
|
135
|
+
const url = `https://registry.npmjs.org/${PKG_NAME.replace('/', '%2F')}/latest`;
|
|
136
|
+
const req = https.get(url, (res) => {
|
|
137
|
+
if (res.statusCode !== 200) {
|
|
138
|
+
res.resume();
|
|
139
|
+
return resolve(null);
|
|
140
|
+
}
|
|
141
|
+
let body = '';
|
|
142
|
+
res.on('data', (c) => (body += c));
|
|
143
|
+
res.on('end', () => {
|
|
144
|
+
try {
|
|
145
|
+
resolve(JSON.parse(body).version ?? null);
|
|
146
|
+
}
|
|
147
|
+
catch {
|
|
148
|
+
resolve(null);
|
|
149
|
+
}
|
|
150
|
+
});
|
|
151
|
+
});
|
|
152
|
+
req.on('error', () => resolve(null));
|
|
153
|
+
req.setTimeout(timeoutMs, () => {
|
|
154
|
+
req.destroy();
|
|
155
|
+
resolve(null);
|
|
156
|
+
});
|
|
157
|
+
// For the background startup check, don't let an in-flight request hold the
|
|
158
|
+
// process open on its own. (Never unref on the awaited path — see above.)
|
|
159
|
+
if (background)
|
|
160
|
+
req.on('socket', (s) => s.unref());
|
|
161
|
+
});
|
|
162
|
+
}
|
|
163
|
+
let bannerArmed = false;
|
|
164
|
+
function armBanner(current, latest) {
|
|
165
|
+
if (bannerArmed)
|
|
166
|
+
return;
|
|
167
|
+
bannerArmed = true;
|
|
168
|
+
// Print at exit so it lands on the clean shell prompt — after Claude's
|
|
169
|
+
// full-screen TUI has closed — instead of scrolling away behind it.
|
|
170
|
+
process.on('exit', () => {
|
|
171
|
+
process.stderr.write('\n' +
|
|
172
|
+
` ${picocolors_1.default.yellow('✨ Update available')} ${picocolors_1.default.dim(current)} → ${picocolors_1.default.green(latest)}\n` +
|
|
173
|
+
` Run ${picocolors_1.default.cyan('mcc update')} to upgrade ${picocolors_1.default.dim('·')} ` +
|
|
174
|
+
`${picocolors_1.default.dim('silence with')} ${picocolors_1.default.cyan('mcc update-check off')}\n\n`);
|
|
175
|
+
});
|
|
176
|
+
}
|
|
62
177
|
function checkForUpdates(currentVersion) {
|
|
63
178
|
if (!(0, config_1.isUpdateCheckEnabled)())
|
|
64
179
|
return;
|
|
65
180
|
if (process.env.CI || process.env.MCC_NO_UPDATE_NOTIFIER)
|
|
66
181
|
return;
|
|
67
182
|
try {
|
|
68
|
-
const
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
}
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
183
|
+
const cache = readCache();
|
|
184
|
+
// If we already know about a newer version, surface it on this run.
|
|
185
|
+
if (cache?.latest && isNewer(cache.latest, currentVersion)) {
|
|
186
|
+
armBanner(currentVersion, cache.latest);
|
|
187
|
+
}
|
|
188
|
+
// Refresh in the background when the cache is missing or stale. Fire and
|
|
189
|
+
// forget — unref'd, so it never delays exit.
|
|
190
|
+
const stale = !cache || Date.now() - cache.lastCheck > CHECK_INTERVAL_MS;
|
|
191
|
+
if (stale) {
|
|
192
|
+
void fetchLatest({ background: true }).then((latest) => {
|
|
193
|
+
if (latest)
|
|
194
|
+
writeCache({ lastCheck: Date.now(), latest });
|
|
80
195
|
});
|
|
81
196
|
}
|
|
82
197
|
}
|
|
83
198
|
catch {
|
|
84
|
-
//
|
|
199
|
+
// Never let the update check block or crash the CLI.
|
|
85
200
|
}
|
|
86
201
|
}
|
|
87
202
|
/**
|
|
@@ -117,26 +232,21 @@ function buildInstallCommand(pm, target) {
|
|
|
117
232
|
async function runUpdate(opts = {}) {
|
|
118
233
|
const pm = opts.pmOverride ?? detectPackageManager();
|
|
119
234
|
if (opts.checkOnly) {
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
updateCheckInterval: 0,
|
|
125
|
-
});
|
|
126
|
-
try {
|
|
127
|
-
const info = await notifier.fetchInfo();
|
|
128
|
-
if (info.type === 'latest') {
|
|
129
|
-
console.log(`${picocolors_1.default.green('✓')} mcc is up to date (${info.current})`);
|
|
130
|
-
}
|
|
131
|
-
else {
|
|
132
|
-
console.log(`${picocolors_1.default.yellow('!')} Update available: ${picocolors_1.default.dim(info.current)} → ${picocolors_1.default.green(info.latest)}`);
|
|
133
|
-
console.log(` Run ${picocolors_1.default.cyan('mcc update')} to upgrade`);
|
|
134
|
-
}
|
|
135
|
-
}
|
|
136
|
-
catch (e) {
|
|
137
|
-
console.error(`[!] Could not reach the npm registry: ${e.message}`);
|
|
235
|
+
const current = getOwnVersion();
|
|
236
|
+
const latest = await fetchLatest();
|
|
237
|
+
if (latest === null) {
|
|
238
|
+
console.error(`[!] Could not reach the npm registry.`);
|
|
138
239
|
process.exit(1);
|
|
139
240
|
}
|
|
241
|
+
if (isNewer(latest, current)) {
|
|
242
|
+
console.log(`${picocolors_1.default.yellow('!')} Update available: ${picocolors_1.default.dim(current)} → ${picocolors_1.default.green(latest)}`);
|
|
243
|
+
console.log(` Run ${picocolors_1.default.cyan('mcc update')} to upgrade`);
|
|
244
|
+
}
|
|
245
|
+
else {
|
|
246
|
+
console.log(`${picocolors_1.default.green('✓')} mcc is up to date (${current})`);
|
|
247
|
+
}
|
|
248
|
+
// Keep the cache warm so the next launch reflects what we just learned.
|
|
249
|
+
writeCache({ lastCheck: Date.now(), latest });
|
|
140
250
|
return;
|
|
141
251
|
}
|
|
142
252
|
const target = `${PKG_NAME}@latest`;
|
|
@@ -156,6 +266,8 @@ async function runUpdate(opts = {}) {
|
|
|
156
266
|
});
|
|
157
267
|
child.on('exit', (code) => {
|
|
158
268
|
if (code === 0) {
|
|
269
|
+
// Clear the stale "update available" cache so we don't nag post-upgrade.
|
|
270
|
+
writeCache({ lastCheck: Date.now(), latest: getOwnVersion() });
|
|
159
271
|
console.log(`\n${picocolors_1.default.green('✓')} mcc upgraded. Run ${picocolors_1.default.cyan('mcc -v')} to confirm.`);
|
|
160
272
|
}
|
|
161
273
|
else {
|
package/dist/update.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"update.js","sourceRoot":"","sources":["../src/update.ts"],"names":[],"mappings":";AAAA
|
|
1
|
+
{"version":3,"file":"update.js","sourceRoot":"","sources":["../src/update.ts"],"names":[],"mappings":";AAAA;;;;;;;;;;;;;;;;;;;;;;;GAuBG;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA4HH,0CAuBC;AAUD,oDASC;AAYD,8BAkDC;AAYD,8CAcC;AA5PD,iDAAsC;AACtC,uCAAyB;AACzB,6CAA+B;AAC/B,2CAA6B;AAC7B,4DAA4B;AAC5B,4CAA4F;AAI5F,MAAM,QAAQ,GAAG,cAAc,CAAC;AAEhC,wEAAwE;AACxE,8EAA8E;AAC9E,gFAAgF;AAChF,MAAM,iBAAiB,GAAG,IAAI,GAAG,EAAE,GAAG,EAAE,CAAC,CAAC,SAAS;AAOnD,SAAS,YAAY;IACnB,OAAO,IAAI,CAAC,IAAI,CAAC,IAAA,mBAAU,GAAE,EAAE,mBAAmB,CAAC,CAAC;AACtD,CAAC;AAED,SAAS,SAAS;IAChB,IAAI,CAAC;QACH,OAAO,IAAI,CAAC,KAAK,CAAC,EAAE,CAAC,YAAY,CAAC,YAAY,EAAE,EAAE,MAAM,CAAC,CAAgB,CAAC;IAC5E,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,IAAI,CAAC;IACd,CAAC;AACH,CAAC;AAED,SAAS,UAAU,CAAC,KAAkB;IACpC,IAAI,CAAC;QACH,MAAM,IAAI,GAAG,IAAA,mBAAU,GAAE,CAAC;QAC1B,IAAI,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC;YAAE,EAAE,CAAC,SAAS,CAAC,IAAI,EAAE,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,CAAC;QAClE,EAAE,CAAC,aAAa,CAAC,YAAY,EAAE,EAAE,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;IAC1D,CAAC;IAAC,MAAM,CAAC;QACP,yEAAyE;IAC3E,CAAC;AACH,CAAC;AAED,4EAA4E;AAC5E,SAAS,YAAY,CAAC,CAAS;IAC7B,OAAO,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,QAAQ,CAAC,CAAC,EAAE,EAAE,CAAC,IAAI,CAAC,CAAC,CAAC;AACrE,CAAC;AAED,SAAS,OAAO,CAAC,MAAc,EAAE,OAAe;IAC9C,MAAM,CAAC,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;IAC/B,MAAM,CAAC,GAAG,YAAY,CAAC,OAAO,CAAC,CAAC;IAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC;QAC3B,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QACpB,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;QACpB,IAAI,CAAC,GAAG,CAAC;YAAE,OAAO,IAAI,CAAC;QACvB,IAAI,CAAC,GAAG,CAAC;YAAE,OAAO,KAAK,CAAC;IAC1B,CAAC;IACD,OAAO,KAAK,CAAC;AACf,CAAC;AAED;;;;;;;;;;GAUG;AACH,SAAS,WAAW,CAAC,OAAqD,EAAE;IAC1E,MAAM,EAAE,SAAS,GAAG,IAAI,EAAE,UAAU,GAAG,KAAK,EAAE,GAAG,IAAI,CAAC;IACtD,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,EAAE;QAC7B,2EAA2E;QAC3E,8EAA8E;QAC9E,sEAAsE;QACtE,sCAAsC;QACtC,MAAM,GAAG,GAAG,8BAA8B,QAAQ,CAAC,OAAO,CAAC,GAAG,EAAE,KAAK,CAAC,SAAS,CAAC;QAChF,MAAM,GAAG,GAAG,KAAK,CAAC,GAAG,CAAC,GAAG,EAAE,CAAC,GAAG,EAAE,EAAE;YACjC,IAAI,GAAG,CAAC,UAAU,KAAK,GAAG,EAAE,CAAC;gBAC3B,GAAG,CAAC,MAAM,EAAE,CAAC;gBACb,OAAO,OAAO,CAAC,IAAI,CAAC,CAAC;YACvB,CAAC;YACD,IAAI,IAAI,GAAG,EAAE,CAAC;YACd,GAAG,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC,CAAC;YACnC,GAAG,CAAC,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE;gBACjB,IAAI,CAAC;oBACH,OAAO,CAAE,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,OAAkB,IAAI,IAAI,CAAC,CAAC;gBACxD,CAAC;gBAAC,MAAM,CAAC;oBACP,OAAO,CAAC,IAAI,CAAC,CAAC;gBAChB,CAAC;YACH,CAAC,CAAC,CAAC;QACL,CAAC,CAAC,CAAC;QACH,GAAG,CAAC,EAAE,CAAC,OAAO,EAAE,GAAG,EAAE,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;QACrC,GAAG,CAAC,UAAU,CAAC,SAAS,EAAE,GAAG,EAAE;YAC7B,GAAG,CAAC,OAAO,EAAE,CAAC;YACd,OAAO,CAAC,IAAI,CAAC,CAAC;QAChB,CAAC,CAAC,CAAC;QACH,4EAA4E;QAC5E,0EAA0E;QAC1E,IAAI,UAAU;YAAE,GAAG,CAAC,EAAE,CAAC,QAAQ,EAAE,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC,CAAC;IACrD,CAAC,CAAC,CAAC;AACL,CAAC;AAED,IAAI,WAAW,GAAG,KAAK,CAAC;AAExB,SAAS,SAAS,CAAC,OAAe,EAAE,MAAc;IAChD,IAAI,WAAW;QAAE,OAAO;IACxB,WAAW,GAAG,IAAI,CAAC;IACnB,uEAAuE;IACvE,oEAAoE;IACpE,OAAO,CAAC,EAAE,CAAC,MAAM,EAAE,GAAG,EAAE;QACtB,OAAO,CAAC,MAAM,CAAC,KAAK,CAClB,IAAI;YACF,KAAK,oBAAE,CAAC,MAAM,CAAC,oBAAoB,CAAC,IAAI,oBAAE,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,oBAAE,CAAC,KAAK,CAAC,MAAM,CAAC,IAAI;YACjF,YAAY,oBAAE,CAAC,IAAI,CAAC,YAAY,CAAC,gBAAgB,oBAAE,CAAC,GAAG,CAAC,GAAG,CAAC,IAAI;YAChE,GAAG,oBAAE,CAAC,GAAG,CAAC,cAAc,CAAC,IAAI,oBAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,MAAM,CACrE,CAAC;IACJ,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAgB,eAAe,CAAC,cAAsB;IACpD,IAAI,CAAC,IAAA,6BAAoB,GAAE;QAAE,OAAO;IACpC,IAAI,OAAO,CAAC,GAAG,CAAC,EAAE,IAAI,OAAO,CAAC,GAAG,CAAC,sBAAsB;QAAE,OAAO;IAEjE,IAAI,CAAC;QACH,MAAM,KAAK,GAAG,SAAS,EAAE,CAAC;QAE1B,oEAAoE;QACpE,IAAI,KAAK,EAAE,MAAM,IAAI,OAAO,CAAC,KAAK,CAAC,MAAM,EAAE,cAAc,CAAC,EAAE,CAAC;YAC3D,SAAS,CAAC,cAAc,EAAE,KAAK,CAAC,MAAM,CAAC,CAAC;QAC1C,CAAC;QAED,yEAAyE;QACzE,6CAA6C;QAC7C,MAAM,KAAK,GAAG,CAAC,KAAK,IAAI,IAAI,CAAC,GAAG,EAAE,GAAG,KAAK,CAAC,SAAS,GAAG,iBAAiB,CAAC;QACzE,IAAI,KAAK,EAAE,CAAC;YACV,KAAK,WAAW,CAAC,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,EAAE;gBACrD,IAAI,MAAM;oBAAE,UAAU,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;YAC5D,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;IAAC,MAAM,CAAC;QACP,qDAAqD;IACvD,CAAC;AACH,CAAC;AAED;;;;;;;GAOG;AACH,SAAgB,oBAAoB;IAClC,MAAM,QAAQ,GAAG,IAAA,mBAAU,GAAE,CAAC,cAAc,CAAC;IAC7C,IAAI,QAAQ;QAAE,OAAO,QAAQ,CAAC;IAE9B,MAAM,GAAG,GAAG,SAAS,CAAC,WAAW,EAAE,CAAC;IACpC,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,OAAO,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAAE,OAAO,MAAM,CAAC;IACxF,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,OAAO,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC;QAAE,OAAO,KAAK,CAAC;IACvF,IAAI,GAAG,CAAC,QAAQ,CAAC,GAAG,IAAI,CAAC,GAAG,OAAO,IAAI,CAAC,GAAG,EAAE,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,QAAQ,CAAC,IAAI,GAAG,CAAC,QAAQ,CAAC,cAAc,CAAC;QAAE,OAAO,MAAM,CAAC;IACxH,OAAO,KAAK,CAAC;AACf,CAAC;AAED,SAAS,mBAAmB,CAAC,EAAkB,EAAE,MAAc;IAC7D,QAAQ,EAAE,EAAE,CAAC;QACX,KAAK,MAAM,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,CAAC;QACjE,KAAK,MAAM,CAAC,CAAC,OAAO,EAAE,GAAG,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,QAAQ,EAAE,KAAK,EAAE,MAAM,CAAC,EAAE,CAAC;QACrE,KAAK,KAAK,CAAC,CAAE,OAAO,EAAE,GAAG,EAAE,KAAK,EAAG,IAAI,EAAE,CAAC,KAAK,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,CAAC;QACjE,KAAK,KAAK,CAAC;QACX,OAAO,CAAC,CAAK,OAAO,EAAE,GAAG,EAAE,KAAK,EAAG,IAAI,EAAE,CAAC,SAAS,EAAE,IAAI,EAAE,MAAM,CAAC,EAAE,CAAC;IACvE,CAAC;AACH,CAAC;AAEM,KAAK,UAAU,SAAS,CAAC,OAA6D,EAAE;IAC7F,MAAM,EAAE,GAAG,IAAI,CAAC,UAAU,IAAI,oBAAoB,EAAE,CAAC;IAErD,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;QACnB,MAAM,OAAO,GAAG,aAAa,EAAE,CAAC;QAChC,MAAM,MAAM,GAAG,MAAM,WAAW,EAAE,CAAC;QACnC,IAAI,MAAM,KAAK,IAAI,EAAE,CAAC;YACpB,OAAO,CAAC,KAAK,CAAC,uCAAuC,CAAC,CAAC;YACvD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAClB,CAAC;QACD,IAAI,OAAO,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,CAAC;YAC7B,OAAO,CAAC,GAAG,CAAC,GAAG,oBAAE,CAAC,MAAM,CAAC,GAAG,CAAC,sBAAsB,oBAAE,CAAC,GAAG,CAAC,OAAO,CAAC,MAAM,oBAAE,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,CAAC,CAAC;YAC5F,OAAO,CAAC,GAAG,CAAC,SAAS,oBAAE,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,CAAC;QAC3D,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,GAAG,CAAC,GAAG,oBAAE,CAAC,KAAK,CAAC,GAAG,CAAC,uBAAuB,OAAO,GAAG,CAAC,CAAC;QACjE,CAAC;QACD,wEAAwE;QACxE,UAAU,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;QAC9C,OAAO;IACT,CAAC;IAED,MAAM,MAAM,GAAG,GAAG,QAAQ,SAAS,CAAC;IACpC,MAAM,EAAE,GAAG,EAAE,IAAI,EAAE,GAAG,mBAAmB,CAAC,EAAE,EAAE,MAAM,CAAC,CAAC;IACtD,OAAO,CAAC,GAAG,CAAC,GAAG,oBAAE,CAAC,IAAI,CAAC,GAAG,CAAC,kBAAkB,oBAAE,CAAC,IAAI,CAAC,EAAE,CAAC,KAAK,oBAAE,CAAC,GAAG,CAAC,GAAG,GAAG,IAAI,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE,CAAC,CAAC;IAEnG,MAAM,KAAK,GAAG,IAAA,qBAAK,EAAC,GAAG,EAAE,IAAI,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,KAAK,EAAE,OAAO,CAAC,QAAQ,KAAK,OAAO,EAAE,CAAC,CAAC;IAC1F,KAAK,CAAC,EAAE,CAAC,OAAO,EAAE,CAAC,GAA0B,EAAE,EAAE;QAC/C,IAAI,GAAG,CAAC,IAAI,KAAK,QAAQ,EAAE,CAAC;YAC1B,OAAO,CAAC,KAAK,CAAC,OAAO,GAAG,qBAAqB,CAAC,CAAC;YAC/C,OAAO,CAAC,KAAK,CAAC,0FAA0F,CAAC,CAAC;YAC1G,OAAO,CAAC,KAAK,CAAC,6DAA6D,CAAC,CAAC;QAC/E,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,uBAAuB,GAAG,CAAC,OAAO,EAAE,CAAC,CAAC;QACtD,CAAC;QACD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC,CAAC,CAAC;IACH,KAAK,CAAC,EAAE,CAAC,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE;QACxB,IAAI,IAAI,KAAK,CAAC,EAAE,CAAC;YACf,yEAAyE;YACzE,UAAU,CAAC,EAAE,SAAS,EAAE,IAAI,CAAC,GAAG,EAAE,EAAE,MAAM,EAAE,aAAa,EAAE,EAAE,CAAC,CAAC;YAC/D,OAAO,CAAC,GAAG,CAAC,KAAK,oBAAE,CAAC,KAAK,CAAC,GAAG,CAAC,sBAAsB,oBAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,cAAc,CAAC,CAAC;QACvF,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,KAAK,CAAC,SAAS,GAAG,qBAAqB,IAAI,GAAG,CAAC,CAAC;YACxD,IAAI,OAAO,CAAC,QAAQ,KAAK,OAAO,IAAI,EAAE,KAAK,KAAK,EAAE,CAAC;gBACjD,OAAO,CAAC,KAAK,CAAC,4CAA4C,oBAAE,CAAC,IAAI,CAAC,uBAAuB,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC;gBACtG,OAAO,CAAC,KAAK,CAAC,4EAA4E,CAAC,CAAC;YAC9F,CAAC;QACH,CAAC;QACD,OAAO,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC,CAAC;IAC1B,CAAC,CAAC,CAAC;AACL,CAAC;AAED,SAAS,aAAa;IACpB,IAAI,CAAC;QACH,oCAAoC;QACpC,MAAM,GAAG,GAAG,OAAO,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,EAAE,cAAc,CAAC,CAAC,CAAC;QAChE,OAAO,GAAG,CAAC,OAAiB,CAAC;IAC/B,CAAC;IAAC,MAAM,CAAC;QACP,OAAO,OAAO,CAAC;IACjB,CAAC;AACH,CAAC;AAED,SAAgB,iBAAiB,CAAC,GAAuB;IACvD,IAAI,CAAC,GAAG,EAAE,CAAC;QACT,OAAO,CAAC,GAAG,CAAC,6BAA6B,IAAA,6BAAoB,GAAE,CAAC,CAAC,CAAC,oBAAE,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,oBAAE,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE,CAAC,CAAC;QACpG,OAAO,CAAC,GAAG,CAAC,YAAY,oBAAE,CAAC,IAAI,CAAC,qBAAqB,CAAC,MAAM,oBAAE,CAAC,IAAI,CAAC,sBAAsB,CAAC,EAAE,CAAC,CAAC;QAC/F,OAAO;IACT,CAAC;IACD,IAAI,GAAG,KAAK,IAAI,IAAI,GAAG,KAAK,KAAK,EAAE,CAAC;QAClC,OAAO,CAAC,KAAK,CAAC,oCAAoC,CAAC,CAAC;QACpD,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;IAClB,CAAC;IACD,MAAM,GAAG,GAAG,IAAA,mBAAU,GAAE,CAAC;IACzB,GAAG,CAAC,WAAW,GAAG,GAAG,KAAK,IAAI,CAAC;IAC/B,IAAA,oBAAW,EAAC,GAAG,CAAC,CAAC;IACjB,OAAO,CAAC,GAAG,CAAC,GAAG,oBAAE,CAAC,KAAK,CAAC,GAAG,CAAC,iBAAiB,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,UAAU,EAAE,CAAC,CAAC;AACxF,CAAC"}
|
|
@@ -348,12 +348,12 @@ function getFormat() {
|
|
|
348
348
|
return (process.env.MCC_IMAGE_ANALYSIS_FORMAT || 'anthropic').trim().toLowerCase();
|
|
349
349
|
}
|
|
350
350
|
|
|
351
|
-
function analyzeViaCliProxy(base64Data, mediaType, model, prompt, timeoutMs) {
|
|
351
|
+
function analyzeViaCliProxy(provider, base64Data, mediaType, model, prompt, timeoutMs) {
|
|
352
352
|
return new Promise((resolve, reject) => {
|
|
353
|
-
const endpoint = new URL(
|
|
353
|
+
const endpoint = new URL(provider.endpoint);
|
|
354
354
|
const transport = endpoint.protocol === 'https:' ? https : http;
|
|
355
|
-
const apiKey =
|
|
356
|
-
const format =
|
|
355
|
+
const apiKey = provider.apiKey || 'mcc-internal-managed';
|
|
356
|
+
const format = (provider.format || 'anthropic').toLowerCase();
|
|
357
357
|
|
|
358
358
|
log.debug('ImageRuntime', `API call endpoint=${endpoint.toString()} model=${model} format=${format} prompt=${prompt.substring(0, 100)} imageSize=${Math.round(base64Data.length * 3 / 4 / 1024)}KB`);
|
|
359
359
|
|
|
@@ -440,14 +440,66 @@ function analyzeViaCliProxy(base64Data, mediaType, model, prompt, timeoutMs) {
|
|
|
440
440
|
});
|
|
441
441
|
}
|
|
442
442
|
|
|
443
|
+
/**
|
|
444
|
+
* Parse the provider fallback chain emitted by model-router
|
|
445
|
+
* (MCC_IMAGE_ANALYSIS_PROVIDERS = JSON array). Each entry is self-contained
|
|
446
|
+
* — its own baseUrl / apiKey / model / format — so the runtime can try a
|
|
447
|
+
* different provider entirely when one 402s or errors. Returns null when the
|
|
448
|
+
* env var is absent, so the legacy single-endpoint path is preserved.
|
|
449
|
+
*/
|
|
450
|
+
function getProvidersToTry() {
|
|
451
|
+
const raw = process.env.MCC_IMAGE_ANALYSIS_PROVIDERS;
|
|
452
|
+
if (!raw || !raw.trim()) return null;
|
|
453
|
+
let arr;
|
|
454
|
+
try {
|
|
455
|
+
arr = JSON.parse(raw);
|
|
456
|
+
} catch {
|
|
457
|
+
return null;
|
|
458
|
+
}
|
|
459
|
+
if (!Array.isArray(arr) || arr.length === 0) return null;
|
|
460
|
+
const providers = arr
|
|
461
|
+
.filter((p) => p && p.baseUrl && p.apiKey && p.model)
|
|
462
|
+
.map((p) => {
|
|
463
|
+
const format = (p.format || 'anthropic').toLowerCase();
|
|
464
|
+
const base = String(p.baseUrl).trim().replace(/\/+$/, '');
|
|
465
|
+
const endpoint = format === 'openai' ? `${base}/chat/completions` : `${base}/v1/messages`;
|
|
466
|
+
return { id: p.id || base, endpoint, apiKey: p.apiKey, format, model: p.model };
|
|
467
|
+
});
|
|
468
|
+
return providers.length > 0 ? providers : null;
|
|
469
|
+
}
|
|
470
|
+
|
|
443
471
|
async function analyzeWithRetry(base64Data, mediaType, prompt, timeoutMs) {
|
|
472
|
+
// Preferred path: explicit provider chain → try each provider in order,
|
|
473
|
+
// falling through on ANY error (402 / auth / rate-limit / network).
|
|
474
|
+
const providers = getProvidersToTry();
|
|
475
|
+
if (providers) {
|
|
476
|
+
let lastError = null;
|
|
477
|
+
for (const [index, p] of providers.entries()) {
|
|
478
|
+
try {
|
|
479
|
+
log.debug('ImageRuntime', `Trying provider ${index + 1}/${providers.length} id=${p.id} model=${p.model} endpoint=${p.endpoint}`);
|
|
480
|
+
const description = await analyzeViaCliProxy(
|
|
481
|
+
{ endpoint: p.endpoint, apiKey: p.apiKey, format: p.format },
|
|
482
|
+
base64Data, mediaType, p.model, prompt, timeoutMs,
|
|
483
|
+
);
|
|
484
|
+
return { description, model: p.model, provider: p.id };
|
|
485
|
+
} catch (error) {
|
|
486
|
+
lastError = error;
|
|
487
|
+
const more = index < providers.length - 1;
|
|
488
|
+
log.debug('ImageRuntime', `Provider ${p.id} failed: ${error.message}${more ? ' — falling back to next' : ' — no more providers'}`);
|
|
489
|
+
}
|
|
490
|
+
}
|
|
491
|
+
throw lastError || new Error('No image analysis providers succeeded');
|
|
492
|
+
}
|
|
493
|
+
|
|
494
|
+
// Legacy path: single endpoint from env, retry across model candidates.
|
|
495
|
+
const envProvider = { endpoint: getRuntimeEndpoint(), apiKey: getApiKey(), format: getFormat() };
|
|
444
496
|
const models = getModelsToTry();
|
|
445
497
|
let lastError = null;
|
|
446
498
|
|
|
447
499
|
for (const [index, model] of models.entries()) {
|
|
448
500
|
try {
|
|
449
501
|
log.debug('ImageRuntime', `Trying model ${index + 1}/${models.length} model=${model}`);
|
|
450
|
-
const description = await analyzeViaCliProxy(base64Data, mediaType, model, prompt, timeoutMs);
|
|
502
|
+
const description = await analyzeViaCliProxy(envProvider, base64Data, mediaType, model, prompt, timeoutMs);
|
|
451
503
|
return { description, model };
|
|
452
504
|
} catch (error) {
|
|
453
505
|
lastError = error;
|
|
@@ -492,6 +544,7 @@ async function analyzeFile(filePath, options = {}) {
|
|
|
492
544
|
return {
|
|
493
545
|
description: result.description,
|
|
494
546
|
model: result.model,
|
|
547
|
+
provider: result.provider,
|
|
495
548
|
fileSize: stats.size,
|
|
496
549
|
mediaType,
|
|
497
550
|
template,
|
package/lib/shared/logger.cjs
CHANGED
|
@@ -95,8 +95,12 @@ function format(level, message, component) {
|
|
|
95
95
|
function write(level, message, component) {
|
|
96
96
|
if (levelValue(level) > _minLevel) return;
|
|
97
97
|
const line = format(level, message, component);
|
|
98
|
-
process.stderr.write(line + '\n');
|
|
99
98
|
writeFile(line);
|
|
99
|
+
// error/warn always echo to stderr; debug echoes only when debug mode is on; info is file-only
|
|
100
|
+
const lv = levelValue(level);
|
|
101
|
+
if (lv <= LEVELS.warn || _minLevel >= LEVELS.debug) {
|
|
102
|
+
process.stderr.write(line + '\n');
|
|
103
|
+
}
|
|
100
104
|
}
|
|
101
105
|
|
|
102
106
|
// --- 导出---
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hileeon/mcc",
|
|
3
|
-
"version": "0.
|
|
3
|
+
"version": "0.3.0",
|
|
4
4
|
"description": "My Claude Code - Multi-provider account and model switching for Claude Code",
|
|
5
5
|
"license": "MIT",
|
|
6
6
|
"author": "Leeon",
|
|
@@ -38,14 +38,12 @@
|
|
|
38
38
|
"dependencies": {
|
|
39
39
|
"cors": "^2.8.5",
|
|
40
40
|
"express": "^4.18.2",
|
|
41
|
-
"picocolors": "^1.1.1"
|
|
42
|
-
"update-notifier": "^5.1.0"
|
|
41
|
+
"picocolors": "^1.1.1"
|
|
43
42
|
},
|
|
44
43
|
"devDependencies": {
|
|
45
44
|
"@types/cors": "^2.8.17",
|
|
46
45
|
"@types/express": "^4.17.21",
|
|
47
46
|
"@types/node": "^20.0.0",
|
|
48
|
-
"@types/update-notifier": "^6.0.8",
|
|
49
47
|
"concurrently": "^10.0.3",
|
|
50
48
|
"tsx": "^4.22.4",
|
|
51
49
|
"typescript": "^5.3.0"
|