Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
92 changes: 45 additions & 47 deletions lib/main.dart
Original file line number Diff line number Diff line change
Expand Up @@ -18,18 +18,18 @@ void main() async {
} catch (e) {
debugPrint('Error initializing services: $e');
}

final themeController = await ThemeController.create();

runApp(
WidgetsBindingObserverWidget(
child: ChangeNotifierProvider<ThemeController>.value(
value: themeController,
child: const MyApp(),
runApp(
WidgetsBindingObserverWidget(
child: ChangeNotifierProvider<ThemeController>.value(
value: themeController,
child: const MyApp(),
),
),
),
);

);
}

class MyApp extends StatelessWidget {
const MyApp({super.key});
Expand All @@ -53,19 +53,19 @@ class MyApp extends StatelessWidget {
settings: settings,
);
} else if (settings.name == '/home') {
final args = (settings.arguments is Map<String, dynamic>)
? settings.arguments as Map<String, dynamic>
final args = (settings.arguments is Map<String, dynamic>)
? settings.arguments as Map<String, dynamic>
: null;

return MaterialPageRoute(
builder: (context) => HomeScreen(arguments: args),
settings: settings,
);
} else if (settings.name == '/chat') {
final args = (settings.arguments is Map<String, dynamic>)
? settings.arguments as Map<String, dynamic>
final args = (settings.arguments is Map<String, dynamic>)
? settings.arguments as Map<String, dynamic>
: null;

return MaterialPageRoute(
builder: (context) => ChatScreen(arguments: args),
settings: settings,
Expand All @@ -78,46 +78,44 @@ class MyApp extends StatelessWidget {
}

class WidgetsBindingObserverWidget extends StatefulWidget {
final Widget child;
final Widget child;

const WidgetsBindingObserverWidget({
super.key,
required this.child,
});
const WidgetsBindingObserverWidget({
super.key,
required this.child,
});

@override
State<WidgetsBindingObserverWidget> createState() =>
_WidgetsBindingObserverWidgetState();
}

class _WidgetsBindingObserverWidgetState
extends State<WidgetsBindingObserverWidget>
with WidgetsBindingObserver {
@override
State<WidgetsBindingObserverWidget> createState() =>
_WidgetsBindingObserverWidgetState();
}

@override
void initState() {
super.initState();
WidgetsBinding.instance.addObserver(this);
}
class _WidgetsBindingObserverWidgetState
extends State<WidgetsBindingObserverWidget> with WidgetsBindingObserver {
@override
void initState() {
super.initState();
WidgetsBinding.instance.addObserver(this);
}

@override
void didChangeAppLifecycleState(AppLifecycleState state) {
if (state == AppLifecycleState.detached) {
SupabaseService().dispose(); // ✅ ONLY IMPORTANT LINE
}
@override
void didChangeAppLifecycleState(AppLifecycleState state) {
if (state == AppLifecycleState.detached) {
SupabaseService().dispose(); // ✅ ONLY IMPORTANT LINE
}
}

@override
void dispose() {
WidgetsBinding.instance.removeObserver(this);
super.dispose();
}
@override
void dispose() {
WidgetsBinding.instance.removeObserver(this);
super.dispose();
}

@override
Widget build(BuildContext context) {
return widget.child;
}
@override
Widget build(BuildContext context) {
return widget.child;
}
}

// Simple singleton RouteObserver to allow screens to refresh on focus
class AppRouteObserver extends RouteObserver<ModalRoute<void>> {
Expand Down
4 changes: 4 additions & 0 deletions linux/flutter/generated_plugin_registrant.cc
Original file line number Diff line number Diff line change
Expand Up @@ -7,12 +7,16 @@
#include "generated_plugin_registrant.h"

#include <gtk/gtk_plugin.h>
#include <printing/printing_plugin.h>
#include <url_launcher_linux/url_launcher_plugin.h>

void fl_register_plugins(FlPluginRegistry* registry) {
g_autoptr(FlPluginRegistrar) gtk_registrar =
fl_plugin_registry_get_registrar_for_plugin(registry, "GtkPlugin");
gtk_plugin_register_with_registrar(gtk_registrar);
g_autoptr(FlPluginRegistrar) printing_registrar =
fl_plugin_registry_get_registrar_for_plugin(registry, "PrintingPlugin");
printing_plugin_register_with_registrar(printing_registrar);
g_autoptr(FlPluginRegistrar) url_launcher_linux_registrar =
fl_plugin_registry_get_registrar_for_plugin(registry, "UrlLauncherPlugin");
url_launcher_plugin_register_with_registrar(url_launcher_linux_registrar);
Expand Down
1 change: 1 addition & 0 deletions linux/flutter/generated_plugins.cmake
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@

list(APPEND FLUTTER_PLUGIN_LIST
gtk
printing
url_launcher_linux
)

Expand Down
6 changes: 6 additions & 0 deletions macos/Flutter/GeneratedPluginRegistrant.swift
Original file line number Diff line number Diff line change
Expand Up @@ -6,13 +6,19 @@ import FlutterMacOS
import Foundation

import app_links
import google_sign_in_ios
import path_provider_foundation
import printing
import shared_preferences_foundation
import speech_to_text
import url_launcher_macos

func RegisterGeneratedPlugins(registry: FlutterPluginRegistry) {
AppLinksMacosPlugin.register(with: registry.registrar(forPlugin: "AppLinksMacosPlugin"))
FLTGoogleSignInPlugin.register(with: registry.registrar(forPlugin: "FLTGoogleSignInPlugin"))
PathProviderPlugin.register(with: registry.registrar(forPlugin: "PathProviderPlugin"))
PrintingPlugin.register(with: registry.registrar(forPlugin: "PrintingPlugin"))
SharedPreferencesPlugin.register(with: registry.registrar(forPlugin: "SharedPreferencesPlugin"))
SpeechToTextPlugin.register(with: registry.registrar(forPlugin: "SpeechToTextPlugin"))
UrlLauncherPlugin.register(with: registry.registrar(forPlugin: "UrlLauncherPlugin"))
}
Loading