mirror of
https://github.com/feeddeck/feeddeck.git
synced 2026-03-11 17:47:47 -05:00
The cached items in the "ItemsRepositoryStore" are now cleared when a user selects an active deck in the settings and when a user signes out of the app. This is done to force a reload of the items in a column, when a user switches between decks. For me this works better because, when I switch between decks I manually trigger a reload for all columns, which is now not necessary anymore.
118 lines
3.7 KiB
Dart
118 lines
3.7 KiB
Dart
import 'package:flutter/material.dart';
|
|
|
|
import 'package:supabase_flutter/supabase_flutter.dart' as supabase;
|
|
|
|
import 'package:feeddeck/repositories/items_repository.dart';
|
|
import 'package:feeddeck/utils/constants.dart';
|
|
import 'package:feeddeck/widgets/general/elevated_button_progress_indicator.dart';
|
|
import 'package:feeddeck/widgets/signin/signin.dart';
|
|
|
|
/// The [SettingsProfileSignOut] displays a sign out button which can be used by
|
|
/// a user to sign out from all devices where he is currently signed in.
|
|
class SettingsProfileSignOut extends StatefulWidget {
|
|
const SettingsProfileSignOut({super.key});
|
|
|
|
@override
|
|
State<SettingsProfileSignOut> createState() => _SettingsProfileSignOutState();
|
|
}
|
|
|
|
class _SettingsProfileSignOutState extends State<SettingsProfileSignOut> {
|
|
bool _isLoading = false;
|
|
|
|
/// [_signOut] signs out the currently authenticated user and redirects him
|
|
/// to the [SignIn] screen. This will sign out the user from all devices.
|
|
///
|
|
/// Before the user is signed out the [ItemsRepositoryStore] is cleared, to
|
|
/// trigger a reload of the items once the user is signed in again.
|
|
Future<void> _signOut() async {
|
|
setState(() {
|
|
_isLoading = true;
|
|
});
|
|
|
|
try {
|
|
ItemsRepositoryStore().clear();
|
|
await supabase.Supabase.instance.client.auth.signOut();
|
|
|
|
setState(() {
|
|
_isLoading = false;
|
|
});
|
|
|
|
if (!mounted) return;
|
|
Navigator.pushAndRemoveUntil(
|
|
context,
|
|
MaterialPageRoute(
|
|
builder: (BuildContext context) => const SignIn(),
|
|
),
|
|
(route) => false,
|
|
);
|
|
} catch (_) {
|
|
setState(() {
|
|
_isLoading = false;
|
|
});
|
|
}
|
|
}
|
|
|
|
/// [buildIcon] return the provided icon or when the [_isLoading] state is
|
|
/// `true` is returns a circular progress indicator.
|
|
Widget buildIcon(Icon icon) {
|
|
if (_isLoading) return const ElevatedButtonProgressIndicator();
|
|
return icon;
|
|
}
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return MouseRegion(
|
|
cursor: SystemMouseCursors.click,
|
|
child: GestureDetector(
|
|
onTap: () => _signOut(),
|
|
child: Card(
|
|
color: Constants.secondary,
|
|
margin: const EdgeInsets.only(
|
|
bottom: Constants.spacingSmall,
|
|
),
|
|
shape: RoundedRectangleBorder(
|
|
borderRadius: BorderRadius.circular(12),
|
|
),
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.stretch,
|
|
children: [
|
|
Padding(
|
|
padding: const EdgeInsets.all(
|
|
Constants.spacingMiddle,
|
|
),
|
|
child: Row(
|
|
mainAxisAlignment: MainAxisAlignment.spaceBetween,
|
|
children: [
|
|
Expanded(
|
|
child: Column(
|
|
crossAxisAlignment: CrossAxisAlignment.start,
|
|
children: [
|
|
Text(
|
|
Characters('Sign Out')
|
|
.replaceAll(
|
|
Characters(''),
|
|
Characters('\u{200B}'),
|
|
)
|
|
.toString(),
|
|
maxLines: 1,
|
|
style: const TextStyle(
|
|
overflow: TextOverflow.ellipsis,
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
buildIcon(
|
|
const Icon(Icons.logout),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
],
|
|
),
|
|
),
|
|
),
|
|
);
|
|
}
|
|
}
|