compiler settings file picker QoL changes

allow selection of files for including.
allow selection of files for ignoring.
allow multiselect for files and folders.
allow multiselect for additional profiles.
allow multiselect for always enabled mods.
This commit is contained in:
EzioTheDeadPoet 2022-11-04 20:28:33 +01:00
parent d3d0a29bcb
commit 7ca983e26a
2 changed files with 111 additions and 27 deletions

View File

@ -165,7 +165,11 @@
<Button Name="AddInclude"> <Button Name="AddInclude">
<icon:Material Kind="Plus"></icon:Material> <icon:Material Kind="Plus"></icon:Material>
</Button> </Button>
<Label>Include</Label> <Label>Include Folders</Label>
<Button Name="AddIncludeFiles">
<icon:Material Kind="Plus"></icon:Material>
</Button>
<Label>Include Files</Label>
</StackPanel> </StackPanel>
<ListBox x:Name="Include"> <ListBox x:Name="Include">
<ListBox.ItemTemplate> <ListBox.ItemTemplate>
@ -179,7 +183,11 @@
<Button Name="AddIgnore"> <Button Name="AddIgnore">
<icon:Material Kind="Plus"></icon:Material> <icon:Material Kind="Plus"></icon:Material>
</Button> </Button>
<Label>Ignore</Label> <Label>Ignore Folders</Label>
<Button Name="AddIgnoreFiles">
<icon:Material Kind="Plus"></icon:Material>
</Button>
<Label>Ignore Files</Label>
</StackPanel> </StackPanel>
<ListBox x:Name="Ignore"> <ListBox x:Name="Ignore">
<ListBox.ItemTemplate> <ListBox.ItemTemplate>

View File

