mirror of
				https://github.com/anna-sara/lan_kiosk
				synced 2025-10-26 21:17:13 +01:00 
			
		
		
		
	Frontend: Login, Sass, FontAwseome
This commit is contained in:
		
							parent
							
								
									237ea299cd
								
							
						
					
					
						commit
						aa99be65e1
					
				
					 11 changed files with 783 additions and 323 deletions
				
			
		
							
								
								
									
										929
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
							
						
						
									
										929
									
								
								package-lock.json
									
									
									
										generated
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load diff
											
										
									
								
							
							
								
								
									
										13
									
								
								package.json
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								package.json
									
									
									
									
									
								
							|  | @ -2,7 +2,7 @@ | ||||||
|     "private": true, |     "private": true, | ||||||
|     "type": "module", |     "type": "module", | ||||||
|     "scripts": { |     "scripts": { | ||||||
|         "build": "tsc && vite build", |         "build": "tsc && vite build && sass --load-path=node_modules my-bulma-project.scss my-bulma-project.css", | ||||||
|         "dev": "vite" |         "dev": "vite" | ||||||
|     }, |     }, | ||||||
|     "devDependencies": { |     "devDependencies": { | ||||||
|  | @ -24,5 +24,16 @@ | ||||||
|         "tailwindcss": "^3.2.1", |         "tailwindcss": "^3.2.1", | ||||||
|         "typescript": "^5.0.2", |         "typescript": "^5.0.2", | ||||||
|         "vite": "^6.2.4" |         "vite": "^6.2.4" | ||||||
|  |     }, | ||||||
|  |     "dependencies": { | ||||||
|  |         "@fortawesome/fontawesome-svg-core": "^6.7.2", | ||||||
|  |         "@fortawesome/free-solid-svg-icons": "^6.7.2", | ||||||
|  |         "@fortawesome/react-fontawesome": "^0.2.2", | ||||||
|  |         "@types/babel__generator": "^7.27.0", | ||||||
|  |         "@types/babel__template": "^7.4.4", | ||||||
|  |         "@types/babel__traverse": "^7.20.7", | ||||||
|  |         "@types/prop-types": "^15.7.14", | ||||||
|  |         "bulma": "^1.0.4", | ||||||
|  |         "sass": "^1.86.3" | ||||||
|     } |     } | ||||||
| } | } | ||||||
|  |  | ||||||
							
								
								
									
										
											BIN
										
									
								
								public/img/logo.png
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								public/img/logo.png
									
									
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 49 KiB | 
							
								
								
									
										96
									
								
								resources/css/app.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										96
									
								
								resources/css/app.scss
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,96 @@ | ||||||
|  | @import 'bulma/css/bulma.min.css'; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | :root { | ||||||
|  |     --button-link-background-color: #0080bb; | ||||||
|  |     --button-link-color: #fff; | ||||||
|  |  } | ||||||
|  | 
 | ||||||
