simple login
This commit is contained in:
@@ -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);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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;
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user