persistance

This commit is contained in:
2024-02-11 02:20:48 +01:00
parent 46897cc51b
commit 463e7ee287
7 changed files with 217 additions and 24 deletions

View File

@@ -1,8 +1,13 @@
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:simplecloudnotifier/api/api_client.dart';
import 'package:simplecloudnotifier/models/key_token_auth.dart';
import 'package:simplecloudnotifier/state/user_account.dart';
class AccountLoginPage extends StatefulWidget {
const AccountLoginPage({super.key});
final void Function()? onLogin;
const AccountLoginPage({super.key, this.onLogin});
@override
State<AccountLoginPage> createState() => _AccountLoginPageState();
@@ -66,20 +71,31 @@ class _AccountLoginPageState extends State<AccountLoginPage> {
void _login() async {
final msgr = ScaffoldMessenger.of(context);
final prov = Provider.of<UserAccount>(context, listen: false);
final verified = await APIClient.verifyToken(_ctrlUserID.text, _ctrlToken.text);
if (verified) {
msgr.showSnackBar(
const SnackBar(
content: Text('Data ok'),
),
);
} else {
msgr.showSnackBar(
const SnackBar(
content: Text('Failed to verify token'),
),
);
try {
final uid = _ctrlUserID.text;
final tok = _ctrlToken.text;
final verified = await APIClient.verifyToken(uid, tok);
if (verified) {
msgr.showSnackBar(
const SnackBar(
content: Text('Data ok'), //TODO toast
),
);
prov.setToken(KeyTokenAuth(userId: uid, token: tok));
await prov.save();
widget.onLogin?.call();
} else {
msgr.showSnackBar(
const SnackBar(
content: Text('Failed to verify token'), //TODO toast
),
);
}
} catch (e) {
//TODO
}
}
}

View File

@@ -16,21 +16,22 @@ enum _SubPage { chooseAuth, login, main }
class _AccountRootPageState extends State<AccountRootPage> {
late _SubPage _page;
late UserAccount userAcc;
@override
void initState() {
super.initState();
var prov = Provider.of<UserAccount>(context, listen: false);
userAcc = Provider.of<UserAccount>(context, listen: false);
_page = (prov.auth != null) ? _SubPage.main : _SubPage.chooseAuth;
_page = (userAcc.auth != null) ? _SubPage.main : _SubPage.chooseAuth;
prov.addListener(_onAuthStateChanged);
userAcc.addListener(_onAuthStateChanged);
}
@override
void dispose() {
Provider.of<UserAccount>(context, listen: false).removeListener(_onAuthStateChanged);
userAcc.removeListener(_onAuthStateChanged);
super.dispose();
}
@@ -48,10 +49,10 @@ class _AccountRootPageState extends State<AccountRootPage> {
builder: (context, acc, child) {
switch (_page) {
case _SubPage.main:
return const Center(
return Center(
child: Text(
'Logged In',
style: TextStyle(fontSize: 24),
'Logged In: ${acc.auth?.userId}',
style: const TextStyle(fontSize: 24),
),
);
case _SubPage.chooseAuth:
@@ -64,7 +65,11 @@ class _AccountRootPageState extends State<AccountRootPage> {
}),
);
case _SubPage.login:
return const AccountLoginPage();
return AccountLoginPage(
onLogin: () => setState(() {
_page = _SubPage.main;
}),
);
}
},
);