Merge branch 'krille/morenullsafety' into 'main'

refactor: Make style settings null safe

See merge request famedly/fluffychat!658
This commit is contained in:
Krille Fear 2022-01-01 13:03:04 +00:00
commit 0c4d1ec3f8
3 changed files with 50 additions and 42 deletions

View File

@ -1,3 +1,5 @@
//@dart=2.12
import 'dart:io'; import 'dart:io';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
@ -12,7 +14,7 @@ import '../../widgets/matrix.dart';
import 'settings_style_view.dart'; import 'settings_style_view.dart';
class SettingsStyle extends StatefulWidget { class SettingsStyle extends StatefulWidget {
const SettingsStyle({Key key}) : super(key: key); const SettingsStyle({Key? key}) : super(key: key);
@override @override
SettingsStyleController createState() => SettingsStyleController(); SettingsStyleController createState() => SettingsStyleController();
@ -22,18 +24,19 @@ class SettingsStyleController extends State<SettingsStyle> {
void setWallpaperAction() async { void setWallpaperAction() async {
final wallpaper = final wallpaper =
await FilePickerCross.importFromStorage(type: FileTypeCross.image); await FilePickerCross.importFromStorage(type: FileTypeCross.image);
if (wallpaper == null) return; final path = wallpaper.path;
Matrix.of(context).wallpaper = File(wallpaper.path); if (path == null) return;
Matrix.of(context).wallpaper = File(path);
await Matrix.of(context) await Matrix.of(context)
.store .store
.setItem(SettingKeys.wallpaper, wallpaper.path); .setItem(SettingKeys.wallpaper, wallpaper.path);
setState(() => null); setState(() {});
} }
void deleteWallpaperAction() async { void deleteWallpaperAction() async {
Matrix.of(context).wallpaper = null; Matrix.of(context).wallpaper = null;
await Matrix.of(context).store.deleteItem(SettingKeys.wallpaper); await Matrix.of(context).store.deleteItem(SettingKeys.wallpaper);
setState(() => null); setState(() {});
} }
void setChatColor(Color color) async { void setChatColor(Color color) async {
@ -48,7 +51,7 @@ class SettingsStyleController extends State<SettingsStyle> {
); );
} }
AdaptiveThemeMode currentTheme; AdaptiveThemeMode? currentTheme;
static final List<Color> customColors = [ static final List<Color> customColors = [
AppConfig.primaryColor, AppConfig.primaryColor,
@ -59,7 +62,8 @@ class SettingsStyleController extends State<SettingsStyle> {
Colors.blueGrey.shade600, Colors.blueGrey.shade600,
]; ];
void switchTheme(AdaptiveThemeMode newTheme) { void switchTheme(AdaptiveThemeMode? newTheme) {
if (newTheme == null) return;
switch (newTheme) { switch (newTheme) {
case AdaptiveThemeMode.light: case AdaptiveThemeMode.light:
AdaptiveTheme.of(context).setLight(); AdaptiveTheme.of(context).setLight();

View File

@ -1,3 +1,5 @@
//@dart=2.12
import 'package:flutter/material.dart'; import 'package:flutter/material.dart';
import 'package:adaptive_theme/adaptive_theme.dart'; import 'package:adaptive_theme/adaptive_theme.dart';
@ -11,7 +13,7 @@ import 'settings_style.dart';
class SettingsStyleView extends StatelessWidget { class SettingsStyleView extends StatelessWidget {
final SettingsStyleController controller; final SettingsStyleController controller;
const SettingsStyleView(this.controller, {Key key}) : super(key: key); const SettingsStyleView(this.controller, {Key? key}) : super(key: key);
@override @override
Widget build(BuildContext context) { Widget build(BuildContext context) {
@ -20,7 +22,7 @@ class SettingsStyleView extends StatelessWidget {
return Scaffold( return Scaffold(
appBar: AppBar( appBar: AppBar(
leading: const BackButton(), leading: const BackButton(),
title: Text(L10n.of(context).changeTheme), title: Text(L10n.of(context)!.changeTheme),
), ),
body: MaxWidthBody( body: MaxWidthBody(
withScrolling: true, withScrolling: true,
@ -59,25 +61,25 @@ class SettingsStyleView extends StatelessWidget {
RadioListTile<AdaptiveThemeMode>( RadioListTile<AdaptiveThemeMode>(
groupValue: controller.currentTheme, groupValue: controller.currentTheme,
value: AdaptiveThemeMode.system, value: AdaptiveThemeMode.system,
title: Text(L10n.of(context).systemTheme), title: Text(L10n.of(context)!.systemTheme),
onChanged: controller.switchTheme, onChanged: controller.switchTheme,
), ),
RadioListTile<AdaptiveThemeMode>( RadioListTile<AdaptiveThemeMode>(
groupValue: controller.currentTheme, groupValue: controller.currentTheme,
value: AdaptiveThemeMode.light, value: AdaptiveThemeMode.light,
title: Text(L10n.of(context).lightTheme), title: Text(L10n.of(context)!.lightTheme),
onChanged: controller.switchTheme, onChanged: controller.switchTheme,
), ),
RadioListTile<AdaptiveThemeMode>( RadioListTile<AdaptiveThemeMode>(
groupValue: controller.currentTheme, groupValue: controller.currentTheme,
value: AdaptiveThemeMode.dark, value: AdaptiveThemeMode.dark,
title: Text(L10n.of(context).darkTheme), title: Text(L10n.of(context)!.darkTheme),
onChanged: controller.switchTheme, onChanged: controller.switchTheme,
), ),
const Divider(height: 1), const Divider(height: 1),
ListTile( ListTile(
title: Text( title: Text(
L10n.of(context).wallpaper, L10n.of(context)!.wallpaper,
style: TextStyle( style: TextStyle(
color: Theme.of(context).colorScheme.secondary, color: Theme.of(context).colorScheme.secondary,
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,
@ -99,10 +101,10 @@ class SettingsStyleView extends StatelessWidget {
), ),
Builder(builder: (context) { Builder(builder: (context) {
return ListTile( return ListTile(
title: Text(L10n.of(context).changeWallpaper), title: Text(L10n.of(context)!.changeWallpaper),
trailing: Icon( trailing: Icon(
Icons.photo_outlined, Icons.photo_outlined,
color: Theme.of(context).textTheme.bodyText1.color, color: Theme.of(context).textTheme.bodyText1?.color,
), ),
onTap: controller.setWallpaperAction, onTap: controller.setWallpaperAction,
); );
@ -110,7 +112,7 @@ class SettingsStyleView extends StatelessWidget {
const Divider(height: 1), const Divider(height: 1),
ListTile( ListTile(
title: Text( title: Text(
L10n.of(context).fontSize, L10n.of(context)!.fontSize,
style: TextStyle( style: TextStyle(
color: Theme.of(context).colorScheme.secondary, color: Theme.of(context).colorScheme.secondary,
fontWeight: FontWeight.bold, fontWeight: FontWeight.bold,

View File

@ -71,34 +71,36 @@ class StoryView extends StatelessWidget {
), ),
), ),
), ),
actions: [ actions: currentEvent == null
if (!controller.isOwnStory && currentEvent != null) ? null
AnimatedOpacity( : [
duration: const Duration(seconds: 1), if (!controller.isOwnStory)
opacity: controller.isHold ? 0 : 1, AnimatedOpacity(
child: IconButton( duration: const Duration(seconds: 1),
icon: Icon(Icons.adaptive.share_outlined), opacity: controller.isHold ? 0 : 1,
onPressed: controller.share, child: IconButton(
), icon: Icon(Icons.adaptive.share_outlined),
), onPressed: controller.share,
AnimatedOpacity(
duration: const Duration(seconds: 1),
opacity: controller.isHold ? 0 : 1,
child: PopupMenuButton<PopupStoryAction>(
onSelected: controller.onPopupStoryAction,
itemBuilder: (context) => [
if (controller.currentEvent?.canRedact ?? false)
PopupMenuItem(
value: PopupStoryAction.delete,
child: Text(L10n.of(context)!.delete),
), ),
PopupMenuItem(
value: PopupStoryAction.report,
child: Text(L10n.of(context)!.reportMessage),
), ),
], AnimatedOpacity(
)), duration: const Duration(seconds: 1),
], opacity: controller.isHold ? 0 : 1,
child: PopupMenuButton<PopupStoryAction>(
onSelected: controller.onPopupStoryAction,
itemBuilder: (context) => [
if (controller.currentEvent?.canRedact ?? false)
PopupMenuItem(
value: PopupStoryAction.delete,
child: Text(L10n.of(context)!.delete),
),
PopupMenuItem(
value: PopupStoryAction.report,
child: Text(L10n.of(context)!.reportMessage),
),
],
)),
],
systemOverlayStyle: SystemUiOverlayStyle.light, systemOverlayStyle: SystemUiOverlayStyle.light,
iconTheme: const IconThemeData(color: Colors.white), iconTheme: const IconThemeData(color: Colors.white),
elevation: 0, elevation: 0,