mirror of
				https://github.com/anna-sara/lan_kiosk
				synced 2025-10-26 21:17:13 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			112 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			112 lines
		
	
	
	
		
			3.8 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
| import Checkbox from '@/Components/Checkbox';
 | |
| import InputError from '@/Components/InputError';
 | |
| import InputLabel from '@/Components/InputLabel';
 | |
| import PrimaryButton from '@/Components/PrimaryButton';
 | |
| import TextInput from '@/Components/TextInput';
 | |
| import GuestLayout from '@/Layouts/GuestLayout';
 | |
| import { Head, Link, useForm } from '@inertiajs/react';
 | |
| import { FormEventHandler } from 'react';
 | |
| 
 | |
| export default function Login({
 | |
|     status,
 | |
|     canResetPassword,
 | |
| }: {
 | |
|     status?: string;
 | |
|     canResetPassword: boolean;
 | |
| }) {
 | |
|     const { data, setData, post, processing, errors, reset } = useForm({
 | |
|         email: '',
 | |
|         password: '',
 | |
|         remember: false as boolean,
 | |
|     });
 | |
| 
 | |
|     const submit: FormEventHandler = (e) => {
 | |
|         e.preventDefault();
 | |
| 
 | |
|         post(route('login'), {
 | |
|             onFinish: () => reset('password'),
 | |
|         });
 | |
|     };
 | |
| 
 | |
|     return (
 | |
|         <GuestLayout>
 | |
|             <Head title="Log in" />
 | |
| 
 | |
|             {status && (
 | |
|                 <div className="mb-4 text-sm font-medium text-green-600">
 | |
|                     {status}
 | |
|                 </div>
 | |
|             )}
 | |
| 
 | |
|             <h1 className='title is-3 has-text-centered has-text-grey'>LAN-kiosken</h1>
 | |
| 
 | |
|             <form onSubmit={submit}>
 | |
|                 <div>
 | |
|                     <InputLabel htmlFor="email" value="Email" />
 | |
| 
 | |
|                     <TextInput
 | |
|                         id="email"
 | |
|                         type="email"
 | |
|                         name="email"
 | |
|                         value={data.email}
 | |
|                         className="mt-1 block w-full"
 | |
|                         autoComplete="username"
 | |
|                         isFocused={true}
 | |
|                         onChange={(e) => setData('email', e.target.value)}
 | |
|                     />
 | |
| 
 | |
|                     <InputError message={errors.email} className="mt-2" />
 | |
|                 </div>
 | |
| 
 | |
|                 <div className="mt-4">
 | |
|                     <InputLabel htmlFor="password" value="Lösenord" />
 | |
| 
 | |
|                     <TextInput
 | |
|                         id="password"
 | |
|                         type="password"
 | |
|                         name="password"
 | |
|                         value={data.password}
 | |
|                         className="mt-1 block w-full"
 | |
|                         autoComplete="current-password"
 | |
|                         onChange={(e) => setData('password', e.target.value)}
 | |
|                     />
 | |
| 
 | |
|                     <InputError message={errors.password} className="mt-2" />
 | |
|                 </div>
 | |
| 
 | |
|                 <div className="mt-4 block">
 | |
|                     <label className="flex items-center">
 | |
|                         <Checkbox
 | |
|                             name="remember"
 | |
|                             checked={data.remember}
 | |
|                             onChange={(e) =>
 | |
|                                 setData(
 | |
|                                     'remember',
 | |
|                                     (e.target.checked || false) as false,
 | |
|                                 )
 | |
|                             }
 | |
|                         />
 | |
|                         <span className="ms-2 text-sm text-gray-600">
 | |
|                            Kom ihåg mig
 | |
|                         </span>
 | |
|                     </label>
 | |
|                 </div>
 | |
| 
 | |
|                 <div className="mt-4 flex items-center justify-end">
 | |
|                     {canResetPassword && (
 | |
|                         <Link
 | |
|                             href={route('password.request')}
 | |
|                             className="rounded-md text-sm text-gray-600 underline hover:text-gray-900 focus:outline-none focus:ring-2 focus:ring-indigo-500 focus:ring-offset-2"
 | |
|                         >
 | |
|                             Glömt ditt lösenord?
 | |
|                         </Link>
 | |
|                     )}
 | |
| 
 | |
|                     <PrimaryButton className="ms-4 button" disabled={processing}>
 | |
|                         Logga in
 | |
|                     </PrimaryButton>
 | |
|                 </div>
 | |
|             </form>
 | |
|         </GuestLayout>
 | |
|     );
 | |
| }
 |