improved app rating UI logic by showing a disabled state during availability check instead of hiding the component

This commit is contained in:
2026-05-13 20:39:05 +02:00
parent 0fd42439e2
commit 4c04d00323
+12 -12
View File
@@ -49,23 +49,13 @@ class _OverhangState extends State<Overhang> {
FutureBuilder( FutureBuilder(
future: InAppReview.instance.isAvailable(), future: InAppReview.instance.isAvailable(),
builder: (context, snapshot) { builder: (context, snapshot) {
if (!snapshot.hasData) return const SizedBox.shrink();
String? getPlatformStoreName() { String? getPlatformStoreName() {
if (Platform.isAndroid) return 'Play store'; if (Platform.isAndroid) return 'Play store';
if (Platform.isIOS) return 'App store'; if (Platform.isIOS) return 'App store';
return null; return null;
} }
return ListTile( Future<void> rate() => InAppReview.instance
leading: const CenteredLeading(Icon(Icons.star_rate_outlined)),
title: const Text('App bewerten'),
subtitle: getPlatformStoreName().wrapNullable(
(data) => Text('Im $data'),
),
trailing: const Icon(Icons.arrow_right),
onTap: () {
InAppReview.instance
.openStoreListing(appStoreId: '6458789560') .openStoreListing(appStoreId: '6458789560')
.then( .then(
(value) { (value) {
@@ -82,7 +72,17 @@ class _OverhangState extends State<Overhang> {
); );
}, },
); );
},
final ready = snapshot.connectionState == ConnectionState.done;
return ListTile(
enabled: ready,
leading: const CenteredLeading(Icon(Icons.star_rate_outlined)),
title: const Text('App bewerten'),
subtitle: getPlatformStoreName().wrapNullable(
(data) => Text('Im $data'),
),
trailing: const Icon(Icons.arrow_right),
onTap: !ready ? null : rate
); );
}, },
), ),