Browse Source

Upgrade to Flutter 3

master
Kenneth Bruen 2 years ago
parent
commit
1f48e868b0
Signed by: kbruen
GPG Key ID: C1980A470C3EE5B1
  1. 2
      lib/components/select_train_suggestions/select_train_suggestions.dart
  2. 2
      lib/components/slim_app_bar.dart
  3. 108
      lib/main.dart
  4. 1
      lib/pages/settings/settings_page_cupertino.dart
  5. 2
      lib/pages/station_arrdep_page/view_station/view_station_material.dart
  6. 15
      lib/utils/state_to_string.dart
  7. 646
      pubspec.lock
  8. 12
      pubspec.yaml

2
lib/components/select_train_suggestions/select_train_suggestions.dart

@ -1,4 +1,3 @@
import 'package:flutter/widgets.dart'; import 'package:flutter/widgets.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:info_tren/components/select_train_suggestions/select_train_suggestions_cupertino.dart'; import 'package:info_tren/components/select_train_suggestions/select_train_suggestions_cupertino.dart';
@ -6,7 +5,6 @@ import 'package:info_tren/components/select_train_suggestions/select_train_sugge
import 'package:info_tren/components/select_train_suggestions/select_train_suggestions_material.dart'; import 'package:info_tren/components/select_train_suggestions/select_train_suggestions_material.dart';
import 'package:info_tren/models.dart'; import 'package:info_tren/models.dart';
import 'package:info_tren/providers.dart'; import 'package:info_tren/providers.dart';
import 'package:info_tren/utils/default_ui_design.dart';
class SelectTrainSuggestions extends ConsumerWidget { class SelectTrainSuggestions extends ConsumerWidget {
final List<TrainsResult> choices; final List<TrainsResult> choices;

2
lib/components/slim_app_bar.dart

@ -44,7 +44,7 @@ class SlimAppBar extends StatelessWidget {
title, title,
textAlign: TextAlign.center, textAlign: TextAlign.center,
style: style:
Theme.of(context).appBarTheme.textTheme?.bodySmall?.copyWith(color: Theme.of(context).appBarTheme.textTheme?.bodyMedium?.color) ?? Theme.of(context).textTheme.titleSmall?.copyWith(color: Theme.of(context).textTheme.titleLarge?.color) ??
Theme.of(context).textTheme.bodySmall?.copyWith(color: Theme.of(context).textTheme.bodyMedium?.color), Theme.of(context).textTheme.bodySmall?.copyWith(color: Theme.of(context).textTheme.bodyMedium?.color),
), ),
), ),

108
lib/main.dart

