From 6dec643be2ad81c7c58a70e58b39cec018e52e26 Mon Sep 17 00:00:00 2001 From: Patrick Magee Date: Sun, 23 Jun 2024 14:41:20 +0100 Subject: [PATCH] - ClickOnce manifest stuff - User settings - Bindings cleanup --- .github/workflows/build.yaml | 36 ++-- .github/workflows/release-windows-v1.yaml | 107 ---------- .github/workflows/release-windows-v2.yaml | 30 --- .github/workflows/release.yaml | 105 +++++++--- Heroesprofile.Uploader.Common/Analyzer.cs | 27 +-- Heroesprofile.Uploader.Windows/App.xaml.cs | 120 +++++------ .../Core/AppConfig.cs | 21 -- .../Core/Settings.cs | 133 ++++++++++++ .../Core/SettingsManager.cs | 38 ++++ .../Heroesprofile.Uploader.Windows.csproj | 13 +- .../MainWindow.xaml | 43 ++-- .../MainWindow.xaml.cs | 49 +++-- .../PublishProfiles/ClickOnceProfile.pubxml | 16 +- .../Properties/Settings.Designer.cs | 194 ------------------ .../Properties/Settings.settings | 48 ----- .../UIHelpers/FlagsConverter.cs | 6 +- .../appsettings.json | 7 +- dotnet-mage-release.ps1 | 47 +++++ 18 files changed, 439 insertions(+), 601 deletions(-) delete mode 100644 .github/workflows/release-windows-v1.yaml delete mode 100644 .github/workflows/release-windows-v2.yaml delete mode 100644 Heroesprofile.Uploader.Windows/Core/AppConfig.cs create mode 100644 Heroesprofile.Uploader.Windows/Core/Settings.cs create mode 100644 Heroesprofile.Uploader.Windows/Core/SettingsManager.cs delete mode 100644 Heroesprofile.Uploader.Windows/Properties/Settings.Designer.cs delete mode 100644 Heroesprofile.Uploader.Windows/Properties/Settings.settings create mode 100644 dotnet-mage-release.ps1 diff --git a/.github/workflows/build.yaml b/.github/workflows/build.yaml index 0deb4b9..e0b55a0 100644 --- a/.github/workflows/build.yaml +++ b/.github/workflows/build.yaml @@ -1,27 +1,27 @@ -name: Build (dagger) +name: build + on: push: branches: - - '**' + - "**" workflow_dispatch: jobs: build: runs-on: ubuntu-latest steps: - - name: Checkout - uses: actions/Checkout@v4 - with: - submodules: 'true' - ref: ${{ github.ref }} - fetch-depth: 0 - - - name: Build Project with Dagger - uses: dagger/dagger-for-github@v5.6.0 - with: - version: "latest" - verb: call - args: build --git=. stdout - cloud-token: ${{ secrets.DAGGER_CLOUD_TOKEN }} - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} \ No newline at end of file + - name: Checkout + uses: actions/Checkout@v4 + with: + submodules: "true" + ref: ${{ github.ref }} + fetch-depth: 0 + - name: Build Project with Dagger + uses: dagger/dagger-for-github@v5.6.0 + with: + version: "latest" + verb: call + args: build --git=. stdout + cloud-token: ${{ secrets.DAGGER_CLOUD_TOKEN }} + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} diff --git a/.github/workflows/release-windows-v1.yaml b/.github/workflows/release-windows-v1.yaml deleted file mode 100644 index 9338cb3..0000000 --- a/.github/workflows/release-windows-v1.yaml +++ /dev/null @@ -1,107 +0,0 @@ -name: ClickOnce Release v1 - -on: - push: - tags: - - 'v[0-9]+.[0-9]+.[0-9]+' - -permissions: - contents: read - pages: write - id-token: write - -jobs: - release: - if: false # This condition disables the job. Change to `true` or remove to enable. - runs-on: windows-latest - environment: - name: github-pages - url: https://heroesreplay.github.io/HeroesProfile.Uploader/ - - steps: - - - name: Checkout code - uses: actions/checkout@v4 - with: - ref: ${{ github.ref }} - submodules: 'true' - fetch-depth: 0 - - - name: Setup .NET 8 SDK - uses: actions/setup-dotnet@v4 - with: - dotnet-version: '8.0.x' - - - name: Install dotnet-mage - run: dotnet tool install --global microsoft.dotnet.mage --version 8.0.0 - - - name: Prepare version and publish directory - id: version - run: | - $version = "${{ github.ref }}" -replace "refs/tags/v", "" - $publishDir = ".\publish\$version" - echo "APP_PUBLISH_DIR=$publishDir" >> $GITHUB_ENV - echo "APP_VERSION=$version" >> $GITHUB_ENV - - - name: Publish application - run: | - dotnet publish .\Heroesprofile.Uploader.Windows ` - --self-contained ` - --os win ` - -o $env:PUBLISH_DIR - env: - APP_PUBLISH_DIR: ${{ env.APP_PUBLISH_DIR }} - APP_VERSION: ${{ env.APP_VERSION }} - - - name: ClickOnce manifest and application - run: | - - $publishDir = $env:APP_PUBLISH_DIR - $version = $env:APP_VERSION - - dotnet mage -al Heroesprofile.Uploader.exe ` - -TargetDirectory $publishDir - - dotnet mage -new Application ` - -ToFile $publishDir\Heroesprofile.Uploader.manifest ` - -FromDirectory $publishDir ` - -Version $version ` - -IconFile .\Heroesprofile.Uploader.Windows\Resources\uploader_icon_dark.ico - - dotnet mage -new Deployment ` - -Install true ` - -Publisher "Patrick Magee" ` - -Version $version ` - -AppManifest $publishDir\Heroesprofile.Uploader.manifest ` - -ToFile Heroesprofile.Uploader.application ` - -ProviderUrl https://heroesreplay.github.io/HeroesProfile.Uploader/ - - env: - APP_PUBLISH_DIR: ${{ env.APP_PUBLISH_DIR }} - APP_VERSION: ${{ env.APP_VERSION }} - - - name: Setup Pages - uses: actions/configure-pages@v5 - with: - enablement: 'true' - token: ${{ secrets.GITHUB_TOKEN }} - - - name: Upload artifact - uses: actions/upload-pages-artifact@v3 - with: - path: ${{ env.APP_PUBLISH_DIR }} - env: - APP_PUBLISH_DIR: ${{ env.APP_PUBLISH_DIR }} - APP_VERSION: ${{ env.APP_VERSION }} - - - name: Deploy to GitHub Pages - id: deployment - uses: actions/deploy-pages@v4 - - - name: Create Release and Upload Assets - uses: softprops/action-gh-release@v1 - with: - files: ${{ env.PUBLISH_DIR }} - token: ${{ secrets.GITHUB_TOKEN }} - env: - PUBLISH_DIR: ${{ env.PUBLISH_DIR }} \ No newline at end of file diff --git a/.github/workflows/release-windows-v2.yaml b/.github/workflows/release-windows-v2.yaml deleted file mode 100644 index df43bbe..0000000 --- a/.github/workflows/release-windows-v2.yaml +++ /dev/null @@ -1,30 +0,0 @@ -name: ClickOnce Release v2 -permissions: - contents: write - packages: write - pages: write - -on: - push: - tags: [v*] - -jobs: - release: - runs-on: windows-latest - - steps: - - name: Checkout code - uses: actions/checkout@v3 - with: - submodules: 'true' - fetch-depth: 0 - - - name: Setup Git - run: | - git config --global url."https://user:${{ secrets.GITHUB_TOKEN }}@github".insteadOf https://github - git config --global user.name github-actions - git config --global user.email github-actions@github.com - - - name: Run release script - shell: pwsh - run: ./release.ps1 \ No newline at end of file diff --git a/.github/workflows/release.yaml b/.github/workflows/release.yaml index 980e50a..117398d 100644 --- a/.github/workflows/release.yaml +++ b/.github/workflows/release.yaml @@ -1,33 +1,88 @@ -name: Release (dagger) +name: release -on: - push: - tags: - - 'v[0-9]+.[0-9]+.[0-9]+' +# Workflow with Windows & Linux +# This is so we can use dotnet mage to build the manifests permissions: + pages: write contents: write - packages: write + id-token: write + deployments: write + +on: + # push: + # tags: + # - "v[0-9]+.[0-9]+.[0-9]+" + workflow_dispatch: + inputs: + tag: + description: 'Tag to release (e.g., v1.0.0)' + required: true + +concurrency: + group: "pages" + cancel-in-progress: false jobs: - release: - if: false # This condition disables the job. Change to `true` or remove to enable. - runs-on: ubuntu-latest + publish: + runs-on: windows-latest + steps: + - name: Checkout code + uses: actions/checkout@v3 + with: + submodules: "true" + fetch-depth: 0 + + - name: Setup .NET 8 SDK + uses: actions/setup-dotnet@v4 + with: + dotnet-version: "8.0.x" + - name: Run release script + run: .\dotnet-mage-release.ps1 + continue-on-error: false + + - name: Upload artifact + uses: actions/upload-pages-artifact@v3 + with: + path: .\Heroesprofile.Uploader.Windows\bin\publish + name: published + retention-days: 1 + + - name: Upload artifact + uses: actions/upload-artifact@v4 + with: + name: published + path: .\Heroesprofile.Uploader.Windows\bin\publish + if-no-files-found: error + retention-days: 2 + overwrite: true + deploy: + needs: publish + environment: + name: github-pages + url: ${{ steps.deployment.outputs.page_url }} + runs-on: ubuntu-latest steps: - - name: Checkout - uses: actions/Checkout@v4 - with: - submodules: 'true' - ref: ${{ github.ref }} - fetch-depth: 0 - - - name: Release - uses: dagger/dagger-for-github@v5.6.0 - with: - version: "latest" - verb: call - args: release --git=. --tag=${{ github.ref_name }} --token=env:GITHUB_TOKEN - cloud-token: ${{ secrets.DAGGER_CLOUD_TOKEN }} - env: - GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} \ No newline at end of file + - name: Deploy to GitHub Pages + uses: actions/deploy-pages@v4 + id: deployment + with: + artifact_name: published + token: ${{ secrets.GITHUB_TOKEN }} + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + - name: Release to GitHub + uses: ncipollo/release-action@v1 + with: + artifacts: ".application" + token: ${{ secrets.GITHUB_TOKEN }} + name: ${{ github.ref }} + tag: ${{ github.ref }} + allowUpdates: true + makeLatest: true + replacesArtifacts: true + generateReleaseNotes: true + env: + GITHUB_TOKEN: ${{ secrets.GITHUB_TOKEN }} + \ No newline at end of file diff --git a/Heroesprofile.Uploader.Common/Analyzer.cs b/Heroesprofile.Uploader.Common/Analyzer.cs index 7b35242..80db1e2 100644 --- a/Heroesprofile.Uploader.Common/Analyzer.cs +++ b/Heroesprofile.Uploader.Common/Analyzer.cs @@ -15,10 +15,6 @@ public class Analyzer : IAnalyzer private static Logger _log = LogManager.GetCurrentClassLogger(); - /// - /// Analyze replay locally before uploading - /// - /// Replay file public Replay Analyze(ReplayFile file) { try { @@ -89,29 +85,22 @@ public Replay Analyze(ReplayFile file) return null; } - /// - /// Get unique hash of replay. Compatible with HotsLogs - /// - /// - /// public string GetFingerprint(Replay replay) { var str = new StringBuilder(); replay.Players.Select(p => p.BattleNetId).OrderBy(x => x).Map(x => str.Append(x.ToString())); str.Append(replay.RandomValue); - var md5 = MD5.Create().ComputeHash(Encoding.UTF8.GetBytes(str.ToString())); + var md5 = MD5.HashData(Encoding.UTF8.GetBytes(str.ToString())); var result = new Guid(md5); return result.ToString(); } - /// - /// Swaps two bytes in a byte array - /// - private void SwapBytes(byte[] buf, int i, int j) - { - byte temp = buf[i]; - buf[i] = buf[j]; - buf[j] = temp; - } + + //private void SwapBytes(byte[] buf, int i, int j) + //{ + // byte temp = buf[i]; + // buf[i] = buf[j]; + // buf[j] = temp; + //} } } diff --git a/Heroesprofile.Uploader.Windows/App.xaml.cs b/Heroesprofile.Uploader.Windows/App.xaml.cs index c347f63..40bb893 100644 --- a/Heroesprofile.Uploader.Windows/App.xaml.cs +++ b/Heroesprofile.Uploader.Windows/App.xaml.cs @@ -8,7 +8,6 @@ using System; using System.Collections.Generic; -using System.ComponentModel; using System.IO; using System.Reflection; using System.Text.Json; @@ -21,29 +20,39 @@ namespace Heroesprofile.Uploader.Windows { - - public partial class App : System.Windows.Application, INotifyPropertyChanged + public partial class App : System.Windows.Application { - public static IConfiguration Config { get; private set; } + public new static App Current => (App) System.Windows.Application.Current; + - public static Logger _log; + private static object _lock = new object(); - public AppConfig AppConfig { get; private set; } + public IConfiguration Config { get; private set; } - public static bool StartWithWindowsCheckboxEnabled => true; + public Logger _log; + + public UserSettings UserSettings { get; private set; } + public AppSettings AppSettings { get; private set; } - public event PropertyChangedEventHandler PropertyChanged; + private SettingsManager settingsManager; public NotifyIcon TrayIcon { get; private set; } public Manager Manager { get; private set; } - internal static Properties.Settings Settings => Uploader.Windows.Properties.Settings.Default; - public static string AppExe => Assembly.GetExecutingAssembly().Location; - public static string AppDir => Path.GetDirectoryName(AppExe); - public static string AppFile => Path.GetFileName(AppExe); - public static string SettingsDir => Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData), "Heroesprofile"); + + public string SettingsDir => Path.Combine(Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData), "Heroesprofile"); - public static Version Version => Assembly.GetExecutingAssembly().GetName().Version; - public string VersionString => $"v{Version.Major}.{Version.Minor}" + (Version.Build == 0 ? "" : $".{Version.Build}"); + public Version Version + { + get { + if (ApplicationDeployment.IsNetworkDeployed) { + return ApplicationDeployment.CurrentDeployment.CurrentVersion; + } + + return Assembly.GetExecutingAssembly().GetName().Version; + } + } + + public string VersionString => $"v{Version}"; public bool StartWithWindows { @@ -64,29 +73,27 @@ public bool StartWithWindows { "MetroDark", "Themes/MetroDark/MetroDark.Heroesprofile.Implicit.xaml" }, }; - - private static object _lock = new object(); + public MainWindow mainWindow; public App() { Config = new ConfigurationBuilder() - .SetBasePath(AppDir) + .SetBasePath(Directory.GetCurrentDirectory()) .AddJsonFile("appsettings.json", optional: true, reloadOnChange: true) .Build(); + settingsManager = new SettingsManager(Path.Combine(SettingsDir, "userSettings.json")); + UserSettings = settingsManager.LoadSettings(); + AppSettings = Config.GetSection(nameof(AppSettings)).Get()!; + + if (UserSettings == null) { + UserSettings = new UserSettings(AppSettings); + } LogManager.Configuration = new NLogLoggingConfiguration(Config.GetSection("NLog")); _log = LogManager.GetCurrentClassLogger(); - - AppConfig = Config.GetSection("AppConfig").Get()!; - - Settings.WindowHeight = AppConfig.WindowHeight; - Settings.WindowWidth = AppConfig.WindowWidth; - Settings.WindowLeft = AppConfig.WindowLeft; - Settings.WindowTop = AppConfig.WindowTop; - if (ApplicationDeployment.IsNetworkDeployed) { _log.Info(JsonSerializer.Serialize(ApplicationDeployment.CurrentDeployment)); } else { @@ -106,30 +113,28 @@ private void Application_Startup(object sender, StartupEventArgs e) // Enable collection modification from any thread BindingOperations.EnableCollectionSynchronization(Manager.Files, _lock); - Manager.PreMatchPage = Settings.PreMatchPage; - Manager.PostMatchPage = Settings.PostMatchPage; - Manager.DeleteAfterUpload = Settings.DeleteAfterUpload; + Manager.PreMatchPage = UserSettings.PreMatchPage; + Manager.PostMatchPage = UserSettings.PostMatchPage; + Manager.DeleteAfterUpload = DeleteFiles.None; - ApplyTheme(Settings.Theme); + ApplyTheme(AppSettings.Theme); + UserSettings.PropertyChanged += (o, ev) => { - Settings.PropertyChanged += (o, ev) => { - if (ev.PropertyName == nameof(Settings.DeleteAfterUpload)) { - Manager.DeleteAfterUpload = Settings.DeleteAfterUpload; - } else if (ev.PropertyName == nameof(Settings.Theme)) { - ApplyTheme(Settings.Theme); - } else if (ev.PropertyName == nameof(Settings.PreMatchPage)) { - Manager.PreMatchPage = Settings.PreMatchPage; - } else if (ev.PropertyName == nameof(Settings.PostMatchPage)) { - Manager.PostMatchPage = Settings.PostMatchPage; + if (ev.PropertyName == nameof(UserSettings.PreMatchPage)) { + Manager.PreMatchPage = UserSettings.PreMatchPage; + } else if (ev.PropertyName == nameof(UserSettings.PostMatchPage)) { + Manager.PostMatchPage = UserSettings.PostMatchPage; } - }; + settingsManager.SaveSettings(UserSettings); + }; - if (Settings.MinimizeToTray) { + if (StartWithWindows) { TrayIcon.Visible = true; } else { mainWindow = new MainWindow(); + mainWindow.Deactivated += (o, ev) => TrayIcon.Visible = true; mainWindow.Show(); } Manager.Start(new Monitor(), new LiveMonitor(), new Analyzer(), new Common.Uploader(), new LiveProcessor(Manager.PreMatchPage)); @@ -154,37 +159,22 @@ public void ApplyTheme(string theme) } public void Activate() - { - if (mainWindow != null) { - if (mainWindow.WindowState == WindowState.Minimized) { - mainWindow.WindowState = WindowState.Normal; - } - mainWindow.Activate(); - } else { - mainWindow = new MainWindow(); - mainWindow.Show(); - mainWindow.WindowState = WindowState.Normal; - TrayIcon.Visible = false; - } + { + mainWindow = new MainWindow(); + mainWindow.Activate(); + mainWindow.WindowState = WindowState.Normal; + mainWindow.Show(); + TrayIcon.Visible = false; } private void SetupTrayIcon() { TrayIcon = new NotifyIcon { - Icon = System.Drawing.Icon.ExtractAssociatedIcon(Assembly.GetExecutingAssembly().Location), + Icon = System.Drawing.Icon.ExtractAssociatedIcon(Path.Combine("Resources", "uploader_icon_dark.ico")), Visible = true }; - TrayIcon.Click += (o, e) => { - if (mainWindow != null) { - mainWindow.Activate(); - TrayIcon.Visible = false; - return; - } else { - mainWindow = new MainWindow(); - mainWindow.Show(); - TrayIcon.Visible = false; - } - }; + + TrayIcon.Click += (o, e) => Activate(); } private void SetExceptionHandlers() diff --git a/Heroesprofile.Uploader.Windows/Core/AppConfig.cs b/Heroesprofile.Uploader.Windows/Core/AppConfig.cs deleted file mode 100644 index bd777bd..0000000 --- a/Heroesprofile.Uploader.Windows/Core/AppConfig.cs +++ /dev/null @@ -1,21 +0,0 @@ -namespace Heroesprofile.Uploader.Windows.Core -{ - public class AppConfig - { - public bool UpgradeRequired { get; set; } - public bool AutoUpdate { get; set; } - public string UpdateRepository { get; set; } - public int WindowTop { get; set; } - public int WindowLeft { get; set; } - public bool MinimizeToTray { get; set; } - public int WindowHeight { get; set; } - public int WindowWidth { get; set; } - public string DeleteAfterUpload { get; set; } - public string Theme { get; set; } - public bool AllowPreReleases { get; set; } - public string ApplicationVersion { get; set; } - public bool PreMatchPage { get; set; } - public bool PostMatchPage { get; set; } - - } -} diff --git a/Heroesprofile.Uploader.Windows/Core/Settings.cs b/Heroesprofile.Uploader.Windows/Core/Settings.cs new file mode 100644 index 0000000..5eb01f7 --- /dev/null +++ b/Heroesprofile.Uploader.Windows/Core/Settings.cs @@ -0,0 +1,133 @@ +using Heroesprofile.Uploader.Common; +using Heroesprofile.Uploader.Windows.Properties; + +using System.ComponentModel; +using System.Text.Json.Serialization; + +namespace Heroesprofile.Uploader.Windows.Core +{ + public class UserSettings : INotifyPropertyChanged + { + private int _windowTop; + + [JsonPropertyName("windowTop")] + public int WindowTop + { + get => _windowTop; + set { + _windowTop = value; + PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(nameof(WindowTop))); + } + } + + private int _windowLeft; + + [JsonPropertyName("windowLeft")] + public int WindowLeft + { + get => _windowLeft; + set { + _windowLeft = value; + PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(nameof(WindowLeft))); + } + } + + private bool _minimizeToTray; + + [JsonPropertyName("minimizeToTray")] + public bool MinimizeToTray + { + get => _minimizeToTray; + set { + _minimizeToTray = value; + PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(nameof(MinimizeToTray))); + } + } + + + private int windowHeight; + + [JsonPropertyName("windowHeight")] + public int WindowHeight + { + get => windowHeight; + set { + windowHeight = value; + PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(nameof(WindowHeight))); + } + } + + private int windowWidth; + + [JsonPropertyName("windowWidth")] + public int WindowWidth + { + get => windowWidth; + set { + windowWidth = value; + PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(nameof(WindowWidth))); + } + } + + + private bool _preMatchPage; + + [JsonPropertyName("preMatchPage")] + + public bool PreMatchPage + { + get => _preMatchPage; + set { + _preMatchPage = value; + PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(nameof(PreMatchPage))); + } + } + + + private bool _postMatchPage; + + [JsonPropertyName("postMatchPage")] + + public bool PostMatchPage + { + get => _postMatchPage; + set { + _postMatchPage = value; + PropertyChanged?.Invoke(this, new PropertyChangedEventArgs(nameof(PostMatchPage))); + } + } + + public UserSettings() + { + + } + + public UserSettings(AppSettings settings) + { + WindowHeight = settings.WindowHeight; + WindowWidth = settings.WindowWidth; + WindowTop = settings.WindowTop; + WindowLeft = settings.WindowLeft; + MinimizeToTray = settings.MinimizeToTray; + PreMatchPage = settings.PreMatchPage; + PostMatchPage = settings.PostMatchPage; + } + + public event PropertyChangedEventHandler? PropertyChanged; + } + + + public class AppSettings { + + public int WindowTop { get; set; } + public int WindowLeft { get; set; } + public bool MinimizeToTray { get; set; } + public int WindowHeight { get; set; } + public int WindowWidth { get; set; } + public DeleteFiles DeleteAfterUpload { get; set; } + public bool PreMatchPage { get; set; } + public bool PostMatchPage { get; set; } + public string Theme { get; set; } + + } +} diff --git a/Heroesprofile.Uploader.Windows/Core/SettingsManager.cs b/Heroesprofile.Uploader.Windows/Core/SettingsManager.cs new file mode 100644 index 0000000..a4e078b --- /dev/null +++ b/Heroesprofile.Uploader.Windows/Core/SettingsManager.cs @@ -0,0 +1,38 @@ +using System; +using System.IO; +using System.Text.Json; + +namespace Heroesprofile.Uploader.Windows.Core +{ + public class SettingsManager where T : class + { + private readonly string _filePath; + + public SettingsManager(string fileName) + { + _filePath = GetLocalFilePath(fileName); + } + + private string GetLocalFilePath(string fileName) + { + string appData = Environment.GetFolderPath(Environment.SpecialFolder.ApplicationData); + return Path.Combine(appData, fileName); + } + + public T? LoadSettings() + { + try { + return JsonSerializer.Deserialize(File.ReadAllText(_filePath), JsonSerializerOptions.Default); + } + catch { + return null; + } + } + + public void SaveSettings(T settings) + { + string json = JsonSerializer.Serialize(settings); + File.WriteAllText(_filePath, json); + } + } +} diff --git a/Heroesprofile.Uploader.Windows/Heroesprofile.Uploader.Windows.csproj b/Heroesprofile.Uploader.Windows/Heroesprofile.Uploader.Windows.csproj index d20e39c..264e82b 100644 --- a/Heroesprofile.Uploader.Windows/Heroesprofile.Uploader.Windows.csproj +++ b/Heroesprofile.Uploader.Windows/Heroesprofile.Uploader.Windows.csproj @@ -42,16 +42,6 @@ PreserveNewest - - True - True - Settings.settings - - - SettingsSingleFileGenerator - Settings.Designer.cs - Always - @@ -67,6 +57,9 @@ Always + + Always + \ No newline at end of file diff --git a/Heroesprofile.Uploader.Windows/MainWindow.xaml b/Heroesprofile.Uploader.Windows/MainWindow.xaml index da9f83f..2dd0843 100644 --- a/Heroesprofile.Uploader.Windows/MainWindow.xaml +++ b/Heroesprofile.Uploader.Windows/MainWindow.xaml @@ -8,9 +8,9 @@ xmlns:heroesprofile="clr-namespace:Heroesprofile.Uploader.Common;assembly=Heroesprofile.Uploader.Common" mc:Ignorable="d" StateChanged="Window_StateChanged" Closed="Window_Closed" - Height="{Binding App.Settings.WindowHeight, Mode=TwoWay}" Width="{Binding App.Settings.WindowWidth, Mode=TwoWay}" - Top="{Binding App.Settings.WindowTop, Mode=TwoWay}" Left="{Binding App.Settings.WindowLeft, Mode=TwoWay}" - Title="{Binding App.VersionString, StringFormat=Heroesprofile.com Uploader {0}}" + Height="{Binding UserSettings.WindowHeight, Mode=TwoWay}" Width="{Binding UserSettings.WindowWidth, Mode=TwoWay}" + Top="{Binding UserSettings.WindowTop, Mode=TwoWay}" Left="{Binding UserSettings.WindowLeft, Mode=TwoWay}" + Title="{Binding VersionString, StringFormat=Heroesprofile.com Uploader {0}}" DataContext="{Binding RelativeSource={RelativeSource Self}}" d:DesignWidth="551"> @@ -31,9 +31,9 @@ - + - + @@ -47,29 +47,24 @@ - - - - - - - - - - + + + + + + + + + + - - - - + + + +