From e07394e8b1899dfa0520f8730ff4c41852a0115b Mon Sep 17 00:00:00 2001 From: NaiJi Date: Wed, 6 Sep 2023 23:31:47 -0300 Subject: [PATCH] feat: Implement visible accent when backup modal buttons are disabled --- lib/ui/pages/backups/backup_details.dart | 69 ++++++++++++++++++++---- 1 file changed, 60 insertions(+), 9 deletions(-) diff --git a/lib/ui/pages/backups/backup_details.dart b/lib/ui/pages/backups/backup_details.dart index 1d08dfac..02838eda 100644 --- a/lib/ui/pages/backups/backup_details.dart +++ b/lib/ui/pages/backups/backup_details.dart @@ -83,6 +83,9 @@ class BackupDetailsPage extends StatelessWidget { ); } + Color? getOverrideColor() => + preventActions ? Theme.of(context).colorScheme.secondary : null; + return BrandHeroScreen( heroIcon: BrandIcons.save, heroTitle: 'backup.card_title'.tr(), @@ -110,11 +113,15 @@ class BackupDetailsPage extends StatelessWidget { ), ); }, - leading: const Icon( + leading: Icon( Icons.add_circle_outline_rounded, + color: getOverrideColor(), ), title: Text( 'backup.create_new'.tr(), + style: TextStyle( + color: getOverrideColor(), + ), ), ), ListTile( @@ -138,13 +145,20 @@ class BackupDetailsPage extends StatelessWidget { ), ); }, - leading: const Icon( + leading: Icon( Icons.manage_history_outlined, + color: getOverrideColor(), ), title: Text( 'backup.autobackup_period_title'.tr(), + style: TextStyle( + color: getOverrideColor(), + ), ), subtitle: Text( + style: TextStyle( + color: getOverrideColor(), + ), autobackupPeriod != null ? 'backup.autobackup_period_subtitle'.tr( namedArgs: { @@ -175,14 +189,21 @@ class BackupDetailsPage extends StatelessWidget { ), ); }, - leading: const Icon( + leading: Icon( Icons.key_outlined, + color: getOverrideColor(), ), title: Text( 'backup.backups_encryption_key'.tr(), + style: TextStyle( + color: getOverrideColor(), + ), ), subtitle: Text( 'backup.backups_encryption_key_subtitle'.tr(), + style: TextStyle( + color: getOverrideColor(), + ), ), ), const SizedBox(height: 8), @@ -227,10 +248,16 @@ class BackupDetailsPage extends StatelessWidget { ), if (backups.isEmpty) ListTile( - leading: const Icon( + leading: Icon( Icons.error_outline, + color: getOverrideColor(), + ), + title: Text( + 'backup.no_backups'.tr(), + style: TextStyle( + color: getOverrideColor(), + ), ), - title: Text('backup.no_backups'.tr()), ), if (backups.isNotEmpty) Column( @@ -282,9 +309,15 @@ class BackupDetailsPage extends StatelessWidget { ); }, title: Text( + style: TextStyle( + color: getOverrideColor(), + ), '${MaterialLocalizations.of(context).formatShortDate(backup.time)} ${TimeOfDay.fromDateTime(backup.time).format(context)}', ), subtitle: Text( + style: TextStyle( + color: getOverrideColor(), + ), service?.displayName ?? backup.fallbackServiceName, ), leading: service != null @@ -293,12 +326,16 @@ class BackupDetailsPage extends StatelessWidget { height: 24, width: 24, colorFilter: ColorFilter.mode( - Theme.of(context).colorScheme.onBackground, + getOverrideColor() ?? + Theme.of(context) + .colorScheme + .onBackground, BlendMode.srcIn, ), ) - : const Icon( + : Icon( Icons.question_mark_outlined, + color: getOverrideColor(), ), ); }, @@ -339,12 +376,19 @@ class BackupDetailsPage extends StatelessWidget { ListTile( title: Text( 'backup.refetch_backups'.tr(), + style: TextStyle( + color: getOverrideColor(), + ), ), subtitle: Text( 'backup.refetch_backups_subtitle'.tr(), + style: TextStyle( + color: getOverrideColor(), + ), ), - leading: const Icon( + leading: Icon( Icons.cached_outlined, + color: getOverrideColor(), ), onTap: preventActions ? null @@ -356,12 +400,19 @@ class BackupDetailsPage extends StatelessWidget { ListTile( title: Text( 'backup.reupload_key'.tr(), + style: TextStyle( + color: getOverrideColor(), + ), ), subtitle: Text( 'backup.reupload_key_subtitle'.tr(), + style: TextStyle( + color: getOverrideColor(), + ), ), - leading: const Icon( + leading: Icon( Icons.warning_amber_outlined, + color: getOverrideColor(), ), onTap: preventActions ? null