| | import { useState } from "react";
|
| | import "./login.css";
|
| |
|
| | const ONLY_ALLOWED_USERNAME = "GLIS26STEM";
|
| |
|
| | export default function LabSelection({ onApproved }) {
|
| | const [username, setUsername] = useState("");
|
| | const [showApproved, setShowApproved] = useState(false);
|
| |
|
| | function submit(e) {
|
| | e.preventDefault();
|
| |
|
| | if (username.trim().toLowerCase() === ONLY_ALLOWED_USERNAME.toLowerCase()) {
|
| | setShowApproved(true);
|
| |
|
| |
|
| | setTimeout(() => onApproved(), 600);
|
| |
|
| |
|
| | setTimeout(() => setShowApproved(false), 2500);
|
| | } else {
|
| | alert("That username isn’t allowed.");
|
| | }
|
| | }
|
| |
|
| | return (
|
| | <>
|
| | <div className={`approvedToast ${showApproved ? "show" : ""}`}>
|
| | Approved ✓
|
| | </div>
|
| |
|
| | <div className="loginOverlay">
|
| | <div className="loginCard">
|
| | <h1 className="loginTitle">Computer Vision Lab</h1>
|
| | <p className="loginSubtitle">Enter your class username to continue.</p>
|
| |
|
| | <form onSubmit={submit} autoComplete="off">
|
| | <label className="loginLabel">Username</label>
|
| | <input
|
| | value={username}
|
| | onChange={(e) => setUsername(e.target.value)}
|
| | placeholder="e.g., cv-student"
|
| | required
|
| | />
|
| |
|
| | <div className="loginRow">
|
| | <button type="submit">Continue</button>
|
| | <div className="loginTip">Tip: usernames are case-insensitive.</div>
|
| | </div>
|
| | </form>
|
| | </div>
|
| | </div>
|
| | </>
|
| | );
|
| | }
|
| |
|