Update AppImage

This commit is contained in:
MacRimi
2025-11-22 20:27:41 +01:00
parent dd3e5ea368
commit e3dd6cbef5
2 changed files with 132 additions and 156 deletions

View File

@@ -1,156 +1,133 @@
@import "tailwindcss"; @tailwind base;
@import "tw-animate-css"; @tailwind components;
@tailwind utilities;
@custom-variant dark (&:is(.dark *));
/* ===================== */
/* Light Mode (default) */
/* ===================== */
:root { :root {
--background: oklch(1 0 0); --background: oklch(1 0 0); /* blanco */
--foreground: oklch(0.145 0 0); --foreground: oklch(0.145 0 0); /* casi negro */
--card: oklch(1 0 0); --card: oklch(1 0 0);
--card-foreground: oklch(0.145 0 0); --card-foreground: var(--foreground);
--popover: oklch(1 0 0);
--popover-foreground: oklch(0.145 0 0); --popover: var(--card);
--primary: oklch(0.205 0 0); --popover-foreground: var(--foreground);
--primary-foreground: oklch(0.985 0 0);
--primary: oklch(0.205 0 0); /* gris oscuro */
--primary-foreground: oklch(0.985 0 0); /* blanco */
--secondary: oklch(0.97 0 0); --secondary: oklch(0.97 0 0);
--secondary-foreground: oklch(0.205 0 0); --secondary-foreground: var(--primary);
--muted: oklch(0.97 0 0); --muted: oklch(0.97 0 0);
--muted-foreground: oklch(0.556 0 0); --muted-foreground: oklch(0.556 0 0); /* gris medio */
--accent: oklch(0.97 0 0); --accent: oklch(0.97 0 0);
--accent-foreground: oklch(0.205 0 0); --accent-foreground: var(--primary);
--destructive: oklch(0.577 0.245 27.325); --destructive: oklch(0.577 0.245 27.325);
--destructive-foreground: oklch(0.577 0.245 27.325); --destructive-foreground: oklch(0.145 0 0);
--border: oklch(0.922 0 0); --border: oklch(0.922 0 0);
--input: oklch(0.922 0 0); --input: var(--border);
--ring: oklch(0.708 0 0); --ring: oklch(0.708 0 0);
--chart-1: oklch(0.646 0.222 41.116); --chart-1: oklch(0.646 0.222 41.116);
--chart-2: oklch(0.6 0.118 184.704); --chart-2: oklch(0.6 0.118 184.704);
--chart-3: oklch(0.398 0.07 227.392); --chart-3: oklch(0.398 0.07 227.392);
--chart-4: oklch(0.828 0.189 84.429); --chart-4: oklch(0.828 0.189 84.429);
--chart-5: oklch(0.769 0.188 70.08); --chart-5: oklch(0.769 0.188 70.08);
--radius: 0.625rem; --radius: 0.625rem;
--sidebar: oklch(0.985 0 0); --sidebar: oklch(0.985 0 0);
--sidebar-foreground: oklch(0.145 0 0); --sidebar-foreground: var(--foreground);
--sidebar-primary: oklch(0.205 0 0); --sidebar-primary: var(--primary);
--sidebar-primary-foreground: oklch(0.985 0 0); --sidebar-primary-foreground: oklch(0.985 0 0);
--sidebar-accent: oklch(0.97 0 0); --sidebar-accent: oklch(0.97 0 0);
--sidebar-accent-foreground: oklch(0.205 0 0); --sidebar-accent-foreground: var(--primary);
--sidebar-border: oklch(0.922 0 0); --sidebar-border: var(--border);
--sidebar-ring: oklch(0.708 0 0); --sidebar-ring: var(--ring);
} }
/* ===================== */
/* Dark Mode (gris) */
/* ===================== */
.dark { .dark {
--background: oklch(0.145 0 0); --background: oklch(0.22 0 0); /* gris oscuro */
--foreground: oklch(0.985 0 0); --foreground: oklch(0.97 0 0); /* blanco/gris claro */
--card: oklch(0.145 0 0);
--card-foreground: oklch(0.985 0 0); --card: oklch(0.24 0 0);
--popover: oklch(0.145 0 0); --card-foreground: var(--foreground);
--popover-foreground: oklch(0.985 0 0);
--primary: oklch(0.985 0 0); --popover: var(--card);
--primary-foreground: oklch(0.205 0 0); --popover-foreground: var(--foreground);
--secondary: oklch(0.269 0 0);
--secondary-foreground: oklch(0.985 0 0); --primary: oklch(0.83 0 0); /* casi blanco */
--muted: oklch(0.269 0 0); --primary-foreground: var(--background);
--muted-foreground: oklch(0.708 0 0);
--accent: oklch(0.269 0 0); --secondary: oklch(0.28 0 0);
--accent-foreground: oklch(0.985 0 0); --secondary-foreground: oklch(0.92 0 0);
--destructive: oklch(0.396 0.141 25.723);
--destructive-foreground: oklch(0.637 0.237 25.331); --muted: oklch(0.26 0 0);
--border: oklch(0.269 0 0); --muted-foreground: oklch(0.72 0 0);
--input: oklch(0.269 0 0);
--ring: oklch(0.439 0 0); --accent: oklch(0.28 0 0);
--chart-1: oklch(0.488 0.243 264.376); --accent-foreground: var(--primary);
--chart-2: oklch(0.696 0.17 162.48);
--chart-3: oklch(0.769 0.188 70.08); --destructive: oklch(0.53 0.25 27);
--chart-4: oklch(0.627 0.265 303.9); --destructive-foreground: oklch(0.9 0 0);
--chart-5: oklch(0.645 0.246 16.439);
--sidebar: oklch(0.205 0 0); --border: oklch(0.34 0 0);
--sidebar-foreground: oklch(0.985 0 0); --input: var(--border);
--sidebar-primary: oklch(0.488 0.243 264.376); --ring: oklch(0.55 0 0);
--sidebar-primary-foreground: oklch(0.985 0 0);
--sidebar-accent: oklch(0.269 0 0); --chart-1: oklch(0.60 0.20 255);
--sidebar-accent-foreground: oklch(0.985 0 0); --chart-2: oklch(0.70 0.16 165);
--sidebar-border: oklch(0.269 0 0); --chart-3: oklch(0.76 0.19 70);
--sidebar-ring: oklch(0.439 0 0); --chart-4: oklch(0.63 0.25 305);
} --chart-5: oklch(0.66 0.24 20);
@theme inline { --sidebar: oklch(0.24 0 0);
/* optional: --font-sans, --font-serif, --font-mono if they are applied in the layout.tsx */ --sidebar-foreground: var(--foreground);
--color-background: var(--background); --sidebar-primary: var(--chart-1);
--color-foreground: var(--foreground); --sidebar-primary-foreground: var(--foreground);
--color-card: var(--card); --sidebar-accent: oklch(0.28 0 0);
--color-card-foreground: var(--card-foreground); --sidebar-accent-foreground: var(--foreground);
--color-popover: var(--popover); --sidebar-border: var(--border);
--color-popover-foreground: var(--popover-foreground); --sidebar-ring: var(--ring);
--color-primary: var(--primary);
--color-primary-foreground: var(--primary-foreground);
--color-secondary: var(--secondary);
--color-secondary-foreground: var(--secondary-foreground);
--color-muted: var(--muted);
--color-muted-foreground: var(--muted-foreground);
--color-accent: var(--accent);
--color-accent-foreground: var(--accent-foreground);
--color-destructive: var(--destructive);
--color-destructive-foreground: var(--destructive-foreground);
--color-border: var(--border);
--color-input: var(--input);
--color-ring: var(--ring);
--color-chart-1: var(--chart-1);
--color-chart-2: var(--chart-2);
--color-chart-3: var(--chart-3);
--color-chart-4: var(--chart-4);
--color-chart-5: var(--chart-5);
--radius-sm: calc(var(--radius) - 4px);
--radius-md: calc(var(--radius) - 2px);
--radius-lg: var(--radius);
--radius-xl: calc(var(--radius) + 4px);
--color-sidebar: var(--sidebar);
--color-sidebar-foreground: var(--sidebar-foreground);
--color-sidebar-primary: var(--sidebar-primary);
--color-sidebar-primary-foreground: var(--sidebar-primary-foreground);
--color-sidebar-accent: var(--sidebar-accent);
--color-sidebar-accent-foreground: var(--sidebar-accent-foreground);
--color-sidebar-border: var(--sidebar-border);
--color-sidebar-ring: var(--sidebar-ring);
} }
/* ===================== */
/* Base layer */
/* ===================== */
@layer base { @layer base {
* { * {
@apply border-border outline-ring/50; @apply border-border;
} }
body { body {
@apply bg-background text-foreground; @apply bg-background text-foreground;
} }
}
/* ===================== */
/* Base Styles */
/* ===================== */
/* Removed @layer and converted to native CSS for Tailwind v4 compatibility */
* {
border-color: var(--border);
outline-color: color-mix(in oklch, var(--ring), transparent 50%);
}
body {
background-color: var(--background);
color: var(--foreground);
}
/* Foco accesible */ /* Foco accesible */
:is(button,[role="button"],a,input,select,textarea,[tabindex]:not([tabindex="-1"])):focus { :is(button,[role="button"],a,input,select,textarea,[tabindex]:not([tabindex="-1"])):focus {
outline: none; @apply outline-none;
} }
:is(button,[role="button"],a,input,select,textarea,[tabindex]:not([tabindex="-1"])):focus-visible { :is(button,[role="button"],a,input,select,textarea,[tabindex]:not([tabindex="-1"])):focus-visible {
outline: 2px solid color-mix(in oklch, var(--ring), transparent 50%); @apply ring-2;
outline-offset: 2px; --tw-ring-color: var(--ring);
--tw-ring-opacity: 0.5; /* equivalente al /50 */
}
} }
/* ===================== */
/* Ajustes para Charts */
/* ===================== */
@layer components { @layer components {
/* ===================== */ /* Recharts axis */
/* Recharts axis styles */
/* ===================== */
.recharts-cartesian-axis-tick tspan { .recharts-cartesian-axis-tick tspan {
fill: var(--muted-foreground); fill: var(--muted-foreground);
} }
@@ -159,44 +136,11 @@ body {
stroke: var(--border); stroke: var(--border);
} }
/* ===================== */ /* Chart.js axis */
/* Chart.js axis styles */
/* ===================== */
.chartjs-render-monitor text { .chartjs-render-monitor text {
fill: var(--muted-foreground); fill: var(--muted-foreground);
} }
.chartjs-render-monitor line { .chartjs-render-monitor line {
stroke: var(--border); stroke: var(--border);
} }
/* ===================== */
/* Terminal Fixes */
/* ===================== */
/* Fixed xterm.js padding to center dialog menus correctly */
.xterm {
padding: 0 !important;
margin: 0 !important;
width: 100% !important;
height: 100% !important;
}
.xterm .xterm-viewport {
width: 100% !important;
overflow-y: scroll !important;
overflow-x: hidden !important;
}
.xterm .xterm-screen {
width: 100% !important;
}
.xterm .xterm-rows {
padding: 0 !important;
}
.xterm .xterm-helpers {
position: absolute;
top: 0;
left: 0;
}
} }

