mirror of
				https://github.com/anna-sara/lan_kiosk
				synced 2025-10-26 21:17:13 +01:00 
			
		
		
		
	Frontend: Customer
This commit is contained in:
		
							parent
							
								
									aa99be65e1
								
							
						
					
					
						commit
						122d26df3a
					
				
					 1 changed files with 138 additions and 0 deletions
				
			
		
							
								
								
									
										138
									
								
								resources/js/Pages/Customer.tsx
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										138
									
								
								resources/js/Pages/Customer.tsx
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,138 @@ | |||
| import TextInput from '@/Components/TextInput'; | ||||
| import AuthenticatedLayout from '@/Layouts/AuthenticatedLayout'; | ||||
| import { Head, useForm } from '@inertiajs/react'; | ||||
| import { FormEventHandler } from 'react'; | ||||
| 
 | ||||
| interface CustomerProps { | ||||
|     customer:{ | ||||
|         id: number | ||||
|         name: string | ||||
|         deposit: number | ||||
|         amount_left: number | ||||
|         give_leftover: number | ||||
|         purchases: [{ | ||||
|             id: number | ||||
|             amount: number | ||||
|         }] | ||||
|     }  | ||||
| }; | ||||
| 
 | ||||
| export default function Customer({customer}: CustomerProps) { | ||||
| 
 | ||||
|     const { data, setData, post, processing, errors, reset } = useForm({ | ||||
|         amount: "", | ||||
|         customer_id: customer.id, | ||||
|         deposit: "", | ||||
|         id: customer.id | ||||
| 
 | ||||
|     }); | ||||
| 
 | ||||
|     const submit: FormEventHandler = (e) => { | ||||
|         e.preventDefault() | ||||
|         post(route('register_purchase'), { | ||||
|             onFinish: () => reset('amount'), | ||||
|         });  | ||||
|     } | ||||
| 
 | ||||
|     const submitDeposit: FormEventHandler = (e) => { | ||||
|         e.preventDefault() | ||||
|         post('/api/register_deposit/' + customer.id, { | ||||
|             onFinish: () => reset('deposit'), | ||||
|         });  | ||||
|     } | ||||
|     | ||||
|     return ( | ||||
|         <AuthenticatedLayout> | ||||
|             <Head title="Deltagare" /> | ||||
| 
 | ||||
|             <section className='section'> | ||||
|                 <div className="container is-max-desktop"> | ||||
|                     <h1 className="title is-2">{customer.name}</h1> | ||||
|                         <div className='container is-centered'> | ||||
|                              <div className="box"> | ||||
|                              <h2 className='title is-4'>Saldo: {customer.amount_left ? customer.amount_left : 0} kr</h2> | ||||
|                                 { customer.deposit &&  | ||||
|                                     <p>Swishad summa: {customer.deposit} kr</p> | ||||
|                                 } | ||||
|                                 <p>Ge ev överblivet saldo till vBytes: {customer.give_leftover ? "Ja" : "Nej"}</p> | ||||
|                             </div> | ||||
| 
 | ||||
|                             <div className="box"> | ||||
|                                 <h2 className='title is-4'>Registrera köp</h2> | ||||
|                                 <form onSubmit={submit}> | ||||
|                                     <div className="field"> | ||||
|                                         <div className="control"> | ||||
|                                             <TextInput | ||||
|                                                 required | ||||
|                                                 className="input"  | ||||
|                                                 type="number"  | ||||
|                                                 name="amount"  | ||||
|                                                 value={data.amount} | ||||
|                                                 placeholder="Summa" | ||||
|                                                 min={0} | ||||
|                                                 //max={customer.amount_left}
 | ||||
|                                                 onChange={(e) => setData('amount', e.target.value)} | ||||
|                                             /> | ||||
|                                         </div> | ||||
|                                     </div> | ||||
|                                     <div className="field is-grouped"> | ||||
|                                         <div className="control"> | ||||
|                                             <button className="button">Spara</button> | ||||
|                                         </div> | ||||
|                                     </div> | ||||
|                                 </form> | ||||
|                             </div> | ||||
| 
 | ||||
|                             <div className="box"> | ||||
|                                 <h2 className='title is-4'>Lägga in swishpeng</h2> | ||||
|                                 <form onSubmit={submitDeposit}> | ||||
|                                     <div className="field"> | ||||
|                                         <div className="control"> | ||||
|                                             <TextInput | ||||
|                                                 required | ||||
|                                                 className="input"  | ||||
|                                                 type="number"  | ||||
|                                                 name="amount"  | ||||
|                                                 value={data.deposit} | ||||
|                                                 placeholder="Summa" | ||||
|                                                 onChange={(e) => setData('deposit', e.target.value)} | ||||
|                                             /> | ||||
|                                         </div> | ||||
|                                     </div> | ||||
|                                     <div className="field is-grouped"> | ||||
|                                         <div className="control"> | ||||
|                                             <button className="button">Spara</button> | ||||
|                                         </div> | ||||
|                                     </div> | ||||
|                                 </form> | ||||
|                             </div> | ||||
| 
 | ||||
|                             <details className="box"> | ||||
|                                 <summary className='title is-4 my-3'> | ||||
|                                     <span>Tidigare köp</span> | ||||
|                                     <div className="summary-chevron-up"> | ||||
| 			                                <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" className="feather feather-chevron-down"> | ||||
|                                                 <polyline points="6 9 12 15 18 9"></polyline> | ||||
|                                             </svg> | ||||
| 		                            </div> | ||||
|                                 </summary> | ||||
|                                 {customer.purchases && customer.purchases.map( purchase => { | ||||
|                                     return <div key={purchase.id} className="box"> | ||||
|                                         <p>{purchase.amount} kr</p> | ||||
|                                     </div> | ||||
|                                 })} | ||||
|                                 <div className="summary-chevron-down"> | ||||
|                                     <svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" fill="none" stroke="currentColor" stroke-width="2" stroke-linecap="round" stroke-linejoin="round" className="feather feather-chevron-up"> | ||||
|                                         <polyline points="18 15 12 9 6 15"></polyline> | ||||
|                                     </svg> | ||||
|                                 </div> | ||||
|                             </details> | ||||
|                         </div> | ||||
|                     | ||||
|                  | ||||
|                 </div> | ||||
|             </section> | ||||
|              | ||||
|         </AuthenticatedLayout> | ||||
|     ); | ||||
| } | ||||
		Loading…
	
		Reference in a new issue