mirror of
https://github.com/vodemn/m3_lightmeter.git
synced 2024-11-23 16:00:41 +00:00
31ef42c4c0
* added source code list tile * added settings sections * wip * moved theme tiles to separate folders * added env * added contact email * widget folders * dynamic colors -> dynamic color * fixed `SettingsSection` clipBehavior * version bump * typo * updated flutter to 3.7 * added style guide * typo * Update style_guide.md * Update README.md * Update README.md * Update README.md
82 lines
3.3 KiB
Dart
82 lines
3.3 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter/services.dart';
|
|
import 'package:flutter_localizations/flutter_localizations.dart';
|
|
import 'package:lightmeter/data/haptics_service.dart';
|
|
import 'package:lightmeter/data/models/ev_source_type.dart';
|
|
import 'package:provider/provider.dart';
|
|
import 'package:shared_preferences/shared_preferences.dart';
|
|
|
|
import 'data/permissions_service.dart';
|
|
import 'data/shared_prefs_service.dart';
|
|
import 'environment.dart';
|
|
import 'generated/l10n.dart';
|
|
import 'res/theme.dart';
|
|
import 'screens/metering/flow_metering.dart';
|
|
import 'screens/settings/screen_settings.dart';
|
|
import 'utils/stop_type_provider.dart';
|
|
|
|
final RouteObserver<PageRoute> routeObserver = RouteObserver<PageRoute>();
|
|
|
|
class Application extends StatelessWidget {
|
|
final Environment env;
|
|
|
|
const Application(this.env, {super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return FutureBuilder<SharedPreferences>(
|
|
future: SharedPreferences.getInstance(),
|
|
builder: (_, snapshot) {
|
|
if (snapshot.data != null) {
|
|
return MultiProvider(
|
|
providers: [
|
|
Provider.value(value: env),
|
|
Provider.value(value: EvSourceType.camera),
|
|
Provider(create: (_) => UserPreferencesService(snapshot.data!)),
|
|
Provider(create: (_) => const HapticsService()),
|
|
Provider(create: (_) => PermissionsService()),
|
|
],
|
|
child: StopTypeProvider(
|
|
child: ThemeProvider(
|
|
builder: (context, _) {
|
|
final systemIconsBrightness =
|
|
ThemeData.estimateBrightnessForColor(context.watch<ThemeData>().colorScheme.onSurface);
|
|
return AnnotatedRegion(
|
|
value: SystemUiOverlayStyle(
|
|
statusBarColor: Colors.transparent,
|
|
statusBarBrightness:
|
|
systemIconsBrightness == Brightness.light ? Brightness.dark : Brightness.light,
|
|
statusBarIconBrightness: systemIconsBrightness,
|
|
systemNavigationBarColor: context.watch<ThemeData>().colorScheme.surface,
|
|
systemNavigationBarIconBrightness: systemIconsBrightness,
|
|
),
|
|
child: MaterialApp(
|
|
theme: context.watch<ThemeData>(),
|
|
localizationsDelegates: const [
|
|
S.delegate,
|
|
GlobalMaterialLocalizations.delegate,
|
|
GlobalWidgetsLocalizations.delegate,
|
|
GlobalCupertinoLocalizations.delegate,
|
|
],
|
|
supportedLocales: S.delegate.supportedLocales,
|
|
builder: (context, child) => MediaQuery(
|
|
data: MediaQuery.of(context).copyWith(textScaleFactor: 1.0),
|
|
child: child!,
|
|
),
|
|
initialRoute: "metering",
|
|
routes: {
|
|
"metering": (context) => const MeteringFlow(),
|
|
"settings": (context) => const SettingsScreen(),
|
|
},
|
|
),
|
|
);
|
|
},
|
|
),
|
|
),
|
|
);
|
|
}
|
|
return const SizedBox();
|
|
},
|
|
);
|
|
}
|
|
}
|