mirror of
https://github.com/Ujwal223/FocusGram.git
synced 2026-05-18 21:58:02 +02:00
105 lines
2.8 KiB
Dart
105 lines
2.8 KiB
Dart
import 'package:flutter/material.dart';
|
|
import 'package:flutter/services.dart';
|
|
import 'package:provider/provider.dart';
|
|
import 'services/session_manager.dart';
|
|
import 'services/settings_service.dart';
|
|
import 'screens/main_webview_page.dart';
|
|
import 'screens/breath_gate_screen.dart';
|
|
import 'screens/app_session_picker.dart';
|
|
import 'screens/cooldown_gate_screen.dart';
|
|
|
|
void main() async {
|
|
WidgetsFlutterBinding.ensureInitialized();
|
|
|
|
// Lock to portrait
|
|
await SystemChrome.setPreferredOrientations([
|
|
DeviceOrientation.portraitUp,
|
|
DeviceOrientation.portraitDown,
|
|
]);
|
|
|
|
final sessionManager = SessionManager();
|
|
final settingsService = SettingsService();
|
|
|
|
await sessionManager.init();
|
|
await settingsService.init();
|
|
|
|
runApp(
|
|
MultiProvider(
|
|
providers: [
|
|
ChangeNotifierProvider.value(value: sessionManager),
|
|
ChangeNotifierProvider.value(value: settingsService),
|
|
],
|
|
child: const FocusGramApp(),
|
|
),
|
|
);
|
|
}
|
|
|
|
class FocusGramApp extends StatelessWidget {
|
|
const FocusGramApp({super.key});
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
return MaterialApp(
|
|
title: 'FocusGram',
|
|
debugShowCheckedModeBanner: false,
|
|
theme: ThemeData(
|
|
brightness: Brightness.dark,
|
|
colorScheme: ColorScheme.dark(
|
|
primary: Colors.blue.shade400,
|
|
surface: Colors.black,
|
|
),
|
|
scaffoldBackgroundColor: Colors.black,
|
|
useMaterial3: true,
|
|
splashColor: Colors.transparent,
|
|
highlightColor: Colors.transparent,
|
|
),
|
|
home: const InitialRouteHandler(),
|
|
);
|
|
}
|
|
}
|
|
|
|
/// Flow on every cold open:
|
|
/// 1. Cooldown Gate (if app-open cooldown active)
|
|
/// 2. Breath Gate (if enabled in settings)
|
|
/// 3. App Session Picker (always)
|
|
/// 4. Main WebView
|
|
class InitialRouteHandler extends StatefulWidget {
|
|
const InitialRouteHandler({super.key});
|
|
|
|
@override
|
|
State<InitialRouteHandler> createState() => _InitialRouteHandlerState();
|
|
}
|
|
|
|
class _InitialRouteHandlerState extends State<InitialRouteHandler> {
|
|
bool _breathCompleted = false;
|
|
bool _appSessionStarted = false;
|
|
|
|
@override
|
|
Widget build(BuildContext context) {
|
|
final sm = context.watch<SessionManager>();
|
|
final settings = context.watch<SettingsService>();
|
|
|
|
// Step 1: Cooldown gate — if too soon since last session
|
|
if (sm.isAppOpenCooldownActive) {
|
|
return const CooldownGateScreen();
|
|
}
|
|
|
|
// Step 2: Breath gate
|
|
if (settings.showBreathGate && !_breathCompleted) {
|
|
return BreathGateScreen(
|
|
onFinish: () => setState(() => _breathCompleted = true),
|
|
);
|
|
}
|
|
|
|
// Step 3: App session picker
|
|
if (!_appSessionStarted) {
|
|
return AppSessionPickerScreen(
|
|
onSessionStarted: () => setState(() => _appSessionStarted = true),
|
|
);
|
|
}
|
|
|
|
// Step 4: Main app
|
|
return const MainWebViewPage();
|
|
}
|
|
}
|