Icon, Tab state persistence

This commit is contained in:
2022-02-03 13:08:35 +01:00
parent 1ea1012703
commit 3da246b3ca
28 changed files with 283 additions and 31 deletions

View File

@@ -47,7 +47,7 @@ namespace FileTime.Providers.Local
_items = _rootContainers.Cast<IItem>().ToList().AsReadOnly();
}
public async Task<IItem?> GetByPath(string path)
public async Task<IItem?> GetByPath(string path, bool acceptDeepestMatch = false)
{
path = path.Replace(Path.DirectorySeparatorChar, Constants.SeparatorChar).TrimEnd(Constants.SeparatorChar);
var pathParts = (IsCaseInsensitive ? path.ToLower() : path).TrimStart(Constants.SeparatorChar).Split(Constants.SeparatorChar);
@@ -64,7 +64,7 @@ namespace FileTime.Providers.Local
}
var remainingPath = string.Join(Constants.SeparatorChar, pathParts.Skip(1));
return remainingPath.Length == 0 ? rootContainer : await rootContainer.GetByPath(remainingPath);
return remainingPath.Length == 0 ? rootContainer : await rootContainer.GetByPath(remainingPath, acceptDeepestMatch);
}
public async Task Refresh() => await Refreshed.InvokeAsync(this, AsyncEventArgs.Empty);

View File

@@ -88,7 +88,7 @@ namespace FileTime.Providers.Local
return _elements;
}
public async Task<IItem?> GetByPath(string path)
public async Task<IItem?> GetByPath(string path, bool acceptDeepestMatch = false)
{
var paths = path.Split(Constants.SeparatorChar);
@@ -101,7 +101,7 @@ namespace FileTime.Providers.Local
if (item is IContainer container)
{
return await container.GetByPath(string.Join(Constants.SeparatorChar, paths.Skip(1)));
return await container.GetByPath(string.Join(Constants.SeparatorChar, paths.Skip(1)), acceptDeepestMatch);
}
return null;