From eac34cf01d989874b4e2a1c841b0eb97d1629999 Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Tue, 16 Jan 2024 12:24:40 +0900 Subject: [PATCH 1/3] Fixed an issue where the window icon was not shown --- .../Utils/Storage/Helpers/FilePropertiesHelpers.cs | 10 +++++++++- 1 file changed, 9 insertions(+), 1 deletion(-) diff --git a/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs index a7b40207ba74..ed8243b49cc3 100644 --- a/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs @@ -8,6 +8,7 @@ using Microsoft.UI.Xaml.Media.Animation; using Microsoft.Windows.ApplicationModel.Resources; using System.Collections.Concurrent; +using Windows.ApplicationModel; using Windows.Graphics; namespace Files.App.Utils.Storage @@ -120,7 +121,14 @@ public static void OpenPropertiesWindow(object item, IShellPage associatedInstan appWindow.TitleBar.ButtonBackgroundColor = Colors.Transparent; appWindow.TitleBar.ButtonInactiveBackgroundColor = Colors.Transparent; - appWindow.SetIcon(applicationService.AppIcoPath); + string appIcoPath = ApplicationService.AppEnvironment switch + { + AppEnvironment.Dev => Constants.AssetPaths.DevLogo, + AppEnvironment.Preview => Constants.AssetPaths.PreviewLogo, + _ => Constants.AssetPaths.StableLogo + }; + + appWindow.SetIcon(SystemIO.Path.Combine(Package.Current.InstalledLocation.Path, appIcoPath)); frame.Navigate( typeof(Views.Properties.MainPropertiesPage), From b7f6013f87813cc57cd697debb44b16ce939027e Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Mon, 22 Jan 2024 23:48:22 +0900 Subject: [PATCH 2/3] Deleted ApplicationService class --- src/Files.App/App.xaml.cs | 4 +- .../Helpers/Application/AppLifecycleHelper.cs | 37 +++++++++++++++++- src/Files.App/MainWindow.xaml.cs | 8 +--- src/Files.App/Program.cs | 2 +- src/Files.App/Services/ApplicationService.cs | 38 ------------------- src/Files.App/Utils/Git/GitHelpers.cs | 4 +- .../Storage/Helpers/FilePropertiesHelpers.cs | 11 +----- src/Files.App/Utils/Taskbar/SystemTrayIcon.cs | 9 +---- .../ViewModels/Settings/AdvancedViewModel.cs | 4 +- src/Files.App/Views/MainPage.xaml.cs | 4 +- src/Files.App/Views/SplashScreenPage.xaml.cs | 2 +- .../Services/IApplicationService.cs | 24 ------------ 12 files changed, 45 insertions(+), 102 deletions(-) delete mode 100644 src/Files.App/Services/ApplicationService.cs delete mode 100644 src/Files.Core/Services/IApplicationService.cs diff --git a/src/Files.App/App.xaml.cs b/src/Files.App/App.xaml.cs index 0ca6dcc706c1..d16bc39a077d 100644 --- a/src/Files.App/App.xaml.cs +++ b/src/Files.App/App.xaml.cs @@ -141,7 +141,7 @@ async Task ActivateAsync() SystemTrayIcon = new SystemTrayIcon().Show(); // Sleep current instance - Program.Pool = new(0, 1, $"Files-{ApplicationService.AppEnvironment}-Instance"); + Program.Pool = new(0, 1, $"Files-{AppLifecycleHelper.AppEnvironment}-Instance"); Thread.Yield(); @@ -229,7 +229,7 @@ private async void Window_Closed(object sender, WindowEventArgs args) await FilePropertiesHelpers.WaitClosingAll(); // Sleep current instance - Program.Pool = new(0, 1, $"Files-{ApplicationService.AppEnvironment}-Instance"); + Program.Pool = new(0, 1, $"Files-{AppLifecycleHelper.AppEnvironment}-Instance"); Thread.Yield(); diff --git a/src/Files.App/Helpers/Application/AppLifecycleHelper.cs b/src/Files.App/Helpers/Application/AppLifecycleHelper.cs index 3ca342a3d309..1277dbbfc29f 100644 --- a/src/Files.App/Helpers/Application/AppLifecycleHelper.cs +++ b/src/Files.App/Helpers/Application/AppLifecycleHelper.cs @@ -14,6 +14,7 @@ using Microsoft.Extensions.Logging; using System.IO; using System.Text; +using Windows.ApplicationModel; using Windows.Storage; using Windows.System; using Windows.UI.Notifications; @@ -26,6 +27,39 @@ namespace Files.App.Helpers /// public static class AppLifecycleHelper { + /// + /// Gets the value that provides application environment or branch name. + /// + public static AppEnvironment AppEnvironment { get; } = +#if STORE + AppEnvironment.Store; +#elif PREVIEW + AppEnvironment.Preview; +#elif STABLE + AppEnvironment.Stable; +#else + AppEnvironment.Dev; +#endif + + /// + /// Gets application package version. + /// + public static Version AppVersion { get; } = new( + Package.Current.Id.Version.Major, + Package.Current.Id.Version.Minor, + Package.Current.Id.Version.Build, + Package.Current.Id.Version.Revision); + + /// + /// Gets application icon relative path. + /// + public static string AppIconPath { get; } = AppEnvironment switch + { + AppEnvironment.Dev => Constants.AssetPaths.DevLogo, + AppEnvironment.Preview => Constants.AssetPaths.PreviewLogo, + _ => Constants.AssetPaths.StableLogo + }; + /// /// Initializes the app components. /// @@ -103,7 +137,7 @@ public static void ConfigureAppCenter() public static IHost ConfigureHost() { return Host.CreateDefaultBuilder() - .UseEnvironment(ApplicationService.AppEnvironment.ToString()) + .UseEnvironment(AppLifecycleHelper.AppEnvironment.ToString()) .ConfigureLogging(builder => builder .AddProvider(new FileLoggerProvider(Path.Combine(ApplicationData.Current.LocalFolder.Path, "debug.log"))) .SetMinimumLevel(LogLevel.Information)) @@ -135,7 +169,6 @@ public static IHost ConfigureHost() .AddSingleton() .AddSingleton() .AddSingleton() - .AddSingleton() .AddSingleton() .AddSingleton() .AddSingleton() diff --git a/src/Files.App/MainWindow.xaml.cs b/src/Files.App/MainWindow.xaml.cs index 0057f682894d..6a7af2881d2b 100644 --- a/src/Files.App/MainWindow.xaml.cs +++ b/src/Files.App/MainWindow.xaml.cs @@ -19,10 +19,6 @@ namespace Files.App { public sealed partial class MainWindow : WindowEx { - private readonly IApplicationService ApplicationService; - - private MainPageViewModel mainPageViewModel; - private static MainWindow? _Instance; public static MainWindow Instance => _Instance ??= new(); @@ -30,8 +26,6 @@ public sealed partial class MainWindow : WindowEx private MainWindow() { - ApplicationService = new ApplicationService(); - WindowHandle = this.GetWindowHandle(); InitializeComponent(); @@ -49,7 +43,7 @@ private void EnsureEarlyWindow() MinWidth = 516; AppWindow.Title = "Files"; - AppWindow.SetIcon(Path.Combine(Package.Current.InstalledLocation.Path, ApplicationService.AppIcoPath)); + AppWindow.SetIcon(Path.Combine(Package.Current.InstalledLocation.Path, AppLifecycleHelper.AppIconPath)); AppWindow.TitleBar.ExtendsContentIntoTitleBar = true; AppWindow.TitleBar.ButtonBackgroundColor = Colors.Transparent; AppWindow.TitleBar.ButtonInactiveBackgroundColor = Colors.Transparent; diff --git a/src/Files.App/Program.cs b/src/Files.App/Program.cs index cc56c6a8f3be..5b1c739948cf 100644 --- a/src/Files.App/Program.cs +++ b/src/Files.App/Program.cs @@ -27,7 +27,7 @@ internal sealed class Program static Program() { - var pool = new Semaphore(0, 1, $"Files-{ApplicationService.AppEnvironment}-Instance", out var isNew); + var pool = new Semaphore(0, 1, $"Files-{AppLifecycleHelper.AppEnvironment}-Instance", out var isNew); if (!isNew) { diff --git a/src/Files.App/Services/ApplicationService.cs b/src/Files.App/Services/ApplicationService.cs deleted file mode 100644 index b9148741640e..000000000000 --- a/src/Files.App/Services/ApplicationService.cs +++ /dev/null @@ -1,38 +0,0 @@ -using Windows.ApplicationModel; - -namespace Files.App.Services -{ - /// - internal sealed class ApplicationService : IApplicationService - { - // Workaround to help improve code clarity - internal static readonly AppEnvironment AppEnvironment = -#if STORE - AppEnvironment.Store; -#elif PREVIEW - AppEnvironment.Preview; -#elif STABLE - AppEnvironment.Stable; -#else - AppEnvironment.Dev; -#endif - - /// - public AppEnvironment Environment { get; } = AppEnvironment; - - /// - public Version AppVersion { get; } = new( - Package.Current.Id.Version.Major, - Package.Current.Id.Version.Minor, - Package.Current.Id.Version.Build, - Package.Current.Id.Version.Revision); - - /// - public string AppIcoPath { get; } = AppEnvironment switch - { - AppEnvironment.Dev => Constants.AssetPaths.DevLogo, - AppEnvironment.Preview => Constants.AssetPaths.PreviewLogo, - _ => Constants.AssetPaths.StableLogo - }; - } -} diff --git a/src/Files.App/Utils/Git/GitHelpers.cs b/src/Files.App/Utils/Git/GitHelpers.cs index aed15ef08641..ec05f54e6ad7 100644 --- a/src/Files.App/Utils/Git/GitHelpers.cs +++ b/src/Files.App/Utils/Git/GitHelpers.cs @@ -31,8 +31,6 @@ internal static class GitHelpers private static readonly IDialogService _dialogService = Ioc.Default.GetRequiredService(); - private static readonly IApplicationService _applicationService = Ioc.Default.GetRequiredService(); - private static readonly FetchOptions _fetchOptions = new() { Prune = true @@ -40,7 +38,7 @@ internal static class GitHelpers private static readonly PullOptions _pullOptions = new(); - private static readonly string _clientId = _applicationService.Environment is AppEnvironment.Store or AppEnvironment.Stable or AppEnvironment.Preview + private static readonly string _clientId = AppLifecycleHelper.AppEnvironment is AppEnvironment.Store or AppEnvironment.Stable or AppEnvironment.Preview ? CLIENT_ID_SECRET : string.Empty; diff --git a/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs index ed8243b49cc3..1e09a2d56131 100644 --- a/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs @@ -89,8 +89,6 @@ public static void OpenPropertiesWindow(IShellPage associatedInstance) /// Associated main window instance public static void OpenPropertiesWindow(object item, IShellPage associatedInstance) { - var applicationService = Ioc.Default.GetRequiredService(); - if (item is null) return; @@ -121,14 +119,7 @@ public static void OpenPropertiesWindow(object item, IShellPage associatedInstan appWindow.TitleBar.ButtonBackgroundColor = Colors.Transparent; appWindow.TitleBar.ButtonInactiveBackgroundColor = Colors.Transparent; - string appIcoPath = ApplicationService.AppEnvironment switch - { - AppEnvironment.Dev => Constants.AssetPaths.DevLogo, - AppEnvironment.Preview => Constants.AssetPaths.PreviewLogo, - _ => Constants.AssetPaths.StableLogo - }; - - appWindow.SetIcon(SystemIO.Path.Combine(Package.Current.InstalledLocation.Path, appIcoPath)); + appWindow.SetIcon(SystemIO.Path.Combine(Package.Current.InstalledLocation.Path, AppLifecycleHelper.AppIconPath)); frame.Navigate( typeof(Views.Properties.MainPropertiesPage), diff --git a/src/Files.App/Utils/Taskbar/SystemTrayIcon.cs b/src/Files.App/Utils/Taskbar/SystemTrayIcon.cs index 1bf0e530fe5a..860a44ebe52b 100644 --- a/src/Files.App/Utils/Taskbar/SystemTrayIcon.cs +++ b/src/Files.App/Utils/Taskbar/SystemTrayIcon.cs @@ -131,14 +131,7 @@ private Rect Position /// public SystemTrayIcon() { - string appIcoPath = ApplicationService.AppEnvironment switch - { - AppEnvironment.Dev => Constants.AssetPaths.DevLogo, - AppEnvironment.Preview => Constants.AssetPaths.PreviewLogo, - _ => Constants.AssetPaths.StableLogo - }; - - var iconPath = SystemIO.Path.Combine(Package.Current.InstalledLocation.Path, appIcoPath); + var iconPath = SystemIO.Path.Combine(Package.Current.InstalledLocation.Path, AppLifecycleHelper.AppIconPath); _Icon = new(iconPath); _Tooltip = Package.Current.DisplayName; diff --git a/src/Files.App/ViewModels/Settings/AdvancedViewModel.cs b/src/Files.App/ViewModels/Settings/AdvancedViewModel.cs index 5f9117c5466a..e90dcb2b5a6d 100644 --- a/src/Files.App/ViewModels/Settings/AdvancedViewModel.cs +++ b/src/Files.App/ViewModels/Settings/AdvancedViewModel.cs @@ -198,11 +198,9 @@ private async Task ImportSettingsAsync() private async Task ExportSettingsAsync() { - var applicationService = Ioc.Default.GetRequiredService(); - FileSavePicker filePicker = InitializeWithWindow(new FileSavePicker()); filePicker.FileTypeChoices.Add("Zip File", new[] { ".zip" }); - filePicker.SuggestedFileName = $"Files_{applicationService.AppVersion}"; + filePicker.SuggestedFileName = $"Files_{AppLifecycleHelper.AppVersion}"; StorageFile file = await filePicker.PickSaveFileAsync(); if (file is not null) diff --git a/src/Files.App/Views/MainPage.xaml.cs b/src/Files.App/Views/MainPage.xaml.cs index 40079660cb9c..60c092673d05 100644 --- a/src/Files.App/Views/MainPage.xaml.cs +++ b/src/Files.App/Views/MainPage.xaml.cs @@ -26,7 +26,6 @@ namespace Files.App.Views public sealed partial class MainPage : Page { public IUserSettingsService UserSettingsService { get; } - public IApplicationService ApplicationService { get; } public ICommandManager Commands { get; } @@ -53,7 +52,6 @@ public MainPage() // Dependency Injection UserSettingsService = Ioc.Default.GetRequiredService(); - ApplicationService = Ioc.Default.GetRequiredService(); Commands = Ioc.Default.GetRequiredService(); WindowContext = Ioc.Default.GetRequiredService(); SidebarAdaptiveViewModel = Ioc.Default.GetRequiredService(); @@ -302,7 +300,7 @@ private void Page_Loaded(object sender, RoutedEventArgs e) // ToDo put this in a StartupPromptService if ( - ApplicationService.Environment is not AppEnvironment.Dev && + AppLifecycleHelper.AppEnvironment is not AppEnvironment.Dev && isAppRunningAsAdmin && UserSettingsService.ApplicationSettingsService.ShowRunningAsAdminPrompt ) diff --git a/src/Files.App/Views/SplashScreenPage.xaml.cs b/src/Files.App/Views/SplashScreenPage.xaml.cs index da9e23d82aa0..0ca92069809b 100644 --- a/src/Files.App/Views/SplashScreenPage.xaml.cs +++ b/src/Files.App/Views/SplashScreenPage.xaml.cs @@ -12,7 +12,7 @@ namespace Files.App.Views public sealed partial class SplashScreenPage : Page { private string BranchLabel => - ApplicationService.AppEnvironment switch + AppLifecycleHelper.AppEnvironment switch { AppEnvironment.Dev => "Dev", AppEnvironment.Preview => "Preview", diff --git a/src/Files.Core/Services/IApplicationService.cs b/src/Files.Core/Services/IApplicationService.cs deleted file mode 100644 index fcc6d45421ad..000000000000 --- a/src/Files.Core/Services/IApplicationService.cs +++ /dev/null @@ -1,24 +0,0 @@ -namespace Files.Core.Services -{ - /// - /// A service that interacts with common app-related APIs. - /// - public interface IApplicationService - { - /// - /// Gets the application build environment. - /// - AppEnvironment Environment { get; } - - /// - /// Gets the version of the app. - /// - Version AppVersion { get; } - - /// - /// Gets the path at which the App Logo is located. - /// - [Obsolete("This is a bad way of accessing the logo. Use something more abstract instead, and ideally move it out of this interface.")] - string AppIcoPath { get; } - } -} From 8fd73f4bb6b0a762ab8ef89ea24ab8c8868de348 Mon Sep 17 00:00:00 2001 From: 0x5BFA <62196528+0x5bfa@users.noreply.github.com> Date: Thu, 25 Jan 2024 03:13:09 +0900 Subject: [PATCH 3/3] Make the app icon path absolute path --- .../Helpers/Application/AppLifecycleHelper.cs | 22 +++++++++---------- src/Files.App/MainWindow.xaml.cs | 2 +- .../Storage/Helpers/FilePropertiesHelpers.cs | 2 +- src/Files.App/Utils/Taskbar/SystemTrayIcon.cs | 4 +--- 4 files changed, 13 insertions(+), 17 deletions(-) diff --git a/src/Files.App/Helpers/Application/AppLifecycleHelper.cs b/src/Files.App/Helpers/Application/AppLifecycleHelper.cs index 1277dbbfc29f..811d8c59e9f6 100644 --- a/src/Files.App/Helpers/Application/AppLifecycleHelper.cs +++ b/src/Files.App/Helpers/Application/AppLifecycleHelper.cs @@ -44,21 +44,19 @@ public static class AppLifecycleHelper /// /// Gets application package version. /// - public static Version AppVersion { get; } = new( - Package.Current.Id.Version.Major, - Package.Current.Id.Version.Minor, - Package.Current.Id.Version.Build, - Package.Current.Id.Version.Revision); + public static Version AppVersion { get; } = + new(Package.Current.Id.Version.Major, Package.Current.Id.Version.Minor, Package.Current.Id.Version.Build, Package.Current.Id.Version.Revision); /// - /// Gets application icon relative path. + /// Gets application icon path. /// - public static string AppIconPath { get; } = AppEnvironment switch - { - AppEnvironment.Dev => Constants.AssetPaths.DevLogo, - AppEnvironment.Preview => Constants.AssetPaths.PreviewLogo, - _ => Constants.AssetPaths.StableLogo - }; + public static string AppIconPath { get; } = + SystemIO.Path.Combine(Package.Current.InstalledLocation.Path, AppEnvironment switch + { + AppEnvironment.Dev => Constants.AssetPaths.DevLogo, + AppEnvironment.Preview => Constants.AssetPaths.PreviewLogo, + _ => Constants.AssetPaths.StableLogo + }); /// /// Initializes the app components. diff --git a/src/Files.App/MainWindow.xaml.cs b/src/Files.App/MainWindow.xaml.cs index 6a7af2881d2b..e4f9551de00d 100644 --- a/src/Files.App/MainWindow.xaml.cs +++ b/src/Files.App/MainWindow.xaml.cs @@ -43,7 +43,7 @@ private void EnsureEarlyWindow() MinWidth = 516; AppWindow.Title = "Files"; - AppWindow.SetIcon(Path.Combine(Package.Current.InstalledLocation.Path, AppLifecycleHelper.AppIconPath)); + AppWindow.SetIcon(AppLifecycleHelper.AppIconPath); AppWindow.TitleBar.ExtendsContentIntoTitleBar = true; AppWindow.TitleBar.ButtonBackgroundColor = Colors.Transparent; AppWindow.TitleBar.ButtonInactiveBackgroundColor = Colors.Transparent; diff --git a/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs b/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs index 1e09a2d56131..a24a0f9efe06 100644 --- a/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs +++ b/src/Files.App/Utils/Storage/Helpers/FilePropertiesHelpers.cs @@ -119,7 +119,7 @@ public static void OpenPropertiesWindow(object item, IShellPage associatedInstan appWindow.TitleBar.ButtonBackgroundColor = Colors.Transparent; appWindow.TitleBar.ButtonInactiveBackgroundColor = Colors.Transparent; - appWindow.SetIcon(SystemIO.Path.Combine(Package.Current.InstalledLocation.Path, AppLifecycleHelper.AppIconPath)); + appWindow.SetIcon(AppLifecycleHelper.AppIconPath); frame.Navigate( typeof(Views.Properties.MainPropertiesPage), diff --git a/src/Files.App/Utils/Taskbar/SystemTrayIcon.cs b/src/Files.App/Utils/Taskbar/SystemTrayIcon.cs index 860a44ebe52b..af10341f2d91 100644 --- a/src/Files.App/Utils/Taskbar/SystemTrayIcon.cs +++ b/src/Files.App/Utils/Taskbar/SystemTrayIcon.cs @@ -131,9 +131,7 @@ private Rect Position /// public SystemTrayIcon() { - var iconPath = SystemIO.Path.Combine(Package.Current.InstalledLocation.Path, AppLifecycleHelper.AppIconPath); - - _Icon = new(iconPath); + _Icon = new(AppLifecycleHelper.AppIconPath); _Tooltip = Package.Current.DisplayName; _taskbarRestartMessageId = PInvoke.RegisterWindowMessage("TaskbarCreated");