Files
apidash/lib/app.dart
Ashita Prasad a3536b021b refactor
2024-10-22 07:06:06 +05:30

159 lines
4.8 KiB
Dart

// ignore_for_file: use_build_context_synchronously
import 'package:apidash_design_system/apidash_design_system.dart';
import 'package:flutter/material.dart';
import 'package:flutter_portal/flutter_portal.dart';
import 'package:flutter_riverpod/flutter_riverpod.dart';
import 'package:window_manager/window_manager.dart' hide WindowCaption;
import 'widgets/widgets.dart' show WindowCaption, WorkspaceSelector;
import 'providers/providers.dart';
import 'services/services.dart';
import 'extensions/extensions.dart';
import 'screens/screens.dart';
import 'consts.dart';
class App extends ConsumerStatefulWidget {
const App({super.key});
@override
ConsumerState<App> createState() => _AppState();
}
class _AppState extends ConsumerState<App> with WindowListener {
@override
void initState() {
super.initState();
windowManager.addListener(this);
_init();
}
@override
void dispose() {
windowManager.removeListener(this);
super.dispose();
}
void _init() async {
// Add this line to override the default close handler
await windowManager.setPreventClose(true);
setState(() {});
}
@override
void onWindowResized() {
windowManager.getSize().then((value) {
ref.read(settingsProvider.notifier).update(size: value);
});
windowManager.getPosition().then((value) {
ref.read(settingsProvider.notifier).update(offset: value);
});
}
@override
void onWindowMoved() {
windowManager.getPosition().then((value) {
ref.read(settingsProvider.notifier).update(offset: value);
});
}
@override
void onWindowClose() async {
bool isPreventClose = await windowManager.isPreventClose();
if (isPreventClose) {
if (ref.watch(
settingsProvider.select((value) => value.promptBeforeClosing)) &&
ref.watch(hasUnsavedChangesProvider)) {
showDialog(
context: context,
builder: (_) => AlertDialog(
title: const Text('Save Changes'),
content:
const Text('Want to save changes before you close API Dash?'),
actions: [
OutlinedButton(
child: const Text('No'),
onPressed: () async {
Navigator.of(context).pop();
await windowManager.destroy();
},
),
FilledButton(
child: const Text('Save'),
onPressed: () async {
await ref
.read(collectionStateNotifierProvider.notifier)
.saveData();
Navigator.of(context).pop();
await windowManager.destroy();
},
),
],
),
);
} else {
await windowManager.destroy();
}
}
}
@override
Widget build(BuildContext context) {
return context.isMediumWindow ? const MobileDashboard() : const Dashboard();
}
}
class DashApp extends ConsumerWidget {
const DashApp({super.key});
@override
Widget build(BuildContext context, WidgetRef ref) {
final isDarkMode =
ref.watch(settingsProvider.select((value) => value.isDark));
final workspaceFolderPath = ref
.watch(settingsProvider.select((value) => value.workspaceFolderPath));
final showWorkspaceSelector = kIsDesktop && (workspaceFolderPath == null);
return Portal(
child: MaterialApp(
debugShowCheckedModeBanner: false,
theme: kLightMaterialAppTheme,
darkTheme: kDarkMaterialAppTheme,
themeMode: isDarkMode ? ThemeMode.dark : ThemeMode.light,
home: showWorkspaceSelector
? WorkspaceSelector(
onContinue: (val) async {
await initHiveBoxes(kIsDesktop, val);
ref
.read(settingsProvider.notifier)
.update(workspaceFolderPath: val);
},
onCancel: () async {
try {
await windowManager.destroy();
} catch (e) {
debugPrint(e.toString());
}
},
)
: Stack(
children: [
!kIsLinux && !kIsMobile
? const App()
: context.isMediumWindow
? const MobileDashboard()
: const Dashboard(),
if (kIsWindows)
SizedBox(
height: 29,
child: WindowCaption(
backgroundColor: Colors.transparent,
brightness:
isDarkMode ? Brightness.dark : Brightness.light,
),
),
],
),
),
);
}
}