@ -219,6 +219,7 @@ namespace Wabbajack
.DisposeWith(disposables); .DisposeWith(disposables);
AddInclude.Command = ReactiveCommand.CreateFromTask(async () => await AddIncludeCommand()); AddInclude.Command = ReactiveCommand.CreateFromTask(async () => await AddIncludeCommand());
AddIncludeFiles.Command = ReactiveCommand.CreateFromTask(async () => await AddIncludeFilesCommand());
ViewModel.WhenAnyValue(vm => vm.Ignore) ViewModel.WhenAnyValue(vm => vm.Ignore)
.WhereNotNull() .WhereNotNull()
@ -227,6 +228,7 @@ namespace Wabbajack
.DisposeWith(disposables); .DisposeWith(disposables);
AddIgnore.Command = ReactiveCommand.CreateFromTask(async () => await AddIgnoreCommand()); AddIgnore.Command = ReactiveCommand.CreateFromTask(async () => await AddIgnoreCommand());
AddIgnoreFiles.Command = ReactiveCommand.CreateFromTask(async () => await AddIgnoreFilesCommand());
}); });
@ -258,16 +260,19 @@ namespace Wabbajack
EnsurePathExists = true, EnsurePathExists = true,
EnsureReadOnly = false, EnsureReadOnly = false,
EnsureValidNames = true, EnsureValidNames = true,
Multiselect = false, Multiselect = true,
ShowPlacesList = true, ShowPlacesList = true,
}; };
if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return; if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return;
var selectedPath = dlg.FileNames.First().ToAbsolutePath(); foreach (var fileName in dlg.FileNames)
{
var selectedPath = fileName.ToAbsolutePath();
if (!selectedPath.InFolder(ViewModel.Source)) return; if (!selectedPath.InFolder(ViewModel.Source)) continue;
ViewModel.AddAlwaysEnabled(selectedPath.RelativeTo(ViewModel.Source)); ViewModel.AddAlwaysEnabled(selectedPath.RelativeTo(ViewModel.Source));
}
} }
public async Task AddOtherProfileCommand() public async Task AddOtherProfileCommand()
@ -295,16 +300,19 @@ namespace Wabbajack
EnsurePathExists = true, EnsurePathExists = true,
EnsureReadOnly = false, EnsureReadOnly = false,
EnsureValidNames = true, EnsureValidNames = true,
Multiselect = false, Multiselect = true,
ShowPlacesList = true, ShowPlacesList = true,
}; };
if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return; if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return;
var selectedPath = dlg.FileNames.First().ToAbsolutePath(); foreach (var filename in dlg.FileNames)
{
if (!selectedPath.InFolder(ViewModel.Source.Combine("profiles"))) return; var selectedPath = filename.ToAbsolutePath();
ViewModel.AddOtherProfile(selectedPath.FileName.ToString()); if (!selectedPath.InFolder(ViewModel.Source.Combine("profiles"))) continue;
ViewModel.AddOtherProfile(selectedPath.FileName.ToString());
}
} }
public Task AddNoMatchIncludeCommand() public Task AddNoMatchIncludeCommand()
@ -321,16 +329,20 @@ namespace Wabbajack
EnsurePathExists = true, EnsurePathExists = true,
EnsureReadOnly = false, EnsureReadOnly = false,
EnsureValidNames = true, EnsureValidNames = true,
Multiselect = false, Multiselect = true,
ShowPlacesList = true, ShowPlacesList = true,
}; };
if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return Task.CompletedTask; if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return Task.CompletedTask;
var selectedPath = dlg.FileNames.First().ToAbsolutePath(); foreach (var filename in dlg.FileNames)
{
var selectedPath = filename.ToAbsolutePath();
if (!selectedPath.InFolder(ViewModel.Source)) return Task.CompletedTask; if (!selectedPath.InFolder(ViewModel.Source)) continue;
ViewModel.AddNoMatchInclude(selectedPath.RelativeTo(ViewModel!.Source));
}
ViewModel.AddNoMatchInclude(selectedPath.RelativeTo(ViewModel!.Source));
return Task.CompletedTask; return Task.CompletedTask;
} }
@ -338,7 +350,7 @@ namespace Wabbajack
{ {
var dlg = new CommonOpenFileDialog var dlg = new CommonOpenFileDialog
{ {
Title = "Please select a file to include", Title = "Please select folders to include",
IsFolderPicker = true, IsFolderPicker = true,
InitialDirectory = ViewModel!.Source.ToString(), InitialDirectory = ViewModel!.Source.ToString(),
AddToMostRecentlyUsedList = false, AddToMostRecentlyUsedList = false,
@ -348,23 +360,55 @@ namespace Wabbajack
EnsurePathExists = true, EnsurePathExists = true,
EnsureReadOnly = false, EnsureReadOnly = false,
EnsureValidNames = true, EnsureValidNames = true,
Multiselect = false, Multiselect = true,
ShowPlacesList = true, ShowPlacesList = true,
}; };
if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return; if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return;
var selectedPath = dlg.FileNames.First().ToAbsolutePath(); foreach (var filename in dlg.FileNames)
{
var selectedPath = filename.ToAbsolutePath();
if (!selectedPath.InFolder(ViewModel.Source)) return; if (!selectedPath.InFolder(ViewModel.Source)) continue;
ViewModel.AddInclude(selectedPath.RelativeTo(ViewModel!.Source)); ViewModel.AddInclude(selectedPath.RelativeTo(ViewModel!.Source));
}
}
public async Task AddIncludeFilesCommand()
{
var dlg = new CommonOpenFileDialog
{
Title = "Please select files to include",
IsFolderPicker = false,
InitialDirectory = ViewModel!.Source.ToString(),
AddToMostRecentlyUsedList = false,
AllowNonFileSystemItems = false,
DefaultDirectory = ViewModel!.Source.ToString(),
EnsureFileExists = true,
EnsurePathExists = true,
EnsureReadOnly = false,
EnsureValidNames = true,
Multiselect = true,
ShowPlacesList = true,
};
if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return;
foreach (var filename in dlg.FileNames)
{
var selectedPath = filename.ToAbsolutePath();
if (!selectedPath.InFolder(ViewModel.Source)) continue;
ViewModel.AddInclude(selectedPath.RelativeTo(ViewModel!.Source));
}
} }
public async Task AddIgnoreCommand() public async Task AddIgnoreCommand()
{ {
var dlg = new CommonOpenFileDialog var dlg = new CommonOpenFileDialog
{ {
Title = "Please select a file to ignore", Title = "Please select folders to ignore",
IsFolderPicker = true, IsFolderPicker = true,
InitialDirectory = ViewModel!.Source.ToString(), InitialDirectory = ViewModel!.Source.ToString(),
AddToMostRecentlyUsedList = false, AddToMostRecentlyUsedList = false,
@ -374,16 +418,48 @@ namespace Wabbajack
EnsurePathExists = true, EnsurePathExists = true,
EnsureReadOnly = false, EnsureReadOnly = false,
EnsureValidNames = true, EnsureValidNames = true,
Multiselect = false, Multiselect = true,
ShowPlacesList = true, ShowPlacesList = true,
}; };
if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return; if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return;
var selectedPath = dlg.FileNames.First().ToAbsolutePath(); foreach (var filename in dlg.FileNames)
{
var selectedPath = filename.ToAbsolutePath();
if (!selectedPath.InFolder(ViewModel.Source)) return; if (!selectedPath.InFolder(ViewModel.Source)) continue;
ViewModel.AddIgnore(selectedPath.RelativeTo(ViewModel!.Source)); ViewModel.AddIgnore(selectedPath.RelativeTo(ViewModel!.Source));
}
}
public async Task AddIgnoreFilesCommand()
{
var dlg = new CommonOpenFileDialog
{
Title = "Please select files to ignore",
IsFolderPicker = false,
InitialDirectory = ViewModel!.Source.ToString(),
AddToMostRecentlyUsedList = false,
AllowNonFileSystemItems = false,
DefaultDirectory = ViewModel!.Source.ToString(),
EnsureFileExists = true,
EnsurePathExists = true,
EnsureReadOnly = false,
EnsureValidNames = true,
Multiselect = true,
ShowPlacesList = true,
};
if (dlg.ShowDialog() != CommonFileDialogResult.Ok) return;
foreach (var filename in dlg.FileNames)
{
var selectedPath = filename.ToAbsolutePath();
if (!selectedPath.InFolder(ViewModel.Source)) continue;
ViewModel.AddIgnore(selectedPath.RelativeTo(ViewModel!.Source));
}
} }
} }
} }