mirror of
				https://github.com/anna-sara/lan_kiosk
				synced 2025-10-26 21:17:13 +01:00 
			
		
		
		
	Frontend: Daskboard
This commit is contained in:
		
							parent
							
								
									122d26df3a
								
							
						
					
					
						commit
						393d00f5f4
					
				
					 1 changed files with 57 additions and 15 deletions
				
			
		|  | @ -1,26 +1,68 @@ | |||
| import AuthenticatedLayout from '@/Layouts/AuthenticatedLayout'; | ||||
| import { Head } from '@inertiajs/react'; | ||||
| import { useState } from 'react'; | ||||
| import { FontAwesomeIcon } from '@fortawesome/react-fontawesome' | ||||
| import { faArrowRight } from '@fortawesome/free-solid-svg-icons' | ||||
| 
 | ||||
| export default function Dashboard() { | ||||
|     return ( | ||||
|         <AuthenticatedLayout | ||||
|             header={ | ||||
|                 <h2 className="text-xl font-semibold leading-tight text-gray-800"> | ||||
|                     Dashboard | ||||
|                 </h2> | ||||
| 
 | ||||
| interface CustomerProps { | ||||
|     customers: [{ | ||||
|         id: number | ||||
|         name: string | ||||
|     }], | ||||
| }; | ||||
| 
 | ||||
| interface Customer { | ||||
|     id: number | ||||
|     name: string | ||||
| }; | ||||
| 
 | ||||
| 
 | ||||
| 
 | ||||
| export default function Dashboard({customers}: CustomerProps) { | ||||
|     const [searchItem, setSearchItem] = useState('') | ||||
|     const [filteredCustomers, setFilteredCustomers] = useState<Customer[]>(customers) | ||||
| 
 | ||||
|     const handleInputChange = (e: any) => {  | ||||
|         const searchTerm = e.target.value; | ||||
|         setSearchItem(searchTerm) | ||||
| 
 | ||||
|         const filteredItems = customers.filter((customer) => | ||||
|             customer.name.toLowerCase().includes(searchTerm.toLowerCase()) | ||||
|         ); | ||||
|          | ||||
|         setFilteredCustomers(filteredItems); | ||||
|     } | ||||
|         > | ||||
| 
 | ||||
|     return ( | ||||
|         <AuthenticatedLayout> | ||||
|             <Head title="Dashboard" /> | ||||
| 
 | ||||
|             <div className="py-12"> | ||||
|                 <div className="mx-auto max-w-7xl sm:px-6 lg:px-8"> | ||||
|                     <div className="overflow-hidden bg-white shadow-sm sm:rounded-lg"> | ||||
|                         <div className="p-6 text-gray-900"> | ||||
|                             You're logged in! | ||||
|                         </div> | ||||
|                     </div> | ||||
|             <section className='section'> | ||||
|                 <div className="container is-max-desktop"> | ||||
|                     <h1 className="title is-2">Deltagare</h1> | ||||
|                         <input | ||||
|                             className='input my-4' | ||||
|                             type="text" | ||||
|                             value={searchItem} | ||||
|                             onChange={handleInputChange} | ||||
|                             placeholder='Skriv för att söka' | ||||
|                         /> | ||||
|                         <div className='container is-centered'> | ||||
|                             {filteredCustomers && filteredCustomers.map( customer => { | ||||
|                                 return <a key={customer.id} className="box is-flex is-justify-content-space-between" href={`/customer/` + customer.id}> | ||||
|                                     <p>{customer.name}</p> | ||||
|                                     <span className="icon has-text-black"> | ||||
|                                         <FontAwesomeIcon icon={faArrowRight} /> | ||||
|                                     </span> | ||||
|                                 </a> | ||||
|                             })} | ||||
|                         </div> | ||||
|                     | ||||
|                  | ||||
|                 </div> | ||||
|             </section> | ||||
|              | ||||
|         </AuthenticatedLayout> | ||||
|     ); | ||||
| } | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue