✨ Logout
This commit is contained in:
parent
de12616109
commit
7ed4045a8c
@ -85,8 +85,15 @@ class AuthGuard {
|
|||||||
|
|
||||||
storage.write(key: profileKey, value: userinfo);
|
storage.write(key: profileKey, value: userinfo);
|
||||||
storage.write(key: storageKey, value: client!.credentials.toJson());
|
storage.write(key: storageKey, value: client!.credentials.toJson());
|
||||||
|
} catch (e) {
|
||||||
|
print(e);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
print('Logged in: $userinfo');
|
void logout() {
|
||||||
|
try {
|
||||||
|
storage.delete(key: profileKey);
|
||||||
|
storage.delete(key: storageKey);
|
||||||
} catch (e) {
|
} catch (e) {
|
||||||
print(e);
|
print(e);
|
||||||
}
|
}
|
||||||
|
@ -1,16 +1,27 @@
|
|||||||
import 'dart:io';
|
|
||||||
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_secure_storage/flutter_secure_storage.dart';
|
|
||||||
import 'package:goatagent/auth.dart';
|
import 'package:goatagent/auth.dart';
|
||||||
import 'package:goatagent/widgets/name_card.dart';
|
import 'package:goatagent/widgets/name_card.dart';
|
||||||
import 'package:oauth2/oauth2.dart' as oauth2;
|
|
||||||
|
|
||||||
import 'auth.dart';
|
class AccountScreen extends StatefulWidget {
|
||||||
|
|
||||||
class AccountScreen extends StatelessWidget {
|
|
||||||
const AccountScreen({super.key});
|
const AccountScreen({super.key});
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<AccountScreen> createState() => _AccountScreenState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _AccountScreenState extends State<AccountScreen> {
|
||||||
|
bool isAuthorized = false;
|
||||||
|
|
||||||
|
@override
|
||||||
|
void initState() {
|
||||||
|
super.initState();
|
||||||
|
AuthGuard().isAuthorized().then((value) {
|
||||||
|
setState(() {
|
||||||
|
isAuthorized = value;
|
||||||
|
});
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
@ -22,6 +33,45 @@ class AccountScreen extends StatelessWidget {
|
|||||||
NameCard(
|
NameCard(
|
||||||
onLogin: () async {
|
onLogin: () async {
|
||||||
await AuthGuard().login(context);
|
await AuthGuard().login(context);
|
||||||
|
var authorized = await AuthGuard().isAuthorized();
|
||||||
|
setState(() {
|
||||||
|
isAuthorized = authorized;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
),
|
||||||
|
FutureBuilder(
|
||||||
|
future: AuthGuard().isAuthorized(),
|
||||||
|
builder: (BuildContext context, AsyncSnapshot<bool> snapshot) {
|
||||||
|
if (snapshot.hasData && snapshot.data == true) {
|
||||||
|
return Padding(
|
||||||
|
padding: const EdgeInsets.only(top: 5),
|
||||||
|
child: Wrap(
|
||||||
|
spacing: 5,
|
||||||
|
children: [
|
||||||
|
Card(
|
||||||
|
elevation: 0,
|
||||||
|
child: InkWell(
|
||||||
|
splashColor: Colors.indigo.withAlpha(30),
|
||||||
|
onTap: () async {
|
||||||
|
AuthGuard().logout();
|
||||||
|
var authorized =
|
||||||
|
await AuthGuard().isAuthorized();
|
||||||
|
setState(() {
|
||||||
|
isAuthorized = authorized;
|
||||||
|
});
|
||||||
|
},
|
||||||
|
child: const ListTile(
|
||||||
|
leading: Icon(Icons.logout),
|
||||||
|
title: Text('Logout'),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
),
|
||||||
|
],
|
||||||
|
),
|
||||||
|
);
|
||||||
|
} else {
|
||||||
|
return const Padding(padding: EdgeInsets.only(top: 5));
|
||||||
|
}
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
],
|
],
|
||||||
|
Reference in New Issue
Block a user