SEBWIN-568: Implemented functionality to automatically reperform text search on browser navigation or reload.

This commit is contained in:
Damian Büchel 2022-05-31 12:34:01 +02:00
parent 930c07d193
commit 66445a117f
3 changed files with 25 additions and 4 deletions

View file

@ -44,6 +44,7 @@ namespace SafeExamBrowser.Browser
{ {
internal class BrowserWindow : IApplicationWindow internal class BrowserWindow : IApplicationWindow
{ {
private const string CLEAR_FIND_TERM = "thisisahacktoclearthesearchresultsasitappearsthatthereisnosuchfunctionalityincef";
private const double ZOOM_FACTOR = 0.2; private const double ZOOM_FACTOR = 0.2;
private readonly AppConfig appConfig; private readonly AppConfig appConfig;
@ -60,6 +61,7 @@ namespace SafeExamBrowser.Browser
private readonly IText text; private readonly IText text;
private readonly IUserInterfaceFactory uiFactory; private readonly IUserInterfaceFactory uiFactory;
private (string term, bool isInitial, bool caseSensitive, bool forward) findParameters;
private IBrowserWindow window; private IBrowserWindow window;
private double zoomLevel; private double zoomLevel;
@ -278,6 +280,8 @@ namespace SafeExamBrowser.Browser
window.UpdateTitle(address); window.UpdateTitle(address);
TitleChanged?.Invoke(address); TitleChanged?.Invoke(address);
} }
AutoFind();
} }
private void Control_LoadFailed(int errorCode, string errorText, bool isMainRequest, string url) private void Control_LoadFailed(int errorCode, string errorText, bool isMainRequest, string url)
@ -715,6 +719,11 @@ namespace SafeExamBrowser.Browser
{ {
if (settings.AllowFind) if (settings.AllowFind)
{ {
findParameters.caseSensitive = caseSensitive;
findParameters.forward = forward;
findParameters.isInitial = isInitial;
findParameters.term = term;
Control.Find(term, isInitial, caseSensitive, forward); Control.Find(term, isInitial, caseSensitive, forward);
} }
} }
@ -763,6 +772,14 @@ namespace SafeExamBrowser.Browser
} }
} }
private void AutoFind()
{
if (settings.AllowFind && !string.IsNullOrEmpty(findParameters.term) && !CLEAR_FIND_TERM.Equals(findParameters.term, StringComparison.OrdinalIgnoreCase))
{
Control.Find(findParameters.term, findParameters.isInitial, findParameters.caseSensitive, findParameters.forward);
}
}
private double CalculateZoomPercentage() private double CalculateZoomPercentage()
{ {
return (zoomLevel * 25.0) + 100.0; return (zoomLevel * 25.0) + 100.0;

View file

@ -33,6 +33,8 @@ namespace SafeExamBrowser.UserInterface.Desktop.Windows
{ {
internal partial class BrowserWindow : Window, IBrowserWindow internal partial class BrowserWindow : Window, IBrowserWindow
{ {
private const string CLEAR_FIND_TERM = "thisisahacktoclearthesearchresultsasitappearsthatthereisnosuchfunctionalityincef";
private readonly bool isMainWindow; private readonly bool isMainWindow;
private readonly BrowserSettings settings; private readonly BrowserSettings settings;
private readonly IText text; private readonly IText text;
@ -330,7 +332,7 @@ namespace SafeExamBrowser.UserInterface.Desktop.Windows
private void FindbarCloseButton_Click(object sender, RoutedEventArgs e) private void FindbarCloseButton_Click(object sender, RoutedEventArgs e)
{ {
FindRequested?.Invoke("thisisahacktoclearthesearchresultsasitappearsthatthereisnosuchfunctionalityincef", true, false); FindRequested?.Invoke(CLEAR_FIND_TERM, true, false);
Findbar.Visibility = Visibility.Collapsed; Findbar.Visibility = Visibility.Collapsed;
} }
@ -348,7 +350,7 @@ namespace SafeExamBrowser.UserInterface.Desktop.Windows
{ {
if (string.IsNullOrEmpty(FindTextBox.Text)) if (string.IsNullOrEmpty(FindTextBox.Text))
{ {
FindRequested?.Invoke("thisisahacktoclearthesearchresultsasitappearsthatthereisnosuchfunctionalityincef", true, false); FindRequested?.Invoke(CLEAR_FIND_TERM, true, false);
} }
else else
{ {

View file

@ -32,6 +32,8 @@ namespace SafeExamBrowser.UserInterface.Mobile.Windows
{ {
internal partial class BrowserWindow : Window, IBrowserWindow internal partial class BrowserWindow : Window, IBrowserWindow
{ {
private const string CLEAR_FIND_TERM = "thisisahacktoclearthesearchresultsasitappearsthatthereisnosuchfunctionalityincef";
private readonly bool isMainWindow; private readonly bool isMainWindow;
private readonly ILogger logger; private readonly ILogger logger;
private readonly BrowserSettings settings; private readonly BrowserSettings settings;
@ -234,7 +236,7 @@ namespace SafeExamBrowser.UserInterface.Mobile.Windows
private void FindbarCloseButton_Click(object sender, RoutedEventArgs e) private void FindbarCloseButton_Click(object sender, RoutedEventArgs e)
{ {
FindRequested?.Invoke("thisisahacktoclearthesearchresultsasitappearsthatthereisnosuchfunctionalityincef", true, false); FindRequested?.Invoke(CLEAR_FIND_TERM, true, false);
Findbar.Visibility = Visibility.Collapsed; Findbar.Visibility = Visibility.Collapsed;
} }
@ -252,7 +254,7 @@ namespace SafeExamBrowser.UserInterface.Mobile.Windows
{ {
if (string.IsNullOrEmpty(FindTextBox.Text)) if (string.IsNullOrEmpty(FindTextBox.Text))
{ {
FindRequested?.Invoke("thisisahacktoclearthesearchresultsasitappearsthatthereisnosuchfunctionalityincef", true, false); FindRequested?.Invoke(CLEAR_FIND_TERM, true, false);
} }
else else
{ {