View File

@@ -319,9 +319,26 @@ export const TerminalPanel: React.FC<TerminalPanelProps> = ({ websocketUrl, onCl
term.open(container) term.open(container)
const xtermElement = container.querySelector(".xterm") as HTMLElement
const xtermViewport = container.querySelector(".xterm-viewport") as HTMLElement
const xtermScreen = container.querySelector(".xterm-screen") as HTMLElement
if (xtermElement) {
xtermElement.style.padding = "0"
xtermElement.style.margin = "0"
}
if (xtermViewport) {
xtermViewport.style.padding = "0"
xtermViewport.style.margin = "0"
}
if (xtermScreen) {
xtermScreen.style.padding = "0"
xtermScreen.style.margin = "0"
}
setTimeout(() => { setTimeout(() => {
fitAddon.fit() fitAddon.fit()
}, 100) }, 50)
const wsUrl = websocketUrl || getWebSocketUrl() const wsUrl = websocketUrl || getWebSocketUrl()
const ws = new WebSocket(wsUrl) const ws = new WebSocket(wsUrl)
@@ -563,7 +580,15 @@ export const TerminalPanel: React.FC<TerminalPanelProps> = ({ websocketUrl, onCl
</TabsList> </TabsList>
{terminals.map((terminal) => ( {terminals.map((terminal) => (
<TabsContent key={terminal.id} value={terminal.id} className="flex-1 m-0 p-0"> <TabsContent key={terminal.id} value={terminal.id} className="flex-1 m-0 p-0">
<div ref={setContainerRef(terminal.id)} className="w-full h-full bg-black overflow-hidden" /> <div
ref={setContainerRef(terminal.id)}
className="w-full h-full bg-black overflow-hidden"
style={{
height: "calc(100vh - 24rem)",
padding: 0,
margin: 0,
}}
/>
</TabsContent> </TabsContent>
))} ))}
</Tabs> </Tabs>
@@ -586,7 +611,14 @@ export const TerminalPanel: React.FC<TerminalPanelProps> = ({ websocketUrl, onCl
</button> </button>
)} )}
</div> </div>
<div ref={setContainerRef(terminal.id)} className="w-full h-full bg-black overflow-hidden" /> <div
ref={setContainerRef(terminal.id)}
className="w-full h-full bg-black pt-7 overflow-hidden"
style={{
padding: "1.75rem 0 0 0",
margin: 0,
}}
/>
</div> </div>
))} ))}
</div> </div>