* fix select edit host but not update view (#438) * fix: Checksum issue with chocolatey * fix: Remove homebrew old stuff * Add Korean translation (#439) Co-authored-by: 송준우 <2484@coreit.co.kr> * feat: Automate flatpak * fix: Add imagemagik to electron builder to resolve build error * fix: Build error with runtime repo flag * fix: Flatpak runtime error and install freedesktop ver warning * fix: Flatpak runtime error and install freedesktop ver warning * feat: Re-add homebrew cask and move scripts to backend * fix: No sandbox flag issue * fix: Change name for electron macos cask output * fix: Sandbox error with Linux * fix: Remove comming soon for app stores in readme * Adding Comment at the end of the public_key on the host on deploy (#440) * Add termix.rb Cask file * Update Termix to version 1.9.0 with new checksum * Update README to remove 'coming soon' notes * -Add New Interface for Credential DB -Add Credential Name as a comment into the server authorized_key file --------- Co-authored-by: Luke Gustafson <88517757+LukeGus@users.noreply.github.com> * Sudo auto fill password (#441) * Add termix.rb Cask file * Update Termix to version 1.9.0 with new checksum * Update README to remove 'coming soon' notes * Feature Sudo password auto-fill; * Fix locale json shema; --------- Co-authored-by: Luke Gustafson <88517757+LukeGus@users.noreply.github.com> * Added Italian Language; (#445) * Add termix.rb Cask file * Update Termix to version 1.9.0 with new checksum * Update README to remove 'coming soon' notes * Added Italian Language; --------- Co-authored-by: Luke Gustafson <88517757+LukeGus@users.noreply.github.com> * Auto collapse snippet folders (#448) * Add termix.rb Cask file * Update Termix to version 1.9.0 with new checksum * Update README to remove 'coming soon' notes * feat: Add collapsable snippets (customizable in user profile) * Translations (#447) * Add termix.rb Cask file * Update Termix to version 1.9.0 with new checksum * Update README to remove 'coming soon' notes * Added Italian Language; * Fix translations; Removed duplicate keys, synchronised other languages using English as the source, translated added keys, fixed inaccurate translations. --------- Co-authored-by: Luke Gustafson <88517757+LukeGus@users.noreply.github.com> * Remove PTY-level keepalive (#449) * Add termix.rb Cask file * Update Termix to version 1.9.0 with new checksum * Update README to remove 'coming soon' notes * Remove PTY-level keepalive to prevent unwanted terminal output; use SSH-level keepalive instead --------- Co-authored-by: Luke Gustafson <88517757+LukeGus@users.noreply.github.com> * feat: Seperate server stats and tunnel management (improved both UI's) then started initial docker implementation * fix: finalize adding docker to db * feat: Add docker management support (local squash) * Fix RBAC role system bugs and improve UX (#446) * Fix RBAC role system bugs and improve UX - Fix user list dropdown selection in host sharing - Fix role sharing permissions to include role-based access - Fix translation template interpolation for success messages - Standardize system roles to admin and user only - Auto-assign user role to new registrations - Remove blocking confirmation dialogs in modal contexts - Add missing i18n keys for common actions - Fix button type to prevent unintended form submissions * Enhance RBAC system with UI improvements and security fixes - Move role assignment to Users tab with per-user role management - Protect system roles (admin/user) from editing and manual assignment - Simplify permission system: remove Use level, keep View and Manage - Hide Update button and Sharing tab for view-only/shared hosts - Prevent users from sharing hosts with themselves - Unify table and modal styling across admin panels - Auto-assign system roles on user registration - Add permission metadata to host interface * Add empty state message for role assignment - Display helpful message when no custom roles available - Clarify that system roles are auto-assigned - Add noCustomRolesToAssign translation in English and Chinese * fix: Prevent credential sharing errors for shared hosts - Skip credential resolution for shared hosts with credential authentication to prevent decryption errors (credentials are encrypted per-user) - Add warning alert in sharing tab when host uses credential authentication - Inform users that shared users cannot connect to credential-based hosts - Add translations for credential sharing warning (EN/ZH) This prevents authentication failures when sharing hosts configured with credential authentication while maintaining security by keeping credentials isolated per user. * feat: Improve rbac UI and fixes some bugs --------- Co-authored-by: Luke Gustafson <88517757+LukeGus@users.noreply.github.com> Co-authored-by: LukeGus <bugattiguy527@gmail.com> * SOCKS5 support (#452) * Add termix.rb Cask file * Update Termix to version 1.9.0 with new checksum * Update README to remove 'coming soon' notes * SOCKS5 support Adding single and chain socks5 proxy support * fix: cleanup files --------- Co-authored-by: Luke Gustafson <88517757+LukeGus@users.noreply.github.com> Co-authored-by: LukeGus <bugattiguy527@gmail.com> * Notes and Expiry fields add (#453) * Add termix.rb Cask file * Update Termix to version 1.9.0 with new checksum * Update README to remove 'coming soon' notes * Notes and Expiry add * fix: cleanup files --------- Co-authored-by: Luke Gustafson <88517757+LukeGus@users.noreply.github.com> Co-authored-by: LukeGus <bugattiguy527@gmail.com> * fix: ssh host types * fix: sudo incorrect styling and remove expiration date * feat: add sudo password and add diagonal bg's * fix: snippet running on enter key * fix: base64 decoding * fix: improve server stats / rbac * fix: wrap ssh host json export in hosts array * feat: auto trim host inputs, fix file manager jump hosts, dashboard prevent duplicates, file manager terminal not size updating, improve left sidebar sorting, hide/show tags, add apperance user profile tab, add new host manager tabs. * feat: improve terminal connection speed * fix: sqlite constriant errors and support non-root user (nginx perm issue) * feat: add beta syntax highlighing to terminal * feat: update imports and improve admin settings user management * chore: update translations * chore: update translations * feat: Complete light mode implementation with semantic theme system (#450) - Add comprehensive light/dark mode CSS variables with semantic naming - Implement theme-aware scrollbars using CSS variables - Add light mode backgrounds: --bg-base, --bg-elevated, --bg-surface, etc. - Add theme-aware borders: --border-base, --border-panel, --border-subtle - Add semantic text colors: --foreground-secondary, --foreground-subtle - Convert oklch colors to hex for better compatibility - Add theme awareness to CodeMirror editors - Update dark mode colors for consistency (background, sidebar, card, muted, input) - Add Tailwind color mappings for semantic classes Co-authored-by: Luke Gustafson <88517757+LukeGus@users.noreply.github.com> * fix: syntax errors * chore: updating/match themes and split admin settings * feat: add translation workflow and remove old translation.json * fix: translation workflow error * fix: translation workflow error * feat: improve translation system and update workflow * fix: wrong path for translations * fix: change translation to flat files * fix: gh rule error * chore: auto-translate to multiple languages (#458) * chore: improve organization and made a few styling changes in host manager * feat: improve terminal stability and split out the host manager * fix: add unnversiioned files * chore: migrate all to use the new theme system * fix: wrong animation line colors * fix: rbac implementation general issues (local squash) * fix: remove unneeded files * feat: add 10 new langs * chore: update gitnore * chore: auto-translate to multiple languages (#459) * fix: improve tunnel system * fix: properly split tabs, still need to fix up the host manager * chore: cleanup files (possible RC) * feat: add norwegian * chore: auto-translate to multiple languages (#461) * fix: small qol fixes and began readme update * fix: run cleanup script * feat: add docker docs button * feat: general bug fixes and readme updates * fix: translations * chore: auto-translate to multiple languages (#462) * fix: cleanup files * fix: test new translation issue and add better server-stats support * fix: fix translate error * chore: auto-translate to multiple languages (#463) * fix: fix translate mismatching text * chore: auto-translate to multiple languages (#465) * fix: fix translate mismatching text * fix: fix translate mismatching text * chore: auto-translate to multiple languages (#466) * fix: fix translate mismatching text * fix: fix translate mismatching text * fix: fix translate mismatching text * chore: auto-translate to multiple languages (#467) * fix: fix translate mismatching text * chore: auto-translate to multiple languages (#468) * feat: add to readme, a few qol changes, and improve server stats in general * chore: auto-translate to multiple languages (#469) * feat: turned disk uage into graph and fixed issue with termina console * fix: electron build error and hide icons when shared * chore: run clean * fix: general server stats issues, file manager decoding, ui qol * fix: add dashboard line breaks * fix: docker console error * fix: docker console not loading and mismatched stripped background for electron * fix: docker console not loading * chore: docker console not loading in docker * chore: translate readme to chinese * chore: match package lock to package json * chore: nginx config issue for dokcer console * chore: auto-translate to multiple languages (#470) --------- Co-authored-by: Tran Trung Kien <kientt13.7@gmail.com> Co-authored-by: junu <bigdwarf_@naver.com> Co-authored-by: 송준우 <2484@coreit.co.kr> Co-authored-by: SlimGary <trash.slim@gmail.com> Co-authored-by: Nunzio Marfè <nunzio.marfe@protonmail.com> Co-authored-by: Wesley Reid <starhound@lostsouls.org> Co-authored-by: ZacharyZcR <zacharyzcr1984@gmail.com> Co-authored-by: Denis <38875137+Medvedinca@users.noreply.github.com> Co-authored-by: Peet McKinney <68706879+PeetMcK@users.noreply.github.com>
296 lines
7.7 KiB
CSS
296 lines
7.7 KiB
CSS
@import "tailwindcss";
|
|
|
|
@custom-variant dark (&:is(.dark *));
|
|
|
|
:root {
|
|
font-family: system-ui, Avenir, Helvetica, Arial, sans-serif;
|
|
line-height: 1.5;
|
|
font-weight: 400;
|
|
|
|
color-scheme: light dark;
|
|
color: var(--foreground);
|
|
background-color: var(--bg-base);
|
|
|
|
font-synthesis: none;
|
|
text-rendering: optimizeLegibility;
|
|
-webkit-font-smoothing: antialiased;
|
|
-moz-osx-font-smoothing: grayscale;
|
|
--radius: 0.625rem;
|
|
--background: #ffffff;
|
|
--foreground: #18181b;
|
|
--card: #ffffff;
|
|
--card-foreground: #18181b;
|
|
--popover: #ffffff;
|
|
--popover-foreground: #18181b;
|
|
--primary: #27272a;
|
|
--primary-foreground: #fafafa;
|
|
--secondary: #f4f4f5;
|
|
--secondary-foreground: #27272a;
|
|
--muted: #f4f4f5;
|
|
--muted-foreground: #71717a;
|
|
--accent: #f4f4f5;
|
|
--accent-foreground: #27272a;
|
|
--destructive: #dc2626;
|
|
--border: #e4e4e7;
|
|
--input: #e4e4e7;
|
|
--ring: #a1a1aa;
|
|
--chart-1: #e76e50;
|
|
--chart-2: #2a9d8f;
|
|
--chart-3: #264653;
|
|
--chart-4: #e9c46a;
|
|
--chart-5: #f4a261;
|
|
--sidebar: #f9f9f9;
|
|
--sidebar-foreground: #18181b;
|
|
--sidebar-primary: #27272a;
|
|
--sidebar-primary-foreground: #fafafa;
|
|
--sidebar-accent: #f4f4f5;
|
|
--sidebar-accent-foreground: #27272a;
|
|
--sidebar-border: #e4e4e7;
|
|
--sidebar-ring: #a1a1aa;
|
|
|
|
--bg-base: #fcfcfc;
|
|
--bg-elevated: #ffffff;
|
|
--bg-surface: #f3f4f6;
|
|
--bg-surface-hover: #e5e7eb;
|
|
--bg-input: #ffffff;
|
|
--bg-deepest: #e5e7eb;
|
|
--bg-header: #eeeeef;
|
|
--bg-button: #f3f4f6;
|
|
--bg-active: #e5e7eb;
|
|
--bg-light: #fafafa;
|
|
--bg-subtle: #f5f5f5;
|
|
--bg-interact: #d1d5db;
|
|
--border-base: #e5e7eb;
|
|
--border-panel: #d1d5db;
|
|
--border-subtle: #f3f4f6;
|
|
--border-medium: #d1d5db;
|
|
--bg-hover: #f3f4f6;
|
|
--bg-hover-alt: #e5e7eb;
|
|
--bg-pressed: #d1d5db;
|
|
--border-hover: #d1d5db;
|
|
--border-active: #9ca3af;
|
|
|
|
--foreground-secondary: #334155;
|
|
--foreground-subtle: #94a3b8;
|
|
|
|
--scrollbar-thumb: #c1c1c3;
|
|
--scrollbar-thumb-hover: #a1a1a3;
|
|
--scrollbar-track: #f3f4f6;
|
|
|
|
--bg-overlay: rgba(0, 0, 0, 0.5);
|
|
}
|
|
|
|
@theme inline {
|
|
--radius-sm: calc(var(--radius) - 4px);
|
|
--radius-md: calc(var(--radius) - 2px);
|
|
--radius-lg: var(--radius);
|
|
--radius-xl: calc(var(--radius) + 4px);
|
|
--color-background: var(--background);
|
|
--color-foreground: var(--foreground);
|
|
--color-card: var(--card);
|
|
--color-card-foreground: var(--card-foreground);
|
|
--color-popover: var(--popover);
|
|
--color-popover-foreground: var(--popover-foreground);
|
|
--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-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);
|
|
--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);
|
|
|
|
--color-dark-bg: #18181b;
|
|
--color-dark-bg-darker: #0e0e10;
|
|
--color-dark-bg-darkest: #09090b;
|
|
--color-dark-bg-input: #222225;
|
|
--color-dark-bg-button: #23232a;
|
|
--color-dark-bg-active: #1d1d1f;
|
|
--color-dark-bg-header: #131316;
|
|
--color-dark-border: #303032;
|
|
--color-dark-border-active: #2d2d30;
|
|
--color-dark-border-hover: #434345;
|
|
--color-dark-hover: #2d2d30;
|
|
--color-dark-active: #2a2a2c;
|
|
--color-dark-pressed: #1a1a1c;
|
|
--color-dark-hover-alt: #2a2a2d;
|
|
--color-dark-border-light: #5a5a5d;
|
|
--color-dark-bg-light: #141416;
|
|
--color-dark-border-medium: #373739;
|
|
--color-dark-bg-very-light: #101014;
|
|
--color-dark-bg-panel: #1b1b1e;
|
|
--color-dark-border-panel: #222224;
|
|
--color-dark-bg-panel-hover: #232327;
|
|
|
|
--color-canvas: var(--bg-base);
|
|
--color-elevated: var(--bg-elevated);
|
|
--color-surface: var(--bg-surface);
|
|
--color-surface-hover: var(--bg-surface-hover);
|
|
--color-field: var(--bg-input);
|
|
--color-deepest: var(--bg-deepest);
|
|
--color-header: var(--bg-header);
|
|
--color-button: var(--bg-button);
|
|
--color-active: var(--bg-active);
|
|
--color-light: var(--bg-light);
|
|
--color-subtle: var(--bg-subtle);
|
|
--color-interact: var(--bg-interact);
|
|
--color-hover: var(--bg-hover);
|
|
--color-hover-alt: var(--bg-hover-alt);
|
|
--color-pressed: var(--bg-pressed);
|
|
|
|
--color-edge: var(--border-base);
|
|
--color-edge-panel: var(--border-panel);
|
|
--color-edge-subtle: var(--border-subtle);
|
|
--color-edge-medium: var(--border-medium);
|
|
--color-edge-hover: var(--border-hover);
|
|
--color-edge-active: var(--border-active);
|
|
|
|
--color-foreground-secondary: var(--foreground-secondary);
|
|
--color-foreground-subtle: var(--foreground-subtle);
|
|
|
|
--color-overlay: var(--bg-overlay);
|
|
}
|
|
|
|
.dark {
|
|
--background: #09090b;
|
|
--foreground: #fafafa;
|
|
--card: #18181b;
|
|
--card-foreground: #fafafa;
|
|
--popover: #27272a;
|
|
--popover-foreground: #fafafa;
|
|
--primary: #e4e4e7;
|
|
--primary-foreground: #27272a;
|
|
--secondary: #3f3f46;
|
|
--secondary-foreground: #fafafa;
|
|
--muted: #27272a;
|
|
--muted-foreground: #9ca3af;
|
|
--accent: #3f3f46;
|
|
--accent-foreground: #fafafa;
|
|
--destructive: #f87171;
|
|
--border: #ffffff1a;
|
|
--input: #ffffff26;
|
|
--ring: #71717a;
|
|
--chart-1: #3b82f6;
|
|
--chart-2: #34d399;
|
|
--chart-3: #f4a261;
|
|
--chart-4: #a855f7;
|
|
--chart-5: #f43f5e;
|
|
--sidebar: #18181b;
|
|
--sidebar-foreground: #fafafa;
|
|
--sidebar-primary: #3b82f6;
|
|
--sidebar-primary-foreground: #fafafa;
|
|
--sidebar-accent: #3f3f46;
|
|
--sidebar-accent-foreground: #fafafa;
|
|
--sidebar-border: #ffffff1a;
|
|
--sidebar-ring: #71717a;
|
|
|
|
--bg-base: #18181b;
|
|
--bg-elevated: #0e0e10;
|
|
--bg-surface: #1b1b1e;
|
|
--bg-surface-hover: #232327;
|
|
--bg-input: #222225;
|
|
--bg-deepest: #09090b;
|
|
--bg-header: #131316;
|
|
--bg-button: #23232a;
|
|
--bg-active: #1d1d1f;
|
|
--bg-light: #141416;
|
|
--bg-subtle: #101014;
|
|
--bg-interact: #2a2a2c;
|
|
--border-base: #303032;
|
|
--border-panel: #222224;
|
|
--border-subtle: #5a5a5d;
|
|
--border-medium: #373739;
|
|
--bg-hover: #2d2d30;
|
|
--bg-hover-alt: #2a2a2d;
|
|
--bg-pressed: #1a1a1c;
|
|
--border-hover: #434345;
|
|
--border-active: #2d2d30;
|
|
|
|
--foreground-secondary: #d1d5db;
|
|
--foreground-subtle: #6b7280;
|
|
|
|
--scrollbar-thumb: #434345;
|
|
--scrollbar-thumb-hover: #5a5a5d;
|
|
--scrollbar-track: #18181b;
|
|
|
|
--bg-overlay: rgba(0, 0, 0, 0.7);
|
|
}
|
|
|
|
@layer base {
|
|
html,
|
|
body {
|
|
height: 100%;
|
|
}
|
|
|
|
* {
|
|
@apply border-border outline-ring/50;
|
|
}
|
|
|
|
body {
|
|
@apply bg-background text-foreground;
|
|
}
|
|
}
|
|
|
|
.thin-scrollbar {
|
|
scrollbar-width: thin;
|
|
scrollbar-color: var(--scrollbar-thumb) var(--scrollbar-track);
|
|
}
|
|
|
|
.thin-scrollbar::-webkit-scrollbar {
|
|
width: 6px;
|
|
height: 6px;
|
|
}
|
|
|
|
.thin-scrollbar::-webkit-scrollbar-track {
|
|
background: var(--scrollbar-track);
|
|
}
|
|
|
|
.thin-scrollbar::-webkit-scrollbar-thumb {
|
|
background: var(--scrollbar-thumb);
|
|
border-radius: 3px;
|
|
}
|
|
|
|
.thin-scrollbar::-webkit-scrollbar-thumb:hover {
|
|
background: var(--scrollbar-thumb-hover);
|
|
}
|
|
|
|
.skinny-scrollbar {
|
|
scrollbar-width: thin;
|
|
scrollbar-color: var(--scrollbar-thumb) transparent;
|
|
}
|
|
|
|
.skinny-scrollbar::-webkit-scrollbar {
|
|
width: 4px;
|
|
height: 4px;
|
|
}
|
|
|
|
.skinny-scrollbar::-webkit-scrollbar-track {
|
|
background: transparent;
|
|
}
|
|
|
|
.skinny-scrollbar::-webkit-scrollbar-thumb {
|
|
background: var(--scrollbar-thumb);
|
|
border-radius: 2px;
|
|
}
|
|
|
|
.skinny-scrollbar::-webkit-scrollbar-thumb:hover {
|
|
background: var(--scrollbar-thumb-hover);
|
|
}
|