simple login

This commit is contained in:
marcoabat
2023-08-05 01:49:40 +02:00
parent 6bc973f8a1
commit 819b3aafe4
3 changed files with 48 additions and 10 deletions

View File

@@ -1,18 +1,31 @@
import 'package:briessenchecker/services/dbhelper.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:flutter_dotenv/flutter_dotenv.dart'; import 'package:flutter_dotenv/flutter_dotenv.dart';
import 'package:gotrue/src/types/auth_state.dart';
import 'package:supabase_flutter/supabase_flutter.dart';
import 'pages/login_page.dart'; import 'pages/login_page.dart';
void main() async { void main() async {
await dotenv.load(fileName: 'secrets.env'); await dotenv.load(fileName: 'secrets.env');
await DbHelper.init();
runApp(const MyApp()); runApp(const MyApp());
} }
class MyApp extends StatelessWidget { class MyApp extends StatefulWidget {
const MyApp({super.key}); const MyApp({super.key});
@override
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
bool isLoggedIn = false;
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
String initialRoute =
isLoggedIn ? LoginPage.routeName : LoginPage.routeName;
DbHelper.authChangeEventStream.listen(_onAuthEvent);
return MaterialApp( return MaterialApp(
title: 'Briessenchecker', title: 'Briessenchecker',
theme: ThemeData.dark( theme: ThemeData.dark(
@@ -20,10 +33,18 @@ class MyApp extends StatelessWidget {
).copyWith( ).copyWith(
colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple), colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple),
), ),
initialRoute: LoginPage.routeName, initialRoute: initialRoute,
routes: { routes: {
LoginPage.routeName: (context) => const LoginPage(), LoginPage.routeName: (context) => const LoginPage(),
}, },
); );
} }
void _onAuthEvent(AuthState event) {
if (event.event == AuthChangeEvent.signedIn) {
setState(() => isLoggedIn = true);
} else if (event.event == AuthChangeEvent.signedOut) {
setState(() => isLoggedIn = false);
}
}
} }

View File

@@ -1,3 +1,4 @@
import 'package:briessenchecker/services/dbhelper.dart';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
class LoginPage extends StatelessWidget { class LoginPage extends StatelessWidget {
@@ -6,9 +7,8 @@ class LoginPage extends StatelessWidget {
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
TextEditingController usernameController = TextEditingController(); final TextEditingController _emailController = TextEditingController();
TextEditingController passwordController = TextEditingController(); final TextEditingController _passwordController = TextEditingController();
return Scaffold( return Scaffold(
body: Form( body: Form(
child: Column( child: Column(
@@ -16,20 +16,24 @@ class LoginPage extends StatelessWidget {
mainAxisAlignment: MainAxisAlignment.center, mainAxisAlignment: MainAxisAlignment.center,
children: [ children: [
TextFormField( TextFormField(
controller: usernameController, controller: _emailController,
decoration: const InputDecoration(label: Text('Username')), decoration: const InputDecoration(label: Text('Email')),
), ),
TextFormField( TextFormField(
controller: passwordController, controller: _passwordController,
decoration: const InputDecoration(label: Text('Password')), decoration: const InputDecoration(label: Text('Password')),
), ),
FloatingActionButton.extended( FloatingActionButton.extended(
onPressed: _loginSubmitted, label: const Text('Login')) onPressed: () => _loginSubmitted(
_emailController.text, _passwordController.text),
label: const Text('Login'))
], ],
), ),
), ),
); );
} }
void _loginSubmitted() {} void _loginSubmitted(String email, String password) {
DbHelper.login(email, password);
}
} }

View File

@@ -3,10 +3,23 @@ import 'package:supabase_flutter/supabase_flutter.dart';
class DbHelper { class DbHelper {
static late final SupabaseClient _client; static late final SupabaseClient _client;
static Future<void> init() async { static Future<void> init() async {
await Supabase.initialize( await Supabase.initialize(
url: dotenv.env['SUPABASE_URL'] ?? '', url: dotenv.env['SUPABASE_URL'] ?? '',
anonKey: dotenv.env['SUPABASE_ANON'] ?? ''); anonKey: dotenv.env['SUPABASE_ANON'] ?? '');
_client = Supabase.instance.client; _client = Supabase.instance.client;
} }
static Future<void> login(String email, String password) async {
email = 'sites@skup.in';
password = 'pass';
await _client.auth.signInWithPassword(
email: email,
password: password,
);
}
static Stream<AuthState> get authChangeEventStream =>
_client.auth.onAuthStateChange;
} }