|  | .button { | ||||||
|  |     background-color: var(--button-link-background-color); | ||||||
|  |     color: var(--button-link-color); | ||||||
|  |     | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .navbar-logo { | ||||||
|  |     height: 50px; | ||||||
|  |     width: auto; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .form-logo{ | ||||||
|  |     height: 100px; | ||||||
|  |     width: auto; | ||||||
|  |     margin: 0px auto 30px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .login-logo { | ||||||
|  |     height: 100px; | ||||||
|  |     width: auto; | ||||||
|  |     margin: 0 auto; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | details { | ||||||
|  | 	position: relative; | ||||||
|  | 
 | ||||||
|  | 	.summary-title { | ||||||
|  | 		user-select: none; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	&:hover { | ||||||
|  | 		cursor: pointer; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  |     &:hover .summary-chevron-down svg { | ||||||
|  |         opacity: 1; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 	.summary-content { | ||||||
|  | 		cursor: default; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	summary { | ||||||
|  | 		list-style: none; | ||||||
|  | 
 | ||||||
|  | 		&:focus { | ||||||
|  | 			outline: none; | ||||||
|  | 		} | ||||||
|  | 
 | ||||||
|  | 		&:hover .summary-chevron-up svg { | ||||||
|  | 			opacity: 1; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	.summary-chevron-up svg { | ||||||
|  | 		opacity: 0.5; | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	.summary-chevron-up, | ||||||
|  | 	.summary-chevron-down { | ||||||
|  | 		pointer-events: none; | ||||||
|  | 		position: absolute; | ||||||
|  | 		top: 1.4em; | ||||||
|  | 		right: 1em; | ||||||
|  | 		background: #ffffff; | ||||||
|  | 
 | ||||||
|  | 		svg { | ||||||
|  | 			display: block; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  |     .summary-chevron-down{ | ||||||
|  | 		pointer-events: none; | ||||||
|  | 		position: absolute; | ||||||
|  | 		top: 2em; | ||||||
|  | 		right: 1.5em; | ||||||
|  | 		background: #ffffff; | ||||||
|  | 
 | ||||||
|  | 		svg { | ||||||
|  | 			display: block; | ||||||
|  |             opacity: 0.5; | ||||||
|  | 		} | ||||||
|  | 	} | ||||||
|  | 
 | ||||||
|  | 	summary::-webkit-details-marker { | ||||||
|  | 		display: none; | ||||||
|  | 	} | ||||||
|  | } | ||||||
|  | @ -1,13 +0,0 @@ | ||||||
| import { SVGAttributes } from 'react'; |  | ||||||
| 
 |  | ||||||
| export default function ApplicationLogo(props: SVGAttributes<SVGElement>) { |  | ||||||
|     return ( |  | ||||||
|         <svg |  | ||||||
|             {...props} |  | ||||||
|             viewBox="0 0 316 316" |  | ||||||
|             xmlns="http://www.w3.org/2000/svg" |  | ||||||
|         > |  | ||||||
|             <path d="M305.8 81.125C305.77 80.995 305.69 80.885 305.65 80.755C305.56 80.525 305.49 80.285 305.37 80.075C305.29 79.935 305.17 79.815 305.07 79.685C304.94 79.515 304.83 79.325 304.68 79.175C304.55 79.045 304.39 78.955 304.25 78.845C304.09 78.715 303.95 78.575 303.77 78.475L251.32 48.275C249.97 47.495 248.31 47.495 246.96 48.275L194.51 78.475C194.33 78.575 194.19 78.725 194.03 78.845C193.89 78.955 193.73 79.045 193.6 79.175C193.45 79.325 193.34 79.515 193.21 79.685C193.11 79.815 192.99 79.935 192.91 80.075C192.79 80.285 192.71 80.525 192.63 80.755C192.58 80.875 192.51 80.995 192.48 81.125C192.38 81.495 192.33 81.875 192.33 82.265V139.625L148.62 164.795V52.575C148.62 52.185 148.57 51.805 148.47 51.435C148.44 51.305 148.36 51.195 148.32 51.065C148.23 50.835 148.16 50.595 148.04 50.385C147.96 50.245 147.84 50.125 147.74 49.995C147.61 49.825 147.5 49.635 147.35 49.485C147.22 49.355 147.06 49.265 146.92 49.155C146.76 49.025 146.62 48.885 146.44 48.785L93.99 18.585C92.64 17.805 90.98 17.805 89.63 18.585L37.18 48.785C37 48.885 36.86 49.035 36.7 49.155C36.56 49.265 36.4 49.355 36.27 49.485C36.12 49.635 36.01 49.825 35.88 49.995C35.78 50.125 35.66 50.245 35.58 50.385C35.46 50.595 35.38 50.835 35.3 51.065C35.25 51.185 35.18 51.305 35.15 51.435C35.05 51.805 35 52.185 35 52.575V232.235C35 233.795 35.84 235.245 37.19 236.025L142.1 296.425C142.33 296.555 142.58 296.635 142.82 296.725C142.93 296.765 143.04 296.835 143.16 296.865C143.53 296.965 143.9 297.015 144.28 297.015C144.66 297.015 145.03 296.965 145.4 296.865C145.5 296.835 145.59 296.775 145.69 296.745C145.95 296.655 146.21 296.565 146.45 296.435L251.36 236.035C252.72 235.255 253.55 233.815 253.55 232.245V174.885L303.81 145.945C305.17 145.165 306 143.725 306 142.155V82.265C305.95 81.875 305.89 81.495 305.8 81.125ZM144.2 227.205L100.57 202.515L146.39 176.135L196.66 147.195L240.33 172.335L208.29 190.625L144.2 227.205ZM244.75 114.995V164.795L226.39 154.225L201.03 139.625V89.825L219.39 100.395L244.75 114.995ZM249.12 57.105L292.81 82.265L249.12 107.425L205.43 82.265L249.12 57.105ZM114.49 184.425L96.13 194.995V85.305L121.49 70.705L139.85 60.135V169.815L114.49 184.425ZM91.76 27.425L135.45 52.585L91.76 77.745L48.07 52.585L91.76 27.425ZM43.67 60.135L62.03 70.705L87.39 85.305V202.545V202.555V202.565C87.39 202.735 87.44 202.895 87.46 203.055C87.49 203.265 87.49 203.485 87.55 203.695V203.705C87.6 203.875 87.69 204.035 87.76 204.195C87.84 204.375 87.89 204.575 87.99 204.745C87.99 204.745 87.99 204.755 88 204.755C88.09 204.905 88.22 205.035 88.33 205.175C88.45 205.335 88.55 205.495 88.69 205.635L88.7 205.645C88.82 205.765 88.98 205.855 89.12 205.965C89.28 206.085 89.42 206.225 89.59 206.325C89.6 206.325 89.6 206.325 89.61 206.335C89.62 206.335 89.62 206.345 89.63 206.345L139.87 234.775V285.065L43.67 229.705V60.135ZM244.75 229.705L148.58 285.075V234.775L219.8 194.115L244.75 179.875V229.705ZM297.2 139.625L253.49 164.795V114.995L278.85 100.395L297.21 89.825V139.625H297.2Z" /> |  | ||||||
|         </svg> |  | ||||||
|     ); |  | ||||||
| } |  | ||||||
|  | @ -10,7 +10,7 @@ export default function InputLabel({ | ||||||
|         <label |         <label | ||||||
|             {...props} |             {...props} | ||||||
|             className={ |             className={ | ||||||
|                 `block text-sm font-medium text-gray-700 ` + |                 `text-sm font-medium text-gray-700 ` + | ||||||
|                 className |                 className | ||||||
|             } |             } | ||||||
|         > |         > | ||||||
|  |  | ||||||
|  | @ -1,4 +1,3 @@ | ||||||
| import ApplicationLogo from '@/Components/ApplicationLogo'; |  | ||||||
| import Dropdown from '@/Components/Dropdown'; | import Dropdown from '@/Components/Dropdown'; | ||||||
| import NavLink from '@/Components/NavLink'; | import NavLink from '@/Components/NavLink'; | ||||||
| import ResponsiveNavLink from '@/Components/ResponsiveNavLink'; | import ResponsiveNavLink from '@/Components/ResponsiveNavLink'; | ||||||
|  | @ -15,17 +14,17 @@ export default function Authenticated({ | ||||||
|         useState(false); |         useState(false); | ||||||
| 
 | 
 | ||||||
|     return ( |     return ( | ||||||
|         <div className="min-h-screen bg-gray-100"> |         <div className="min-h-screen bg-white"> | ||||||
|             <nav className="border-b border-gray-100 bg-white"> |             <nav className="border-b border-gray-100 bg-white"> | ||||||
|                 <div className="mx-auto max-w-7xl px-4 sm:px-6 lg:px-8"> |                 <div className="mx-auto max-w-7xl px-4 sm:px-6 lg:px-8"> | ||||||
|                     <div className="flex h-16 justify-between"> |                     <div className="flex h-16 justify-between"> | ||||||
|                         <div className="flex"> |                         <div className="flex"> | ||||||
|                             <div className="flex shrink-0 items-center"> |                             <div className="flex shrink-0 items-center"> | ||||||
|                                 <Link href="/"> |                                 <Link href="/dashboard"> | ||||||
|                                     <ApplicationLogo className="block h-9 w-auto fill-current text-gray-800" /> |                                     <img className="navbar-logo" src="/img/logo.png" /> | ||||||
|                                 </Link> |                                 </Link> | ||||||
|                             </div> |                             </div> | ||||||
| 
 | {/* | ||||||
|                             <div className="hidden space-x-8 sm:-my-px sm:ms-10 sm:flex"> |                             <div className="hidden space-x-8 sm:-my-px sm:ms-10 sm:flex"> | ||||||
|                                 <NavLink |                                 <NavLink | ||||||
|                                     href={route('dashboard')} |                                     href={route('dashboard')} | ||||||
|  | @ -33,7 +32,7 @@ export default function Authenticated({ | ||||||
|                                 > |                                 > | ||||||
|                                     Dashboard |                                     Dashboard | ||||||
|                                 </NavLink> |                                 </NavLink> | ||||||
|                             </div> |                             </div>*/} | ||||||
|                         </div> |                         </div> | ||||||
| 
 | 
 | ||||||
|                         <div className="hidden sm:ms-6 sm:flex sm:items-center"> |                         <div className="hidden sm:ms-6 sm:flex sm:items-center"> | ||||||
|  | @ -64,11 +63,11 @@ export default function Authenticated({ | ||||||
|                                     </Dropdown.Trigger> |                                     </Dropdown.Trigger> | ||||||
| 
 | 
 | ||||||
|                                     <Dropdown.Content> |                                     <Dropdown.Content> | ||||||
|                                         <Dropdown.Link |                                         {/*<Dropdown.Link | ||||||
|                                             href={route('profile.edit')} |                                             href={route('profile.edit')} | ||||||
|                                         > |                                         > | ||||||
|                                             Profile |                                             Profile | ||||||
|                                         </Dropdown.Link> |                                         </Dropdown.Link>*/} | ||||||
|                                         <Dropdown.Link |                                         <Dropdown.Link | ||||||
|                                             href={route('logout')} |                                             href={route('logout')} | ||||||
|                                             method="post" |                                             method="post" | ||||||
|  | @ -130,14 +129,14 @@ export default function Authenticated({ | ||||||
|                         ' sm:hidden' |                         ' sm:hidden' | ||||||
|                     } |                     } | ||||||
|                 > |                 > | ||||||
|                     <div className="space-y-1 pb-3 pt-2"> |                     {/*<div className="space-y-1 pb-3 pt-2"> | ||||||
|                         <ResponsiveNavLink |                         <ResponsiveNavLink | ||||||
|                             href={route('dashboard')} |                             href={route('dashboard')} | ||||||
|                             active={route().current('dashboard')} |                             active={route().current('dashboard')} | ||||||
|                         > |                         > | ||||||
|                             Dashboard |                             Dashboard | ||||||
|                         </ResponsiveNavLink> |                         </ResponsiveNavLink> | ||||||
|                     </div> |                     </div>*/} | ||||||
| 
 | 
 | ||||||
|                     <div className="border-t border-gray-200 pb-1 pt-4"> |                     <div className="border-t border-gray-200 pb-1 pt-4"> | ||||||
|                         <div className="px-4"> |                         <div className="px-4"> | ||||||
|  | @ -150,9 +149,9 @@ export default function Authenticated({ | ||||||
|                         </div> |                         </div> | ||||||
| 
 | 
 | ||||||
|                         <div className="mt-3 space-y-1"> |                         <div className="mt-3 space-y-1"> | ||||||
|                             <ResponsiveNavLink href={route('profile.edit')}> |                             {/*<ResponsiveNavLink href={route('profile.edit')}> | ||||||
|                                 Profile |                                 Profile | ||||||
|                             </ResponsiveNavLink> |                             </ResponsiveNavLink>*/} | ||||||
|                             <ResponsiveNavLink |                             <ResponsiveNavLink | ||||||
|                                 method="post" |                                 method="post" | ||||||
|                                 href={route('logout')} |                                 href={route('logout')} | ||||||
|  | @ -164,15 +163,6 @@ export default function Authenticated({ | ||||||
|                     </div> |                     </div> | ||||||
|                 </div> |                 </div> | ||||||
|             </nav> |             </nav> | ||||||
| 
 |  | ||||||
|             {header && ( |  | ||||||
|                 <header className="bg-white shadow"> |  | ||||||
|                     <div className="mx-auto max-w-7xl px-4 py-6 sm:px-6 lg:px-8"> |  | ||||||
|                         {header} |  | ||||||
|                     </div> |  | ||||||
|                 </header> |  | ||||||
|             )} |  | ||||||
| 
 |  | ||||||
|             <main>{children}</main> |             <main>{children}</main> | ||||||
|         </div> |         </div> | ||||||
|     ); |     ); | ||||||
|  |  | ||||||
|  | @ -1,4 +1,4 @@ | ||||||
| import ApplicationLogo from '@/Components/ApplicationLogo'; | 
 | ||||||
| import { Link } from '@inertiajs/react'; | import { Link } from '@inertiajs/react'; | ||||||
| import { PropsWithChildren } from 'react'; | import { PropsWithChildren } from 'react'; | ||||||
| 
 | 
 | ||||||
|  | @ -7,11 +7,11 @@ export default function Guest({ children }: PropsWithChildren) { | ||||||
|         <div className="flex min-h-screen flex-col items-center bg-gray-100 pt-6 sm:justify-center sm:pt-0"> |         <div className="flex min-h-screen flex-col items-center bg-gray-100 pt-6 sm:justify-center sm:pt-0"> | ||||||
|             <div> |             <div> | ||||||
|                 <Link href="/"> |                 <Link href="/"> | ||||||
|                     <ApplicationLogo className="h-20 w-20 fill-current text-gray-500" /> |                     <img className="login-logo" src="/img/logo.png" /> | ||||||
|                 </Link> |                 </Link> | ||||||
|             </div> |             </div> | ||||||
| 
 | 
 | ||||||
|             <div className="mt-6 w-full overflow-hidden bg-white px-6 py-4 shadow-md sm:max-w-md sm:rounded-lg"> |             <div className="mt-6 w-full overflow-hidden bg-white px-6 py-6 shadow-md sm:max-w-md sm:rounded-lg"> | ||||||
|                 {children} |                 {children} | ||||||
|             </div> |             </div> | ||||||
|         </div> |         </div> | ||||||
|  |  | ||||||
|  | @ -38,6 +38,8 @@ export default function Login({ | ||||||
|                 </div> |                 </div> | ||||||
|             )} |             )} | ||||||
| 
 | 
 | ||||||
|  |             <h1 className='title is-3 has-text-centered has-text-grey'>LAN-kiosken</h1> | ||||||
|  | 
 | ||||||
|             <form onSubmit={submit}> |             <form onSubmit={submit}> | ||||||
|                 <div> |                 <div> | ||||||
|                     <InputLabel htmlFor="email" value="Email" /> |                     <InputLabel htmlFor="email" value="Email" /> | ||||||
|  | @ -57,7 +59,7 @@ export default function Login({ | ||||||
|                 </div> |                 </div> | ||||||
| 
 | 
 | ||||||
|                 <div className="mt-4"> |                 <div className="mt-4"> | ||||||
|                     <InputLabel htmlFor="password" value="Password" /> |                     <InputLabel htmlFor="password" value="Lösenord" /> | ||||||
| 
 | 
 | ||||||
|                     <TextInput |                     <TextInput | ||||||
|                         id="password" |                         id="password" | ||||||
|  | @ -85,7 +87,7 @@ export default function Login({ | ||||||
|                             } |                             } | ||||||
|                         /> |                         /> | ||||||
|                         <span className="ms-2 text-sm text-gray-600"> |                         <span className="ms-2 text-sm text-gray-600"> | ||||||
|                             Remember me |                            Kom ihåg mig | ||||||
|                         </span> |                         </span> | ||||||
|                     </label> |                     </label> | ||||||
|                 </div> |                 </div> | ||||||
|  | @ -96,12 +98,12 @@ export default function Login({ | ||||||
|                             href={route('password.request')} |                             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" |                             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" | ||||||
|                         > |                         > | ||||||
|                             Forgot your password? |                             Glömt ditt lösenord? | ||||||
|                         </Link> |                         </Link> | ||||||
|                     )} |                     )} | ||||||
| 
 | 
 | ||||||
|                     <PrimaryButton className="ms-4" disabled={processing}> |                     <PrimaryButton className="ms-4 button" disabled={processing}> | ||||||
|                         Log in |                         Logga in | ||||||
|                     </PrimaryButton> |                     </PrimaryButton> | ||||||
|                 </div> |                 </div> | ||||||
|             </form> |             </form> | ||||||
|  |  | ||||||
|  | @ -1,4 +1,5 @@ | ||||||
| import '../css/app.css'; | import '../css/app.css'; | ||||||
|  | import '../css/app.scss'; | ||||||
| import './bootstrap'; | import './bootstrap'; | ||||||
| 
 | 
 | ||||||
| import { createInertiaApp } from '@inertiajs/react'; | import { createInertiaApp } from '@inertiajs/react'; | ||||||
|  |  | ||||||
|  | @ -1,5 +1,5 @@ | ||||||
| <!DOCTYPE html> | <!DOCTYPE html> | ||||||
| <html lang="{{ str_replace('_', '-', app()->getLocale()) }}"> | <html lang="{{ str_replace('_', '-', app()->getLocale()) }}" data-theme="light"> | ||||||
|     <head> |     <head> | ||||||
|         <meta charset="utf-8"> |         <meta charset="utf-8"> | ||||||
|         <meta name="viewport" content="width=device-width, initial-scale=1"> |         <meta name="viewport" content="width=device-width, initial-scale=1"> | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue