Commit 6865289a authored by Ujvari Gergely's avatar Ujvari Gergely

Clear searchbar when switching back to Viewer.

Added a $routeChangeStart handle to the AppController which checks if we're to go back to the Viewer then it clears the searchbar and also clears the search query from localstorage
A solution for #643
parent 287f5754
...@@ -215,6 +215,17 @@ class App ...@@ -215,6 +215,17 @@ class App
$scope.$broadcast '$reset' $scope.$broadcast '$reset'
$scope.$on '$routeChangeStart', (current, next) =>
if next.$$route?.controller is 'ViewerController'
# Got back from search page
$scope.show_search = false
@visualSearch.searchBox.disableFacets();
@visualSearch.searchBox.value('');
@visualSearch.searchBox.flags.allSelected = false;
$scope.clearSearchLocalStorage()
# Update scope with auto-filled form field values # Update scope with auto-filled form field values
$timeout -> $timeout ->
for i in $element.find('input') when i.value for i in $element.find('input') when i.value
...@@ -259,6 +270,24 @@ class App ...@@ -259,6 +270,24 @@ class App
console.log "Should create unattached annotation" console.log "Should create unattached annotation"
# Searchbar initialization # Searchbar initialization
$scope.clearSearchLocalStorage = ->
unless typeof(localStorage) is 'undefined'
try
localStorage.setItem "hyp_page_search_query", ""
catch error
console.warn 'Cannot save query to localStorage!'
if error is DOMException.QUOTA_EXCEEDED_ERR
console.warn 'localStorage quota exceeded!'
$scope.saveSearchLocalStorage = (query) ->
unless typeof(localStorage) is 'undefined'
try
localStorage.setItem "hyp_page_search_query", query
catch error
console.warn 'Cannot save query to localStorage!'
if error is DOMException.QUOTA_EXCEEDED_ERR
console.warn 'localStorage quota exceeded!'
@user_filter = $filter('userName') @user_filter = $filter('userName')
search_query = '' search_query = ''
unless typeof(localStorage) is 'undefined' unless typeof(localStorage) is 'undefined'
...@@ -380,13 +409,7 @@ class App ...@@ -380,13 +409,7 @@ class App
matched.push annotation.id matched.push annotation.id
# Save query to localStorage # Save query to localStorage
unless typeof(localStorage) is 'undefined' $scope.saveSearchLocalStorage query
try
localStorage.setItem "hyp_page_search_query", query
catch error
console.warn 'Cannot save query to localStorage!'
if error is DOMException.QUOTA_EXCEEDED_ERR
console.warn 'localStorage quota exceeded!'
# Set the path # Set the path
search = search =
...@@ -409,13 +432,7 @@ class App ...@@ -409,13 +432,7 @@ class App
clearSearch: (original) => clearSearch: (original) =>
$scope.show_search = false $scope.show_search = false
original() original()
unless typeof(localStorage) is 'undefined' $scope.clearSearchLocalStorage()
try
localStorage.setItem "hyp_page_search_query", ""
catch error
console.warn 'Cannot save query to localStorage!'
if error is DOMException.QUOTA_EXCEEDED_ERR
console.warn 'localStorage quota exceeded!'
$location.path('/viewer') $location.path('/viewer')
$rootScope.$digest() $rootScope.$digest()
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment