This commit is contained in:
2026-02-27 21:12:56 +08:00
commit a878084cbb
233 changed files with 22988 additions and 0 deletions

61
lib/app/app.dart Normal file
View File

@@ -0,0 +1,61 @@
import 'package:flutter/material.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import '../backend/event.dart';
import 'features/peers/controller/peers_controller.dart';
import 'features/transfer/controller/transfers_controller.dart';
import 'navigation/home_shell.dart';
import 'sync/backend_event_sync.dart';
import 'theme/app_theme.dart';
import 'theme/theme_mode_controller.dart';
class MeshDropApp extends ConsumerWidget {
const MeshDropApp({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
final themeMode = ref.watch(themeModeControllerProvider);
ref.listen<AsyncValue<AppEvent>>(backendEventSyncProvider, (
previous,
next,
) {
next.whenData((event) {
switch (event) {
case AppEvent_PeerConnectOrUpdated(:final peer):
ref.read(peersControllerProvider.notifier).upsertPeer(peer);
case AppEvent_PeerDisconnected(:final id):
ref.read(peersControllerProvider.notifier).removePeer(id);
case AppEvent_TransferAdded(:final transfer):
ref
.read(transfersControllerProvider.notifier)
.upsertTransfer(transfer);
case AppEvent_TransferStatusChanged(:final transfer):
ref
.read(transfersControllerProvider.notifier)
.upsertTransfer(transfer);
case AppEvent_TransferRemoved(:final id):
ref.read(transfersControllerProvider.notifier).removeTransfer(id);
case AppEvent_TransferClear():
ref
.read(transfersControllerProvider.notifier)
.clearTransfersLocal();
case AppEvent_TransferProgressChanged(:final id, :final progress):
final currentBytes = progress < 0 ? 0.0 : progress;
ref
.read(transfersControllerProvider.notifier)
.updateProgress(id, currentBytes);
}
});
});
return MaterialApp(
title: 'Mesh Drop',
debugShowCheckedModeBanner: false,
themeMode: themeMode,
theme: AppTheme.lightTheme,
darkTheme: AppTheme.darkTheme,
home: const HomeShell(),
);
}
}