mirror of
https://github.com/Ryujinx/Ryujinx.git
synced 2025-01-22 17:01:40 +00:00
eafcc314a9
* Start refactor * Move around functions * It builds * Menu opens * Buttons * Fix overlapping text * SaveAndClose and Close buttons * Remove button * Layout * It’s a little funky but it works * Enable all/disable all buttons * Fix UpdateCount desyncs * Search bar * Search by title id * Fix fuck ups * Fix selection mode * Update Ryujinx.Ava/UI/ViewModels/DownloadableContentManagerViewModel.cs Co-authored-by: Ac_K <Acoustik666@gmail.com> * Update Ryujinx.Ava/UI/ViewModels/DownloadableContentManagerViewModel.cs Co-authored-by: Ac_K <Acoustik666@gmail.com> * Update Ryujinx.Ava/UI/ViewModels/DownloadableContentManagerViewModel.cs Co-authored-by: Ac_K <Acoustik666@gmail.com> * Fix search bar * Log corrupted DLC json * Fix LibHac changes --------- Co-authored-by: Ac_K <Acoustik666@gmail.com>
115 lines
3.7 KiB
C#
115 lines
3.7 KiB
C#
using Avalonia.Controls;
|
|
using Avalonia.Interactivity;
|
|
using Avalonia.Styling;
|
|
using FluentAvalonia.UI.Controls;
|
|
using Ryujinx.Ava.Common.Locale;
|
|
using Ryujinx.Ava.UI.Helpers;
|
|
using Ryujinx.Ava.UI.Models;
|
|
using Ryujinx.Ava.UI.ViewModels;
|
|
using Ryujinx.HLE.FileSystem;
|
|
using Ryujinx.Ui.Common.Helper;
|
|
using System.Threading.Tasks;
|
|
using Button = Avalonia.Controls.Button;
|
|
|
|
namespace Ryujinx.Ava.UI.Windows
|
|
{
|
|
public partial class DownloadableContentManagerWindow : UserControl
|
|
{
|
|
public DownloadableContentManagerViewModel ViewModel;
|
|
|
|
public DownloadableContentManagerWindow()
|
|
{
|
|
DataContext = this;
|
|
|
|
InitializeComponent();
|
|
}
|
|
|
|
public DownloadableContentManagerWindow(VirtualFileSystem virtualFileSystem, ulong titleId, string titleName)
|
|
{
|
|
DataContext = ViewModel = new DownloadableContentManagerViewModel(virtualFileSystem, titleId, titleName);
|
|
|
|
InitializeComponent();
|
|
}
|
|
|
|
public static async Task Show(VirtualFileSystem virtualFileSystem, ulong titleId, string titleName)
|
|
{
|
|
ContentDialog contentDialog = new()
|
|
{
|
|
PrimaryButtonText = "",
|
|
SecondaryButtonText = "",
|
|
CloseButtonText = "",
|
|
Content = new DownloadableContentManagerWindow(virtualFileSystem, titleId, titleName),
|
|
Title = string.Format(LocaleManager.Instance[LocaleKeys.DlcWindowTitle], titleName, titleId.ToString("X16"))
|
|
};
|
|
|
|
Style bottomBorder = new(x => x.OfType<Grid>().Name("DialogSpace").Child().OfType<Border>());
|
|
bottomBorder.Setters.Add(new Setter(IsVisibleProperty, false));
|
|
|
|
contentDialog.Styles.Add(bottomBorder);
|
|
|
|
await ContentDialogHelper.ShowAsync(contentDialog);
|
|
}
|
|
|
|
private void SaveAndClose(object sender, RoutedEventArgs routedEventArgs)
|
|
{
|
|
ViewModel.Save();
|
|
((ContentDialog)Parent).Hide();
|
|
}
|
|
|
|
private void Close(object sender, RoutedEventArgs e)
|
|
{
|
|
((ContentDialog)Parent).Hide();
|
|
}
|
|
|
|
private void RemoveDLC(object sender, RoutedEventArgs e)
|
|
{
|
|
if (sender is Button button)
|
|
{
|
|
if (button.DataContext is DownloadableContentModel model)
|
|
{
|
|
ViewModel.Remove(model);
|
|
}
|
|
}
|
|
}
|
|
|
|
private void OpenLocation(object sender, RoutedEventArgs e)
|
|
{
|
|
if (sender is Button button)
|
|
{
|
|
if (button.DataContext is DownloadableContentModel model)
|
|
{
|
|
OpenHelper.LocateFile(model.ContainerPath);
|
|
}
|
|
}
|
|
}
|
|
|
|
private void OnSelectionChanged(object sender, SelectionChangedEventArgs e)
|
|
{
|
|
foreach (var content in e.AddedItems)
|
|
{
|
|
if (content is DownloadableContentModel model)
|
|
{
|
|
var index = ViewModel.DownloadableContents.IndexOf(model);
|
|
|
|
if (index != -1)
|
|
{
|
|
ViewModel.DownloadableContents[index].Enabled = true;
|
|
}
|
|
}
|
|
}
|
|
|
|
foreach (var content in e.RemovedItems)
|
|
{
|
|
if (content is DownloadableContentModel model)
|
|
{
|
|
var index = ViewModel.DownloadableContents.IndexOf(model);
|
|
|
|
if (index != -1)
|
|
{
|
|
ViewModel.DownloadableContents[index].Enabled = false;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
}
|
|
} |