Fix - Resolved an issue where the window could get stuck in a minimized state when minimized using the taskbar icon https://github.com/Crunchy-DL/Crunchy-Downloader/issues/102
This commit is contained in:
parent
47fae7e933
commit
33dba5322e
|
@ -45,7 +45,7 @@ public class Widevine{
|
||||||
var fileInfo = new FileInfo(file);
|
var fileInfo = new FileInfo(file);
|
||||||
if (fileInfo.Length < 1024 * 8 && !fileInfo.Attributes.HasFlag(FileAttributes.Directory)){
|
if (fileInfo.Length < 1024 * 8 && !fileInfo.Attributes.HasFlag(FileAttributes.Directory)){
|
||||||
string fileContents = File.ReadAllText(file, Encoding.UTF8);
|
string fileContents = File.ReadAllText(file, Encoding.UTF8);
|
||||||
if (fileContents.Contains("-BEGIN RSA PRIVATE KEY-")){
|
if (fileContents.Contains("-BEGIN RSA PRIVATE KEY-") || fileContents.Contains("-BEGIN PRIVATE KEY-")){
|
||||||
privateKey = File.ReadAllBytes(file);
|
privateKey = File.ReadAllBytes(file);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -1,11 +1,10 @@
|
||||||
using System;
|
using System;
|
||||||
using System.Collections.Generic;
|
using System.Collections.Generic;
|
||||||
using System.IO;
|
using System.IO;
|
||||||
|
using System.Linq;
|
||||||
using Avalonia;
|
using Avalonia;
|
||||||
using Avalonia.Controls;
|
using Avalonia.Controls;
|
||||||
using Avalonia.Interactivity;
|
|
||||||
using Avalonia.Markup.Xaml;
|
using Avalonia.Markup.Xaml;
|
||||||
using Avalonia.Media;
|
|
||||||
using Avalonia.Platform;
|
using Avalonia.Platform;
|
||||||
using CRD.Downloader.Crunchyroll;
|
using CRD.Downloader.Crunchyroll;
|
||||||
using CRD.Utils;
|
using CRD.Utils;
|
||||||
|
@ -13,7 +12,6 @@ using CRD.Utils.Files;
|
||||||
using CRD.Utils.Structs;
|
using CRD.Utils.Structs;
|
||||||
using CRD.Utils.Updater;
|
using CRD.Utils.Updater;
|
||||||
using CRD.ViewModels;
|
using CRD.ViewModels;
|
||||||
using CRD.Views;
|
|
||||||
using CRD.Views.Utils;
|
using CRD.Views.Utils;
|
||||||
using FluentAvalonia.Core;
|
using FluentAvalonia.Core;
|
||||||
using FluentAvalonia.UI.Controls;
|
using FluentAvalonia.UI.Controls;
|
||||||
|
@ -77,7 +75,7 @@ public partial class MainWindow : AppWindow{
|
||||||
|
|
||||||
//select first element as default
|
//select first element as default
|
||||||
var nv = this.FindControl<NavigationView>("NavView");
|
var nv = this.FindControl<NavigationView>("NavView");
|
||||||
nv.SelectedItem = nv.MenuItems.ElementAt(0);
|
nv.SelectedItem = IEnumerableExtensions.ElementAt(nv.MenuItems, 0);
|
||||||
selectedNavVieItem = nv.SelectedItem;
|
selectedNavVieItem = nv.SelectedItem;
|
||||||
|
|
||||||
MessageBus.Current.Listen<NavigationMessage>()
|
MessageBus.Current.Listen<NavigationMessage>()
|
||||||
|
@ -246,9 +244,8 @@ public partial class MainWindow : AppWindow{
|
||||||
}
|
}
|
||||||
|
|
||||||
private void OnWindowStateChanged(object sender, AvaloniaPropertyChangedEventArgs e){
|
private void OnWindowStateChanged(object sender, AvaloniaPropertyChangedEventArgs e){
|
||||||
if (e.Property == Window.WindowStateProperty){
|
if (e.Property == WindowStateProperty){
|
||||||
if (WindowState == WindowState.Normal){
|
if (WindowState == WindowState.Normal){
|
||||||
// When the window is restored to normal, use the stored restore size and position
|
|
||||||
Width = _restoreSize.Width;
|
Width = _restoreSize.Width;
|
||||||
Height = _restoreSize.Height;
|
Height = _restoreSize.Height;
|
||||||
Position = _restorePosition;
|
Position = _restorePosition;
|
||||||
|
@ -258,9 +255,19 @@ public partial class MainWindow : AppWindow{
|
||||||
|
|
||||||
private void OnPositionChanged(object sender, PixelPointEventArgs e){
|
private void OnPositionChanged(object sender, PixelPointEventArgs e){
|
||||||
if (WindowState == WindowState.Normal){
|
if (WindowState == WindowState.Normal){
|
||||||
|
var screens = Screens.All;
|
||||||
|
|
||||||
|
bool isWithinAnyScreen = screens.Any(screen =>
|
||||||
|
e.Point.X >= screen.WorkingArea.X &&
|
||||||
|
e.Point.X <= screen.WorkingArea.X + screen.WorkingArea.Width &&
|
||||||
|
e.Point.Y >= screen.WorkingArea.Y &&
|
||||||
|
e.Point.Y <= screen.WorkingArea.Y + screen.WorkingArea.Height);
|
||||||
|
|
||||||
|
if (isWithinAnyScreen){
|
||||||
_restorePosition = e.Point;
|
_restorePosition = e.Point;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private void OnSizeChanged(object sender, SizeChangedEventArgs e){
|
private void OnSizeChanged(object sender, SizeChangedEventArgs e){
|
||||||
if (WindowState == WindowState.Normal){
|
if (WindowState == WindowState.Normal){
|
||||||
|
|
Loading…
Reference in New Issue