import type { ChangeEvent, FormEvent } from "react"; import type { Applications, DatabaseType, ServersType } from "../../types/enums"; import type { ServerFormState } from "./types"; interface ServerModalProps { isOpen: boolean; form: ServerFormState; loading: boolean; onClose: () => void; onChange: (event: ChangeEvent) => void; onSubmit: (event: FormEvent) => void; serverTypeOptions: ServersType[]; applicationOptions: Applications[]; databaseOptions: DatabaseType[]; } export const ServerModal = ({ isOpen, form, loading, onClose, onChange, onSubmit, serverTypeOptions, applicationOptions, databaseOptions, }: ServerModalProps) => { if (!isOpen) return null; return (

Adicionar novo servidor

); }; const Styles = { modalOverlay: "fixed inset-0 z-40 flex items-center justify-center bg-black/40 backdrop-blur-sm px-4 !mt-0", modal: "w-full max-w-2xl rounded-2xl border border-cardBorder bg-card p-6 shadow-xl transform transition-all duration-200 animate-fade-up", modalHeader: "flex items-start justify-between gap-4 pb-4 border-b border-cardBorder", modalTitle: "text-lg font-semibold text-text", closeButton: "text-2xl leading-none text-text-secondary hover:text-text", form: "pt-4 space-y-4", formGrid: "grid gap-4 md:grid-cols-2", field: "flex flex-col gap-2", label: "text-xs font-semibold uppercase tracking-wide text-text-secondary", input: "rounded-lg border border-cardBorder bg-white px-3 py-2 text-sm text-text outline-none focus:border-accent focus:ring-1 focus:ring-accent", select: "rounded-lg border border-cardBorder bg-white px-3 py-2 text-sm text-text outline-none focus:border-accent focus:ring-1 focus:ring-accent capitalize", modalActions: "flex justify-end gap-3 pt-2", secondaryButton: "rounded-md border border-cardBorder px-4 py-2 text-sm font-medium text-text hover:bg-bg disabled:opacity-50", primaryButton: "rounded-md bg-accent px-4 py-2 text-sm font-semibold text-white hover:bg-hover disabled:opacity-70", };