Fixed wrong replacements

This commit is contained in:
Jan Philipp Weber 2020-09-05 17:41:18 +02:00 committed by GitHub
parent c970ce6873
commit 75e0737acd
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23

View file

@ -15,12 +15,11 @@ using System.Windows.Controls;
using System.Windows.Input;
using System.Windows.Media;
using FontAwesome.WPF;
using Microsoft.Win32;
using SafeExamBrowser.I18n.Contracts;
using SafeExamBrowser.UserInterface.Contracts.FileSystemDialog;
using SafeExamBrowser.UserInterface.Contracts.Windows;
using SafeExamBrowser.UserInterface.Shared.Utilities;
using Microsoft.Win32;
namespace SafeExamBrowser.UserInterface.Desktop.Windows
{
@ -31,6 +30,7 @@ namespace SafeExamBrowser.UserInterface.Desktop.Windows
private string message;
private FileSystemOperation operation;
private IWindow parent;
private bool restrictNavigation;
private IText text;
private string title;
@ -41,13 +41,15 @@ namespace SafeExamBrowser.UserInterface.Desktop.Windows
string initialPath = default(string),
string message = default(string),
string title = default(string),
IWindow parent = default(IWindow))
IWindow parent = default(IWindow),
bool restrictNavigation = false)
{
this.element = element;
this.initialPath = initialPath;
this.message = message;
this.operation = operation;
this.parent = parent;
this.restrictNavigation = restrictNavigation;
this.text = text;
this.title = title;
@ -292,7 +294,7 @@ namespace SafeExamBrowser.UserInterface.Desktop.Windows
var drives = DriveInfo.GetDrives();
int noDrives = (int)Registry.GetValue("HKEY_CURRENT_USER\\Software\\Microsoft\\Windows\\CurrentVersion\\Policies\\Explorer", "NoDrives", 0);
if (noDrives > 0 || showAll)
if (noDrives > 0 && !showAll)
{
return drives.Where(drive => (noDrives & (int)(Math.Pow(2, (int)(drive.RootDirectory.ToString()[0]) - 65))) == 0).ToArray();
}
@ -300,7 +302,36 @@ namespace SafeExamBrowser.UserInterface.Desktop.Windows
return drives;
}
private void InitializeFileSystem()
{
if (restrictNavigation && !string.IsNullOrEmpty(initialPath))
{
InitializeRestricted();
}
else
{
InitializeUnrestricted();
}
}
private void InitializeRestricted()
{
var root = Directory.Exists(initialPath) ? initialPath : Path.GetDirectoryName(initialPath);
if (Directory.Exists(root))
{
var directory = CreateItem(new DirectoryInfo(root));
FileSystem.Items.Add(directory);
directory.IsExpanded = true;
directory.IsSelected = true;
directory.BringIntoView();
}
}
private void InitializeUnrestricted()
{
foreach (var drive in GetDrives())
{