@ -1,5 +1,6 @@
import 'dart:io'; import 'dart:io';
import 'package:dynamic_color/dynamic_color.dart';
import 'package:fluent_ui/fluent_ui.dart' as f; import 'package:fluent_ui/fluent_ui.dart' as f;
import 'package:flutter/cupertino.dart' as c; import 'package:flutter/cupertino.dart' as c;
import 'package:flutter/gestures.dart'; import 'package:flutter/gestures.dart';
@ -20,6 +21,7 @@ import 'package:shared_preferences/shared_preferences.dart';
import 'package:timezone/data/latest.dart'; import 'package:timezone/data/latest.dart';
void main() async { void main() async {
WidgetsFlutterBinding.ensureInitialized();
initializeTimeZones(); initializeTimeZones();
final sharedPreferences = await SharedPreferences.getInstance(); final sharedPreferences = await SharedPreferences.getInstance();
runApp( runApp(
@ -107,52 +109,82 @@ class StartPoint extends ConsumerWidget {
Widget build(BuildContext context, WidgetRef ref) { Widget build(BuildContext context, WidgetRef ref) {
final uiDesign = ref.watch(uiDesignProvider); final uiDesign = ref.watch(uiDesignProvider);
if (uiDesign == UiDesign.CUPERTINO) { if (uiDesign == UiDesign.CUPERTINO) {
return AnnotatedRegion( return DynamicColorBuilder(
value: const SystemUiOverlayStyle( builder: (lightScheme, darkScheme) {
statusBarBrightness: c.Brightness.dark, return AnnotatedRegion(
), value: const SystemUiOverlayStyle(
child: c.CupertinoApp( statusBarBrightness: c.Brightness.dark,
title: appTitle, ),
theme: c.CupertinoThemeData( child: c.CupertinoApp(
primaryColor: m.Colors.blue.shade600, title: appTitle,
brightness: c.Brightness.dark, theme: c.CupertinoThemeData(
// textTheme: CupertinoTextThemeData( primaryColor: darkScheme?.primary ?? m.Colors.blue.shade600,
// textStyle: TextStyle( brightness: c.Brightness.dark,
// fontFamily: 'Atkinson Hyperlegible', // textTheme: CupertinoTextThemeData(
// ), // textStyle: TextStyle(
// ), // fontFamily: 'Atkinson Hyperlegible',
), // ),
scrollBehavior: Platform.isLinux ? const DragCupertinoScrollBevahior() : null, // ),
routes: routes, ),
), scrollBehavior: Platform.isLinux ? const DragCupertinoScrollBevahior() : null,
routes: routes,
),
);
}
); );
} }
else if (uiDesign == UiDesign.FLUENT) { else if (uiDesign == UiDesign.FLUENT) {
return f.FluentApp( return DynamicColorBuilder(
title: appTitle, builder: (lightScheme, darkScheme) {
theme: f.ThemeData( return f.FluentApp(
brightness: f.Brightness.dark, title: appTitle,
accentColor: f.Colors.blue, theme: f.FluentThemeData(
), brightness: f.Brightness.light,
routes: routes, accentColor: lightScheme != null ? f.AccentColor.swatch({
scrollBehavior: Platform.isLinux ? const DragFluentScrollBevahior() : const f.FluentScrollBehavior(), 'normal': lightScheme.primary,
}) : f.Colors.blue,
),
darkTheme: f.FluentThemeData(
brightness: f.Brightness.dark,
accentColor: darkScheme != null ? f.AccentColor.swatch({
'normal': darkScheme.primary,
}) : f.Colors.blue,
),
routes: routes,
scrollBehavior: Platform.isLinux ? const DragFluentScrollBevahior() : const f.FluentScrollBehavior(),
);
}
); );
} }
else { else {
return m.MaterialApp( return DynamicColorBuilder(
title: appTitle, builder: (lightScheme, darkScheme) {
theme: m.ThemeData( lightScheme ??= m.ColorScheme.fromSwatch(
primarySwatch: m.Colors.blue, brightness: m.Brightness.light,
colorScheme: m.ColorScheme.fromSwatch( primarySwatch: m.Colors.blue,
);
darkScheme ??= m.ColorScheme.fromSwatch(
brightness: m.Brightness.dark, brightness: m.Brightness.dark,
primarySwatch: m.Colors.blue, primarySwatch: m.Colors.blue,
accentColor: m.Colors.blue.shade700, );
),
useMaterial3: true,
// fontFamily: 'Atkinson Hyperlegible', return m.MaterialApp(
), title: appTitle,
scrollBehavior: Platform.isLinux ? const DragMaterialScrollBevahior() : null, theme: m.ThemeData(
routes: routes, colorScheme: lightScheme,
useMaterial3: true,
// fontFamily: 'Atkinson Hyperlegible',
),
darkTheme: m.ThemeData(
colorScheme: darkScheme,
useMaterial3: true,
// fontFamily: 'Atkinson Hyperlegible',
),
scrollBehavior: Platform.isLinux ? const DragMaterialScrollBevahior() : null,
routes: routes,
);
}
); );
} }
} }

1
lib/pages/settings/settings_page_cupertino.dart

@ -1,6 +1,5 @@
import 'package:flutter/cupertino.dart'; import 'package:flutter/cupertino.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:info_tren/components/cupertino_listtile.dart';
import 'package:info_tren/models.dart'; import 'package:info_tren/models.dart';
import 'package:info_tren/pages/settings/setings_page.dart'; import 'package:info_tren/pages/settings/setings_page.dart';
import 'package:info_tren/providers.dart'; import 'package:info_tren/providers.dart';

2
lib/pages/station_arrdep_page/view_station/view_station_material.dart

@ -1,6 +1,6 @@
import 'dart:math'; import 'dart:math';
import 'dart:ui'; import 'dart:ui';
import 'package:flutter/material.dart'; import 'package:flutter/material.dart' hide Badge;
import 'package:hooks_riverpod/hooks_riverpod.dart'; import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:info_tren/components/badge/badge.dart'; import 'package:info_tren/components/badge/badge.dart';
import 'package:info_tren/components/loading/loading.dart'; import 'package:info_tren/components/loading/loading.dart';

15
lib/utils/state_to_string.dart

@ -1,12 +1,7 @@
import 'package:info_tren/models.dart'; import 'package:info_tren/models.dart';
String stateToString(TrainDataState state) { String stateToString(TrainDataState state) => switch (state) {
switch(state) { TrainDataState.passing => 'trecere fără oprire',
case TrainDataState.PASSING: TrainDataState.arrival => 'sosire',
return 'trecere fără oprire'; TrainDataState.departure => 'plecare',
case TrainDataState.ARRIVAL: };
return 'sosire';
case TrainDataState.DEPARTURE:
return 'plecare';
}
}

646
pubspec.lock

File diff suppressed because it is too large Load Diff

12
pubspec.yaml

@ -14,7 +14,7 @@ description: O aplicație de vizualizare a datelor puse la dispoziție de Inform
version: 2.7.10 version: 2.7.10
environment: environment:
sdk: ">=2.17.0 <3.0.0" sdk: ">=3.0.0 <4.0.0"
dependencies: dependencies:
flutter: flutter:
@ -30,19 +30,23 @@ dependencies:
url_launcher: ^6.1.5 url_launcher: ^6.1.5
flutter_hooks: ^0.18.5+1 flutter_hooks: ^0.18.5+1
hooks_riverpod: ^2.0.2 hooks_riverpod: ^2.0.2
freezed_annotation: ^2.2.0 freezed_annotation: ^2.4.1
json_annotation: ^4.7.0 json_annotation: ^4.8.1
shared_preferences: ^2.0.15 shared_preferences: ^2.0.15
fluent_ui: ^4.0.3+1 fluent_ui: ^4.0.3+1
timezone: ^0.9.0 timezone: ^0.9.0
dynamic_color: ^1.6.6
riverpod_annotation: ^2.1.1
dev_dependencies: dev_dependencies:
# flutter_test: # flutter_test:
# sdk: flutter # sdk: flutter
build_runner: ^2.1.0 build_runner: ^2.1.0
json_serializable: ^6.5.4 json_serializable: ^6.5.4
freezed: 2.2.0 freezed: ^2.4.1
flutter_lints: ^2.0.1 flutter_lints: ^2.0.1
riverpod_lint: ^1.3.2
riverpod_generator: ^2.2.3
# For information on the generic Dart part of this file, see the # For information on the generic Dart part of this file, see the

Loading…
Cancel
Save