Skip to content

Commit

Permalink
fix: ThemeProvider properly resync the theme (openfoodfacts#5363)
Browse files Browse the repository at this point in the history
* Fix theme internals

* Also fix the animation
  • Loading branch information
g123k authored Jun 13, 2024
1 parent 73d6e72 commit b5b308c
Show file tree
Hide file tree
Showing 5 changed files with 37 additions and 21 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@ import 'dart:io';
import 'dart:isolate';

import 'package:collection/collection.dart';
import 'package:flutter/foundation.dart';
import 'package:flutter/widgets.dart';
import 'package:http/http.dart' as http;
import 'package:path/path.dart';
import 'package:path_provider/path_provider.dart';
Expand Down Expand Up @@ -63,9 +63,9 @@ class TagLineProvider extends ChangeNotifier {

void _emit(TagLineState state) {
_state = state;
try {
WidgetsBinding.instance.addPostFrameCallback((_) {
notifyListeners();
} catch (_) {}
});
}

TagLineState get state => _state;
Expand Down
6 changes: 3 additions & 3 deletions packages/smooth_app/lib/pages/scan/scan_tagline.dart
Original file line number Diff line number Diff line change
Expand Up @@ -112,7 +112,7 @@ class _ScanTagLineContentState extends State<_ScanTagLineContent> {
DecoratedBox(
decoration: BoxDecoration(
color: currentNews.style?.titleBackground ??
(themeProvider.isLightTheme
(!themeProvider.isDarkMode(context)
? theme.primarySemiDark
: theme.primaryBlack),
borderRadius: const BorderRadiusDirectional.only(
Expand All @@ -137,7 +137,7 @@ class _ScanTagLineContentState extends State<_ScanTagLineContent> {
child: DecoratedBox(
decoration: BoxDecoration(
color: currentNews.style?.contentBackgroundColor ??
(themeProvider.isLightTheme
(!themeProvider.isDarkMode(context)
? theme.primaryMedium
: theme.primaryDark),
borderRadius: const BorderRadiusDirectional.only(
Expand Down Expand Up @@ -253,7 +253,7 @@ class _TagLineContentBody extends StatelessWidget {
text: message,
textStyle: TextStyle(
color: textColor ??
(themeProvider.isLightTheme
(!themeProvider.isDarkMode(context)
? theme.primarySemiDark
: theme.primaryLight),
),
Expand Down
2 changes: 1 addition & 1 deletion packages/smooth_app/lib/resources/app_animations.dart
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,7 @@ class _SearchEyeAnimationState extends State<SearchEyeAnimation> {
@override
Widget build(BuildContext context) {
final double size = widget.size ?? IconTheme.of(context).size ?? 24.0;
final bool lightTheme = context.watch<ThemeProvider>().isLightTheme;
final bool lightTheme = context.watch<ThemeProvider>().isDarkMode(context);

return ExcludeSemantics(
child: SizedBox(
Expand Down
28 changes: 24 additions & 4 deletions packages/smooth_app/lib/themes/theme_provider.dart
Original file line number Diff line number Diff line change
Expand Up @@ -7,15 +7,28 @@ const String THEME_DARK = 'Dark';
const String THEME_AMOLED = 'AMOLED';

class ThemeProvider with ChangeNotifier {
ThemeProvider(this._userPreferences);
ThemeProvider(this._userPreferences)
: _theme = _userPreferences.currentTheme {
_userPreferences.addListener(_onPreferencesChanged);
}

final UserPreferences _userPreferences;

// The onboarding needs the light mode.
bool _forceLight = false;

String get currentTheme =>
_forceLight ? THEME_LIGHT : _userPreferences.currentTheme;
// Local cache for [_userPreferences.currentTheme]
String _theme;

void _onPreferencesChanged() {
final String newTheme = _userPreferences.currentTheme;
if (newTheme != _theme) {
_theme = newTheme;
notifyListeners();
}
}

String get currentTheme => _forceLight ? THEME_LIGHT : _theme;

void setOnboardingComplete(final bool onboardingComplete) {
_forceLight = !onboardingComplete;
Expand Down Expand Up @@ -53,6 +66,13 @@ class ThemeProvider with ChangeNotifier {
}

bool isDarkMode(BuildContext context) {
return MediaQuery.platformBrightnessOf(context) == Brightness.dark;
return currentThemeMode != ThemeMode.light &&
MediaQuery.platformBrightnessOf(context) == Brightness.dark;
}

@override
void dispose() {
_userPreferences.removeListener(_onPreferencesChanged);
super.dispose();
}
}
16 changes: 6 additions & 10 deletions packages/smooth_app/lib/widgets/smooth_product_carousel.dart
Original file line number Diff line number Diff line change
Expand Up @@ -263,12 +263,10 @@ class _SearchCard extends StatelessWidget {
@override
Widget build(BuildContext context) {
final AppLocalizations localizations = AppLocalizations.of(context);
final ThemeProvider themeProvider = context.watch<ThemeProvider>();
final bool lightTheme = !context.watch<ThemeProvider>().isDarkMode(context);

final Widget widget = SmoothCard(
color: themeProvider.isLightTheme
? Colors.grey.withOpacity(0.1)
: Colors.black,
color: lightTheme ? Colors.grey.withOpacity(0.1) : Colors.black,
padding: const EdgeInsets.symmetric(
vertical: MEDIUM_SPACE,
horizontal: LARGE_SPACE,
Expand All @@ -281,7 +279,7 @@ class _SearchCard extends StatelessWidget {
mainAxisAlignment: MainAxisAlignment.spaceEvenly,
children: <Widget>[
SvgPicture.asset(
Theme.of(context).brightness == Brightness.light
lightTheme
? 'assets/app/logo_text_black.svg'
: 'assets/app/logo_text_white.svg',
semanticsLabel: localizations.homepage_main_card_logo_description,
Expand Down Expand Up @@ -317,9 +315,9 @@ class _SearchBar extends StatelessWidget {
@override
Widget build(BuildContext context) {
final AppLocalizations localizations = AppLocalizations.of(context);
final ThemeProvider themeProvider = context.watch<ThemeProvider>();
final SmoothColorsThemeExtension theme =
Theme.of(context).extension<SmoothColorsThemeExtension>()!;
final bool lightTheme = !context.watch<ThemeProvider>().isDarkMode(context);

return SizedBox(
height: SEARCH_BAR_HEIGHT,
Expand All @@ -329,7 +327,7 @@ class _SearchBar extends StatelessWidget {
child: Ink(
decoration: BoxDecoration(
borderRadius: BorderRadius.circular(30.0),
color: themeProvider.isLightTheme ? Colors.white : theme.greyDark,
color: lightTheme ? Colors.white : theme.greyDark,
border: Border.all(color: theme.primaryBlack),
),
child: Row(
Expand All @@ -347,9 +345,7 @@ class _SearchBar extends StatelessWidget {
maxLines: 1,
overflow: TextOverflow.ellipsis,
style: TextStyle(
color: themeProvider.isLightTheme
? Colors.black
: Colors.white,
color: lightTheme ? Colors.black : Colors.white,
),
),
),
Expand Down

0 comments on commit b5b308c

Please sign in to comment.