mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
115 lines
3.1 KiB
Dart
115 lines
3.1 KiB
Dart
import 'dart:async';
|
|
import 'dart:ui';
|
|
|
|
import 'package:flutter/foundation.dart';
|
|
import 'package:flutter/material.dart';
|
|
|
|
import 'package:appflowy/core/helpers/helpers.dart';
|
|
import 'package:appflowy/startup/startup.dart';
|
|
import 'package:appflowy/startup/tasks/app_window_size_manager.dart';
|
|
import 'package:appflowy_editor/appflowy_editor.dart';
|
|
import 'package:bitsdojo_window/bitsdojo_window.dart';
|
|
import 'package:scaled_app/scaled_app.dart';
|
|
import 'package:window_manager/window_manager.dart';
|
|
|
|
class InitAppWindowTask extends LaunchTask with WindowListener {
|
|
InitAppWindowTask({this.title = 'AppFlowy'});
|
|
|
|
final String title;
|
|
final windowSizeManager = WindowSizeManager();
|
|
|
|
@override
|
|
Future<void> initialize(LaunchContext context) async {
|
|
// Don't initialize on mobile or web.
|
|
if (!defaultTargetPlatform.isDesktop || context.env.isIntegrationTest) {
|
|
return;
|
|
}
|
|
|
|
await windowManager.ensureInitialized();
|
|
windowManager.addListener(this);
|
|
|
|
final windowSize = await windowSizeManager.getSize();
|
|
final windowOptions = WindowOptions(
|
|
size: windowSize,
|
|
minimumSize: const Size(
|
|
WindowSizeManager.minWindowWidth,
|
|
WindowSizeManager.minWindowHeight,
|
|
),
|
|
maximumSize: const Size(
|
|
WindowSizeManager.maxWindowWidth,
|
|
WindowSizeManager.maxWindowHeight,
|
|
),
|
|
title: title,
|
|
);
|
|
|
|
final position = await windowSizeManager.getPosition();
|
|
|
|
if (PlatformExtension.isWindows) {
|
|
doWhenWindowReady(() async {
|
|
appWindow.minSize = windowOptions.minimumSize;
|
|
appWindow.maxSize = windowOptions.maximumSize;
|
|
appWindow.size = windowSize;
|
|
|
|
if (position != null) {
|
|
appWindow.position = position;
|
|
}
|
|
|
|
appWindow.show();
|
|
|
|
/// on Windows we maximize the window if it was previously closed
|
|
/// from a maximized state.
|
|
final isMaximized = await windowSizeManager.getWindowMaximized();
|
|
if (isMaximized) {
|
|
appWindow.maximize();
|
|
}
|
|
});
|
|
} else {
|
|
await windowManager.waitUntilReadyToShow(windowOptions, () async {
|
|
await windowManager.show();
|
|
await windowManager.focus();
|
|
|
|
if (position != null) {
|
|
await windowManager.setPosition(position);
|
|
}
|
|
});
|
|
}
|
|
|
|
unawaited(
|
|
windowSizeManager.getScaleFactor().then(
|
|
(v) => ScaledWidgetsFlutterBinding.instance.scaleFactor = (_) => v,
|
|
),
|
|
);
|
|
}
|
|
|
|
@override
|
|
Future<void> onWindowMaximize() async {
|
|
super.onWindowMaximize();
|
|
await windowSizeManager.setWindowMaximized(true);
|
|
}
|
|
|
|
@override
|
|
Future<void> onWindowUnmaximize() async {
|
|
super.onWindowUnmaximize();
|
|
await windowSizeManager.setWindowMaximized(false);
|
|
}
|
|
|
|
@override
|
|
Future<void> onWindowResize() async {
|
|
super.onWindowResize();
|
|
|
|
final currentWindowSize = await windowManager.getSize();
|
|
return windowSizeManager.setSize(currentWindowSize);
|
|
}
|
|
|
|
@override
|
|
void onWindowMoved() async {
|
|
super.onWindowMoved();
|
|
|
|
final position = await windowManager.getPosition();
|
|
return windowSizeManager.setPosition(position);
|
|
}
|
|
|
|
@override
|
|
Future<void> dispose() async {}
|
|
}
|