mirror of
https://github.com/flutter/samples.git
synced 2025-11-08 22:09:06 +00:00
Veggie seasons update (#518)
This commit is contained in:
@@ -19,4 +19,4 @@ match any new language/SDK features, etc.).
|
|||||||
| provider_counter | redbrogdon | 11/21/19 |
|
| provider_counter | redbrogdon | 11/21/19 |
|
||||||
| provider_shopper | redbrogdon | 11/21/19 |
|
| provider_shopper | redbrogdon | 11/21/19 |
|
||||||
| testing_app | | |
|
| testing_app | | |
|
||||||
| veggieseasons | | |
|
| veggieseasons | filiph | 8/13/20 |
|
||||||
|
|||||||
@@ -10,73 +10,32 @@ project 'Runner', {
|
|||||||
'Release' => :release,
|
'Release' => :release,
|
||||||
}
|
}
|
||||||
|
|
||||||
def parse_KV_file(file, separator='=')
|
def flutter_root
|
||||||
file_abs_path = File.expand_path(file)
|
generated_xcode_build_settings_path = File.expand_path(File.join('..', 'Flutter', 'Generated.xcconfig'), __FILE__)
|
||||||
if !File.exists? file_abs_path
|
unless File.exist?(generated_xcode_build_settings_path)
|
||||||
return [];
|
raise "#{generated_xcode_build_settings_path} must exist. If you're running pod install manually, make sure flutter pub get is executed first"
|
||||||
end
|
end
|
||||||
generated_key_values = {}
|
|
||||||
skip_line_start_symbols = ["#", "/"]
|
File.foreach(generated_xcode_build_settings_path) do |line|
|
||||||
File.foreach(file_abs_path) do |line|
|
matches = line.match(/FLUTTER_ROOT\=(.*)/)
|
||||||
next if skip_line_start_symbols.any? { |symbol| line =~ /^\s*#{symbol}/ }
|
return matches[1].strip if matches
|
||||||
plugin = line.split(pattern=separator)
|
|
||||||
if plugin.length == 2
|
|
||||||
podname = plugin[0].strip()
|
|
||||||
path = plugin[1].strip()
|
|
||||||
podpath = File.expand_path("#{path}", file_abs_path)
|
|
||||||
generated_key_values[podname] = podpath
|
|
||||||
else
|
|
||||||
puts "Invalid plugin specification: #{line}"
|
|
||||||
end
|
end
|
||||||
end
|
raise "FLUTTER_ROOT not found in #{generated_xcode_build_settings_path}. Try deleting Generated.xcconfig, then run flutter pub get"
|
||||||
generated_key_values
|
|
||||||
end
|
end
|
||||||
|
|
||||||
|
require File.expand_path(File.join('packages', 'flutter_tools', 'bin', 'podhelper'), flutter_root)
|
||||||
|
|
||||||
|
flutter_ios_podfile_setup
|
||||||
|
|
||||||
target 'Runner' do
|
target 'Runner' do
|
||||||
use_frameworks!
|
use_frameworks!
|
||||||
use_modular_headers!
|
use_modular_headers!
|
||||||
|
|
||||||
# Flutter Pod
|
flutter_install_all_ios_pods File.dirname(File.realpath(__FILE__))
|
||||||
|
|
||||||
copied_flutter_dir = File.join(__dir__, 'Flutter')
|
|
||||||
copied_framework_path = File.join(copied_flutter_dir, 'Flutter.framework')
|
|
||||||
copied_podspec_path = File.join(copied_flutter_dir, 'Flutter.podspec')
|
|
||||||
unless File.exist?(copied_framework_path) && File.exist?(copied_podspec_path)
|
|
||||||
# Copy Flutter.framework and Flutter.podspec to Flutter/ to have something to link against if the xcode backend script has not run yet.
|
|
||||||
# That script will copy the correct debug/profile/release version of the framework based on the currently selected Xcode configuration.
|
|
||||||
# CocoaPods will not embed the framework on pod install (before any build phases can generate) if the dylib does not exist.
|
|
||||||
|
|
||||||
generated_xcode_build_settings_path = File.join(copied_flutter_dir, 'Generated.xcconfig')
|
|
||||||
unless File.exist?(generated_xcode_build_settings_path)
|
|
||||||
raise "Generated.xcconfig must exist. If you're running pod install manually, make sure flutter pub get is executed first"
|
|
||||||
end
|
|
||||||
generated_xcode_build_settings = parse_KV_file(generated_xcode_build_settings_path)
|
|
||||||
cached_framework_dir = generated_xcode_build_settings['FLUTTER_FRAMEWORK_DIR'];
|
|
||||||
|
|
||||||
unless File.exist?(copied_framework_path)
|
|
||||||
FileUtils.cp_r(File.join(cached_framework_dir, 'Flutter.framework'), copied_flutter_dir)
|
|
||||||
end
|
|
||||||
unless File.exist?(copied_podspec_path)
|
|
||||||
FileUtils.cp(File.join(cached_framework_dir, 'Flutter.podspec'), copied_flutter_dir)
|
|
||||||
end
|
|
||||||
end
|
|
||||||
|
|
||||||
# Keep pod path relative so it can be checked into Podfile.lock.
|
|
||||||
pod 'Flutter', :path => 'Flutter'
|
|
||||||
|
|
||||||
# Plugin Pods
|
|
||||||
|
|
||||||
# Prepare symlinks folder. We use symlinks to avoid having Podfile.lock
|
|
||||||
# referring to absolute paths on developers' machines.
|
|
||||||
system('rm -rf .symlinks')
|
|
||||||
system('mkdir -p .symlinks/plugins')
|
|
||||||
plugin_pods = parse_KV_file('../.flutter-plugins')
|
|
||||||
plugin_pods.each do |name, path|
|
|
||||||
symlink = File.join('.symlinks', 'plugins', name)
|
|
||||||
File.symlink(path, symlink)
|
|
||||||
pod name, :path => File.join(symlink, 'ios')
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
# Prevent Cocoapods from embedding a second Flutter framework and causing an error with the new Xcode build system.
|
post_install do |installer|
|
||||||
install! 'cocoapods', :disable_input_output_paths => true
|
installer.pods_project.targets.each do |target|
|
||||||
|
flutter_additional_ios_build_settings(target)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|||||||
@@ -2,33 +2,21 @@ PODS:
|
|||||||
- Flutter (1.0.0)
|
- Flutter (1.0.0)
|
||||||
- shared_preferences (0.0.1):
|
- shared_preferences (0.0.1):
|
||||||
- Flutter
|
- Flutter
|
||||||
- shared_preferences_macos (0.0.1):
|
|
||||||
- Flutter
|
|
||||||
- shared_preferences_web (0.0.1):
|
|
||||||
- Flutter
|
|
||||||
|
|
||||||
DEPENDENCIES:
|
DEPENDENCIES:
|
||||||
- Flutter (from `Flutter`)
|
- Flutter (from `Flutter`)
|
||||||
- shared_preferences (from `.symlinks/plugins/shared_preferences/ios`)
|
- shared_preferences (from `.symlinks/plugins/shared_preferences/ios`)
|
||||||
- shared_preferences_macos (from `.symlinks/plugins/shared_preferences_macos/ios`)
|
|
||||||
- shared_preferences_web (from `.symlinks/plugins/shared_preferences_web/ios`)
|
|
||||||
|
|
||||||
EXTERNAL SOURCES:
|
EXTERNAL SOURCES:
|
||||||
Flutter:
|
Flutter:
|
||||||
:path: Flutter
|
:path: Flutter
|
||||||
shared_preferences:
|
shared_preferences:
|
||||||
:path: ".symlinks/plugins/shared_preferences/ios"
|
:path: ".symlinks/plugins/shared_preferences/ios"
|
||||||
shared_preferences_macos:
|
|
||||||
:path: ".symlinks/plugins/shared_preferences_macos/ios"
|
|
||||||
shared_preferences_web:
|
|
||||||
:path: ".symlinks/plugins/shared_preferences_web/ios"
|
|
||||||
|
|
||||||
SPEC CHECKSUMS:
|
SPEC CHECKSUMS:
|
||||||
Flutter: 0e3d915762c693b495b44d77113d4970485de6ec
|
Flutter: 0e3d915762c693b495b44d77113d4970485de6ec
|
||||||
shared_preferences: af6bfa751691cdc24be3045c43ec037377ada40d
|
shared_preferences: af6bfa751691cdc24be3045c43ec037377ada40d
|
||||||
shared_preferences_macos: f3f29b71ccbb56bf40c9dd6396c9acf15e214087
|
|
||||||
shared_preferences_web: 141cce0c3ed1a1c5bf2a0e44f52d31eeb66e5ea9
|
|
||||||
|
|
||||||
PODFILE CHECKSUM: 75bff59e97643485829cfc01124f2ea710a554fc
|
PODFILE CHECKSUM: aafe91acc616949ddb318b77800a7f51bffa2a4c
|
||||||
|
|
||||||
COCOAPODS: 1.9.1
|
COCOAPODS: 1.9.1
|
||||||
|
|||||||
@@ -225,9 +225,14 @@
|
|||||||
files = (
|
files = (
|
||||||
);
|
);
|
||||||
inputPaths = (
|
inputPaths = (
|
||||||
|
"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks.sh",
|
||||||
|
"${PODS_ROOT}/../Flutter/Flutter.framework",
|
||||||
|
"${BUILT_PRODUCTS_DIR}/shared_preferences/shared_preferences.framework",
|
||||||
);
|
);
|
||||||
name = "[CP] Embed Pods Frameworks";
|
name = "[CP] Embed Pods Frameworks";
|
||||||
outputPaths = (
|
outputPaths = (
|
||||||
|
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/Flutter.framework",
|
||||||
|
"${TARGET_BUILD_DIR}/${FRAMEWORKS_FOLDER_PATH}/shared_preferences.framework",
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
shellPath = /bin/sh;
|
shellPath = /bin/sh;
|
||||||
|
|||||||
@@ -2,31 +2,31 @@
|
|||||||
// Use of this source code is governed by a BSD-style license that can be
|
// Use of this source code is governed by a BSD-style license that can be
|
||||||
// found in the LICENSE file.
|
// found in the LICENSE file.
|
||||||
|
|
||||||
import 'package:scoped_model/scoped_model.dart';
|
import 'package:flutter/foundation.dart';
|
||||||
import 'package:veggieseasons/data/veggie.dart';
|
|
||||||
import 'package:veggieseasons/data/local_veggie_provider.dart';
|
import 'package:veggieseasons/data/local_veggie_provider.dart';
|
||||||
|
import 'package:veggieseasons/data/veggie.dart';
|
||||||
|
|
||||||
class AppState extends Model {
|
class AppState extends ChangeNotifier {
|
||||||
final List<Veggie> _veggies;
|
final List<Veggie> _veggies;
|
||||||
|
|
||||||
AppState() : _veggies = LocalVeggieProvider.veggies;
|
AppState() : _veggies = LocalVeggieProvider.veggies;
|
||||||
|
|
||||||
List<Veggie> get allVeggies => List<Veggie>.from(_veggies);
|
List<Veggie> get allVeggies => List<Veggie>.from(_veggies);
|
||||||
|
|
||||||
Veggie getVeggie(int id) => _veggies.singleWhere((v) => v.id == id);
|
|
||||||
|
|
||||||
List<Veggie> get availableVeggies {
|
List<Veggie> get availableVeggies {
|
||||||
var currentSeason = _getSeasonForDate(DateTime.now());
|
var currentSeason = _getSeasonForDate(DateTime.now());
|
||||||
return _veggies.where((v) => v.seasons.contains(currentSeason)).toList();
|
return _veggies.where((v) => v.seasons.contains(currentSeason)).toList();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
List<Veggie> get favoriteVeggies =>
|
||||||
|
_veggies.where((v) => v.isFavorite).toList();
|
||||||
|
|
||||||
List<Veggie> get unavailableVeggies {
|
List<Veggie> get unavailableVeggies {
|
||||||
var currentSeason = _getSeasonForDate(DateTime.now());
|
var currentSeason = _getSeasonForDate(DateTime.now());
|
||||||
return _veggies.where((v) => !v.seasons.contains(currentSeason)).toList();
|
return _veggies.where((v) => !v.seasons.contains(currentSeason)).toList();
|
||||||
}
|
}
|
||||||
|
|
||||||
List<Veggie> get favoriteVeggies =>
|
Veggie getVeggie(int id) => _veggies.singleWhere((v) => v.id == id);
|
||||||
_veggies.where((v) => v.isFavorite).toList();
|
|
||||||
|
|
||||||
List<Veggie> searchVeggies(String terms) => _veggies
|
List<Veggie> searchVeggies(String terms) => _veggies
|
||||||
.where((v) => v.name.toLowerCase().contains(terms.toLowerCase()))
|
.where((v) => v.name.toLowerCase().contains(terms.toLowerCase()))
|
||||||
|
|||||||
@@ -4,13 +4,13 @@
|
|||||||
|
|
||||||
import 'dart:async';
|
import 'dart:async';
|
||||||
|
|
||||||
import 'package:scoped_model/scoped_model.dart';
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:veggieseasons/data/veggie.dart';
|
import 'package:veggieseasons/data/veggie.dart';
|
||||||
import 'package:shared_preferences/shared_preferences.dart';
|
import 'package:shared_preferences/shared_preferences.dart';
|
||||||
|
|
||||||
/// A model class that mirrors the options in [SettingsScreen] and stores data
|
/// A model class that mirrors the options in [SettingsScreen] and stores data
|
||||||
/// in shared preferences.
|
/// in shared preferences.
|
||||||
class Preferences extends Model {
|
class Preferences extends ChangeNotifier {
|
||||||
// Keys to use with shared preferences.
|
// Keys to use with shared preferences.
|
||||||
static const _caloriesKey = 'calories';
|
static const _caloriesKey = 'calories';
|
||||||
static const _preferredCategoriesKey = 'preferredCategories';
|
static const _preferredCategoriesKey = 'preferredCategories';
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
import 'package:flutter/cupertino.dart';
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:flutter/services.dart' show DeviceOrientation, SystemChrome;
|
import 'package:flutter/services.dart' show DeviceOrientation, SystemChrome;
|
||||||
import 'package:scoped_model/scoped_model.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:veggieseasons/data/app_state.dart';
|
import 'package:veggieseasons/data/app_state.dart';
|
||||||
import 'package:veggieseasons/data/preferences.dart';
|
import 'package:veggieseasons/data/preferences.dart';
|
||||||
import 'package:veggieseasons/screens/home.dart';
|
import 'package:veggieseasons/screens/home.dart';
|
||||||
@@ -17,15 +17,19 @@ void main() {
|
|||||||
]);
|
]);
|
||||||
|
|
||||||
runApp(
|
runApp(
|
||||||
ScopedModel<AppState>(
|
MultiProvider(
|
||||||
model: AppState(),
|
providers: [
|
||||||
child: ScopedModel<Preferences>(
|
ChangeNotifierProvider(
|
||||||
model: Preferences()..load(),
|
create: (_) => AppState(),
|
||||||
|
),
|
||||||
|
ChangeNotifierProvider(
|
||||||
|
create: (_) => Preferences()..load(),
|
||||||
|
),
|
||||||
|
],
|
||||||
child: CupertinoApp(
|
child: CupertinoApp(
|
||||||
debugShowCheckedModeBanner: false,
|
debugShowCheckedModeBanner: false,
|
||||||
home: HomeScreen(),
|
home: HomeScreen(),
|
||||||
),
|
),
|
||||||
),
|
),
|
||||||
),
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
import 'package:flutter/cupertino.dart';
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:flutter/widgets.dart';
|
import 'package:flutter/widgets.dart';
|
||||||
import 'package:scoped_model/scoped_model.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:veggieseasons/data/app_state.dart';
|
import 'package:veggieseasons/data/app_state.dart';
|
||||||
import 'package:veggieseasons/data/preferences.dart';
|
import 'package:veggieseasons/data/preferences.dart';
|
||||||
import 'package:veggieseasons/data/veggie.dart';
|
import 'package:veggieseasons/data/veggie.dart';
|
||||||
@@ -163,8 +163,8 @@ class InfoView extends StatelessWidget {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final appState = ScopedModel.of<AppState>(context, rebuildOnChange: true);
|
final appState = Provider.of<AppState>(context);
|
||||||
final prefs = ScopedModel.of<Preferences>(context, rebuildOnChange: true);
|
final prefs = Provider.of<Preferences>(context);
|
||||||
final veggie = appState.getVeggie(id);
|
final veggie = appState.getVeggie(id);
|
||||||
final themeData = CupertinoTheme.of(context);
|
final themeData = CupertinoTheme.of(context);
|
||||||
|
|
||||||
@@ -280,7 +280,7 @@ class _DetailsScreenState extends State<DetailsScreen> {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final appState = ScopedModel.of<AppState>(context, rebuildOnChange: true);
|
final appState = Provider.of<AppState>(context);
|
||||||
|
|
||||||
return CupertinoPageScaffold(
|
return CupertinoPageScaffold(
|
||||||
child: Column(
|
child: Column(
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
import 'package:flutter/cupertino.dart';
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:flutter/widgets.dart';
|
import 'package:flutter/widgets.dart';
|
||||||
import 'package:scoped_model/scoped_model.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:veggieseasons/data/app_state.dart';
|
import 'package:veggieseasons/data/app_state.dart';
|
||||||
import 'package:veggieseasons/data/veggie.dart';
|
import 'package:veggieseasons/data/veggie.dart';
|
||||||
import 'package:veggieseasons/styles.dart';
|
import 'package:veggieseasons/styles.dart';
|
||||||
@@ -15,7 +15,7 @@ class FavoritesScreen extends StatelessWidget {
|
|||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return CupertinoTabView(
|
return CupertinoTabView(
|
||||||
builder: (context) {
|
builder: (context) {
|
||||||
final model = ScopedModel.of<AppState>(context, rebuildOnChange: true);
|
final model = Provider.of<AppState>(context);
|
||||||
|
|
||||||
return CupertinoPageScaffold(
|
return CupertinoPageScaffold(
|
||||||
navigationBar: CupertinoNavigationBar(
|
navigationBar: CupertinoNavigationBar(
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
import 'package:flutter/cupertino.dart';
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:flutter/widgets.dart';
|
import 'package:flutter/widgets.dart';
|
||||||
import 'package:intl/intl.dart';
|
import 'package:intl/intl.dart';
|
||||||
import 'package:scoped_model/scoped_model.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:veggieseasons/data/app_state.dart';
|
import 'package:veggieseasons/data/app_state.dart';
|
||||||
import 'package:veggieseasons/data/preferences.dart';
|
import 'package:veggieseasons/data/preferences.dart';
|
||||||
import 'package:veggieseasons/data/veggie.dart';
|
import 'package:veggieseasons/data/veggie.dart';
|
||||||
@@ -32,10 +32,8 @@ class ListScreen extends StatelessWidget {
|
|||||||
builder: (context) {
|
builder: (context) {
|
||||||
var dateString = DateFormat('MMMM y').format(DateTime.now());
|
var dateString = DateFormat('MMMM y').format(DateTime.now());
|
||||||
|
|
||||||
final appState =
|
final appState = Provider.of<AppState>(context);
|
||||||
ScopedModel.of<AppState>(context, rebuildOnChange: true);
|
final prefs = Provider.of<Preferences>(context);
|
||||||
final prefs =
|
|
||||||
ScopedModel.of<Preferences>(context, rebuildOnChange: true);
|
|
||||||
final themeData = CupertinoTheme.of(context);
|
final themeData = CupertinoTheme.of(context);
|
||||||
return SafeArea(
|
return SafeArea(
|
||||||
bottom: false,
|
bottom: false,
|
||||||
|
|||||||
@@ -4,7 +4,7 @@
|
|||||||
|
|
||||||
import 'package:flutter/cupertino.dart';
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:flutter/widgets.dart';
|
import 'package:flutter/widgets.dart';
|
||||||
import 'package:scoped_model/scoped_model.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:veggieseasons/data/app_state.dart';
|
import 'package:veggieseasons/data/app_state.dart';
|
||||||
import 'package:veggieseasons/data/veggie.dart';
|
import 'package:veggieseasons/data/veggie.dart';
|
||||||
import 'package:veggieseasons/styles.dart';
|
import 'package:veggieseasons/styles.dart';
|
||||||
@@ -73,7 +73,7 @@ class _SearchScreenState extends State<SearchScreen> {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final model = ScopedModel.of<AppState>(context, rebuildOnChange: true);
|
final model = Provider.of<AppState>(context);
|
||||||
|
|
||||||
return CupertinoTabView(
|
return CupertinoTabView(
|
||||||
builder: (context) {
|
builder: (context) {
|
||||||
|
|||||||
@@ -5,7 +5,7 @@
|
|||||||
import 'package:flutter/cupertino.dart';
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter/widgets.dart';
|
import 'package:flutter/widgets.dart';
|
||||||
import 'package:scoped_model/scoped_model.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:veggieseasons/data/preferences.dart';
|
import 'package:veggieseasons/data/preferences.dart';
|
||||||
import 'package:veggieseasons/data/veggie.dart';
|
import 'package:veggieseasons/data/veggie.dart';
|
||||||
import 'package:veggieseasons/styles.dart';
|
import 'package:veggieseasons/styles.dart';
|
||||||
@@ -15,7 +15,7 @@ import 'package:veggieseasons/widgets/settings_item.dart';
|
|||||||
class VeggieCategorySettingsScreen extends StatelessWidget {
|
class VeggieCategorySettingsScreen extends StatelessWidget {
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final model = ScopedModel.of<Preferences>(context, rebuildOnChange: true);
|
final model = Provider.of<Preferences>(context);
|
||||||
final currentPrefs = model.preferredCategories;
|
final currentPrefs = model.preferredCategories;
|
||||||
var brightness = CupertinoTheme.brightnessOf(context);
|
var brightness = CupertinoTheme.brightnessOf(context);
|
||||||
return CupertinoPageScaffold(
|
return CupertinoPageScaffold(
|
||||||
@@ -79,7 +79,7 @@ class CalorieSettingsScreen extends StatelessWidget {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final model = ScopedModel.of<Preferences>(context, rebuildOnChange: true);
|
final model = Provider.of<Preferences>(context);
|
||||||
var brightness = CupertinoTheme.brightnessOf(context);
|
var brightness = CupertinoTheme.brightnessOf(context);
|
||||||
return CupertinoPageScaffold(
|
return CupertinoPageScaffold(
|
||||||
navigationBar: CupertinoNavigationBar(
|
navigationBar: CupertinoNavigationBar(
|
||||||
@@ -181,7 +181,7 @@ class SettingsScreen extends StatelessWidget {
|
|||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
final prefs = ScopedModel.of<Preferences>(context, rebuildOnChange: true);
|
final prefs = Provider.of<Preferences>(context);
|
||||||
|
|
||||||
return CupertinoPageScaffold(
|
return CupertinoPageScaffold(
|
||||||
child: Container(
|
child: Container(
|
||||||
|
|||||||
@@ -1,6 +1,6 @@
|
|||||||
import 'package:flutter/cupertino.dart';
|
import 'package:flutter/cupertino.dart';
|
||||||
import 'package:flutter/widgets.dart';
|
import 'package:flutter/widgets.dart';
|
||||||
import 'package:scoped_model/scoped_model.dart';
|
import 'package:provider/provider.dart';
|
||||||
import 'package:veggieseasons/data/app_state.dart';
|
import 'package:veggieseasons/data/app_state.dart';
|
||||||
import 'package:veggieseasons/data/veggie.dart';
|
import 'package:veggieseasons/data/veggie.dart';
|
||||||
import 'package:veggieseasons/styles.dart';
|
import 'package:veggieseasons/styles.dart';
|
||||||
@@ -48,8 +48,7 @@ class _TriviaViewState extends State<TriviaView> {
|
|||||||
void didChangeDependencies() {
|
void didChangeDependencies() {
|
||||||
super.didChangeDependencies();
|
super.didChangeDependencies();
|
||||||
|
|
||||||
final newAppState =
|
final newAppState = Provider.of<AppState>(context);
|
||||||
ScopedModel.of<AppState>(context, rebuildOnChange: true);
|
|
||||||
|
|
||||||
setState(() {
|
setState(() {
|
||||||
appState = newAppState;
|
appState = newAppState;
|
||||||
|
|||||||
@@ -85,6 +85,13 @@ packages:
|
|||||||
url: "https://pub.dartlang.org"
|
url: "https://pub.dartlang.org"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.1.0"
|
version: "1.1.0"
|
||||||
|
file:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: file
|
||||||
|
url: "https://pub.dartlang.org"
|
||||||
|
source: hosted
|
||||||
|
version: "5.2.1"
|
||||||
flutter:
|
flutter:
|
||||||
dependency: "direct main"
|
dependency: "direct main"
|
||||||
description: flutter
|
description: flutter
|
||||||
@@ -142,6 +149,13 @@ packages:
|
|||||||
url: "https://pub.dartlang.org"
|
url: "https://pub.dartlang.org"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.1.8"
|
version: "1.1.8"
|
||||||
|
nested:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: nested
|
||||||
|
url: "https://pub.dartlang.org"
|
||||||
|
source: hosted
|
||||||
|
version: "0.0.4"
|
||||||
path:
|
path:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -149,6 +163,20 @@ packages:
|
|||||||
url: "https://pub.dartlang.org"
|
url: "https://pub.dartlang.org"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.7.0"
|
version: "1.7.0"
|
||||||
|
path_provider_linux:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: path_provider_linux
|
||||||
|
url: "https://pub.dartlang.org"
|
||||||
|
source: hosted
|
||||||
|
version: "0.0.1+2"
|
||||||
|
path_provider_platform_interface:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: path_provider_platform_interface
|
||||||
|
url: "https://pub.dartlang.org"
|
||||||
|
source: hosted
|
||||||
|
version: "1.0.2"
|
||||||
pedantic:
|
pedantic:
|
||||||
dependency: "direct dev"
|
dependency: "direct dev"
|
||||||
description:
|
description:
|
||||||
@@ -163,20 +191,48 @@ packages:
|
|||||||
url: "https://pub.dartlang.org"
|
url: "https://pub.dartlang.org"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "2.4.0"
|
version: "2.4.0"
|
||||||
scoped_model:
|
platform:
|
||||||
dependency: "direct main"
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
name: scoped_model
|
name: platform
|
||||||
url: "https://pub.dartlang.org"
|
url: "https://pub.dartlang.org"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.0.1"
|
version: "2.2.1"
|
||||||
|
plugin_platform_interface:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: plugin_platform_interface
|
||||||
|
url: "https://pub.dartlang.org"
|
||||||
|
source: hosted
|
||||||
|
version: "1.0.2"
|
||||||
|
process:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: process
|
||||||
|
url: "https://pub.dartlang.org"
|
||||||
|
source: hosted
|
||||||
|
version: "3.0.13"
|
||||||
|
provider:
|
||||||
|
dependency: "direct main"
|
||||||
|
description:
|
||||||
|
name: provider
|
||||||
|
url: "https://pub.dartlang.org"
|
||||||
|
source: hosted
|
||||||
|
version: "4.3.2"
|
||||||
shared_preferences:
|
shared_preferences:
|
||||||
dependency: "direct main"
|
dependency: "direct main"
|
||||||
description:
|
description:
|
||||||
name: shared_preferences
|
name: shared_preferences
|
||||||
url: "https://pub.dartlang.org"
|
url: "https://pub.dartlang.org"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.5.7+1"
|
version: "0.5.8"
|
||||||
|
shared_preferences_linux:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: shared_preferences_linux
|
||||||
|
url: "https://pub.dartlang.org"
|
||||||
|
source: hosted
|
||||||
|
version: "0.0.2+1"
|
||||||
shared_preferences_macos:
|
shared_preferences_macos:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -259,6 +315,13 @@ packages:
|
|||||||
url: "https://pub.dartlang.org"
|
url: "https://pub.dartlang.org"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "2.0.8"
|
version: "2.0.8"
|
||||||
|
xdg_directories:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: xdg_directories
|
||||||
|
url: "https://pub.dartlang.org"
|
||||||
|
source: hosted
|
||||||
|
version: "0.1.0"
|
||||||
xml:
|
xml:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -275,4 +338,4 @@ packages:
|
|||||||
version: "2.2.1"
|
version: "2.2.1"
|
||||||
sdks:
|
sdks:
|
||||||
dart: ">=2.9.0-14.0.dev <3.0.0"
|
dart: ">=2.9.0-14.0.dev <3.0.0"
|
||||||
flutter: ">=1.12.13+hotfix.5 <2.0.0"
|
flutter: ">=1.16.0 <2.0.0"
|
||||||
|
|||||||
@@ -13,8 +13,8 @@ dependencies:
|
|||||||
cupertino_icons: ^0.1.3
|
cupertino_icons: ^0.1.3
|
||||||
font_awesome_flutter: ^8.8.1
|
font_awesome_flutter: ^8.8.1
|
||||||
intl: ^0.16.1
|
intl: ^0.16.1
|
||||||
scoped_model: ^1.0.1
|
provider: ^4.3.2
|
||||||
shared_preferences: ^0.5.7
|
shared_preferences: ^0.5.8
|
||||||
|
|
||||||
dev_dependencies:
|
dev_dependencies:
|
||||||
flutter_test:
|
flutter_test:
|
||||||
|
|||||||
Reference in New Issue
Block a user