mirror of
https://github.com/netbirdio/netbird.git
synced 2026-04-30 22:26:42 +00:00
Stage 1 of the client/ui (Fyne) replacement. Adds a new client/ui-wails module that runs on Linux/macOS/Windows from a single React + Vite + Tailwind frontend driven by a thin gRPC services layer in Go. - Single-module integration (no submodule): merge Wails3 into root go.mod with build tags !android !ios !freebsd !js so cross-compiles on those targets exclude the package automatically. - Seven gRPC-bound services: Connection, Settings, Networks, Profiles, Debug, Update, Peers. Peers bridges Status polling and SubscribeEvents to the Wails event bus (netbird:status, netbird:event). - Tray + window shell mirrors the Fyne menu 1:1 with hide-on-close, SIGUSR1 / Windows named-event for external "show window" triggers. - React pages cover functional parity for Status, Settings (3 tabs), Networks (3 tabs), Profiles, Debug, Update, QuickActions, LoginUrl. - SVG-sourced tray icons (12 source SVGs incl. macOS template variants) rasterized to PNG via task common:generate:tray:icons. - Linux launcher sets WEBKIT_DISABLE_DMABUF_RENDERER=1 in the .desktop Exec= line and in task linux:run so the app renders correctly under RDP, VirtualBox, KVM, and bare WMs (Fluxbox/dwm) without DRM access.
34 lines
976 B
TypeScript
34 lines
976 B
TypeScript
import { InputHTMLAttributes, forwardRef } from "react";
|
|
import { cn } from "../lib/cn";
|
|
|
|
interface Props extends InputHTMLAttributes<HTMLInputElement> {
|
|
label?: string;
|
|
}
|
|
|
|
export const Input = forwardRef<HTMLInputElement, Props>(function Input(
|
|
{ label, className, id, ...rest },
|
|
ref,
|
|
) {
|
|
const inputId = id ?? label?.toLowerCase().replace(/\s+/g, "-");
|
|
return (
|
|
<div className="flex flex-col gap-1">
|
|
{label && (
|
|
<label htmlFor={inputId} className="text-xs font-medium text-nb-gray-600 dark:text-nb-gray-300">
|
|
{label}
|
|
</label>
|
|
)}
|
|
<input
|
|
id={inputId}
|
|
ref={ref}
|
|
className={cn(
|
|
"h-9 rounded-md border border-nb-gray-300 bg-white px-3 text-sm",
|
|
"focus:border-netbird focus:outline-none focus:ring-1 focus:ring-netbird",
|
|
"dark:border-nb-gray-700 dark:bg-nb-gray-925 dark:text-nb-gray-50",
|
|
className,
|
|
)}
|
|
{...rest}
|
|
/>
|
|
</div>
|
|
);
|
|
});
|