Path: blob/master/gate-controller/app/page.tsx
1085 views
"use client";12import { ModeToggle } from "@/components/mode-toggle";3import RelayManager from "@/components/RelayManager";4import { Globe, Shield } from "lucide-react";56export default function Home() {7return (8<main className="h-screen flex flex-col items-center justify-center p-2 bg-gradient-to-br from-background via-background to-muted/20 overflow-hidden">9<div className="w-full max-w-5xl h-full max-h-[90vh] bg-card/95 backdrop-blur-sm shadow-2xl border border-border/50 flex flex-col overflow-hidden relative">10<header className="relative bg-gradient-to-r from-primary/10 via-primary/5 to-background px-8 py-3 border-b border-border/50 flex-shrink-0">11<div className="absolute top-2 right-4 z-20">12<ModeToggle />13</div>1415<div className="flex items-center justify-start gap-4">16<div className="w-12 h-12 bg-primary/10 rounded-xl flex items-center justify-center ring-2 ring-primary/20">17<Shield className="w-7 h-7 text-primary" />18</div>19<div className="text-left">20<h1 className="text-2xl font-bold tracking-tight bg-gradient-to-r from-foreground to-foreground/70 bg-clip-text text-transparent">21GateController22</h1>23{/* <p className="text-muted-foreground text-xs font-medium">24Advanced Relay Control System25</p> */}26</div>27</div>28</header>2930<section className="flex-grow min-h-0 p-6 overflow-y-auto">31<RelayManager />32</section>3334<footer className="px-8 py-2 bg-muted/30 border-t border-border/50 flex-shrink-0">35<div className="flex items-center justify-between">36<p className="text-xs text-muted-foreground">37© 2025 Plate Recognizer, a subsidiary of ParkPow, Inc. All rights38reserved.39</p>40<a41href="https://platerecognizer.com"42target="_blank"43rel="noopener noreferrer"44className="inline-flex items-center gap-2 text-sm text-muted-foreground hover:text-primary transition-colors duration-200 group"45>46<Globe className="w-4 h-4 group-hover:rotate-12 transition-transform duration-200" />47<span className="font-medium">Powered by Platerecognizer</span>48</a>49</div>50</footer>51</div>5253<div className="fixed inset-0 -z-10 overflow-hidden pointer-events-none">54<div className="absolute top-1/4 -left-48 w-96 h-96 bg-primary/5 rounded-full blur-3xl" />55<div className="absolute bottom-1/4 -right-48 w-96 h-96 bg-primary/5 rounded-full blur-3xl" />56</div>57</main>58);59}606162