2025-03-18 13:48:08 +01:00

104 lines
3.1 KiB
Dart

import 'package:flutter/material.dart';
import 'package:mobile/controllers/session.dart';
import 'package:mobile/pages/register_page.dart';
import 'package:mobile/results.dart';
import 'package:mobile/widgets/error_box.dart';
import 'package:mobile/widgets/primary_button.dart';
import 'package:mobile/widgets/primary_input.dart';
import 'package:provider/provider.dart';
class LoginPage extends StatelessWidget {
const LoginPage({super.key});
@override
Widget build(BuildContext context) {
return const Scaffold(
body: Row(
mainAxisAlignment: MainAxisAlignment.center,
children: [LoginForm()]));
}
}
class LoginForm extends StatefulWidget {
const LoginForm({super.key});
@override
State<StatefulWidget> createState() => LoginFormState();
}
class LoginFormState extends State<LoginForm> {
bool loginError = false;
@override
Widget build(BuildContext context) {
final sessionProvider = context.read<SessionProvider>();
final mailController = TextEditingController();
final passwordController = TextEditingController();
return Column(
spacing: 10,
mainAxisAlignment: MainAxisAlignment.center,
children: [
Text(
"Log ind",
style: Theme.of(context).textTheme.headlineLarge,
),
ErrorBox(
visible: loginError,
errorText: "Ugyldig mail eller password",
onClosePressed: () {
setState(() => loginError = false);
},
),
PrimaryInput(
label: "Mail",
placeholderText: "f.eks. example@example.com",
controller: mailController,
),
PrimaryInput(
label: "Password",
placeholderText: "*********",
obscure: true,
controller: passwordController,
),
PrimaryButton(
onPressed: () async {
final loginResult = await sessionProvider.controller
.loginUser(mailController.text, passwordController.text);
switch (loginResult) {
case Ok<Null, String>():
setState(() => loginError = false);
case Err<Null, String>():
setState(() => loginError = true);
}
},
child: const Text("Log ind")),
TextButton(
onPressed: () {
setState(() => loginError = false);
Navigator.of(context).push(
MaterialPageRoute(builder: (context) => const RegisterPage()));
},
child: RichText(
text: const TextSpan(children: [
TextSpan(
text: 'Har du ikke en konto? Klik ',
style: TextStyle(color: Colors.black),
),
TextSpan(
text: 'her',
style: TextStyle(
color: Color.fromARGB(255, 0, 94, 255),
decoration: TextDecoration.underline),
),
TextSpan(
text: ' for at oprette en konto',
style: TextStyle(color: Colors.black),
),
])),
)
],
);
}
}