select: function( event, ui ) {
$.log("select artifactId:"+ui.item.artifactId);
// user can be in a non search view so init the search view first
+ var searchViewModel = new SearchViewModel();
+ var searchRequest = new SearchRequest();
+ searchRequest.artifactId(ui.item.artifactId);
+ searchViewModel.searchRequest(searchRequest);
displaySearch(function(){
- var searchViewModel = new SearchViewModel();
- var searchRequest = new SearchRequest();
- searchRequest.artifactId(ui.item.artifactId);
- searchViewModel.searchRequest(searchRequest);
searchViewModel.externalAdvancedSearch();
- });
+ },searchViewModel);
}
}).data( "autocomplete" )._renderItem = function( ul, item ) {
return $( "<li></li>" )
});
}
+ /**
+ * search results view model: display a grid with autocomplete filtering on grid headers
+ * @param artifacts
+ */
ResultViewModel=function(artifacts){
var self=this;
this.originalArtifacts=artifacts;
});
}
+ /**
+ * View model used for search response and filtering
+ */
SearchViewModel=function(){
var self=this;
this.searchRequest=ko.observable(new SearchRequest());
self.search("restServices/archivaServices/searchService/searchArtifacts");
}
removeFilter=function(){
+ $.log("removeFilter:"+self.resultViewModel.originalArtifacts.length);
self.resultViewModel.artifacts(self.resultViewModel.originalArtifacts);
}
this.search=function(url){
mainContent.find("#btn-advanced-search" ).button("loading");
$("#user-messages").html(mediumSpinnerImg());
-
self.selectedRepoIds=[];
mainContent.find("#search-basic-repositories" )
.find(".chzn-choices li span").each(function(i,span){
success: function(data) {
clearUserMessages();
var artifacts=mapArtifacts(data);
+ $.log("search#ajax call success:artifacts.length:"+artifacts.length);
if (artifacts.length<1){
displayWarningMessage( $.i18n.prop("search.artifact.noresults"));
return;
} else {
self.resultViewModel.originalArtifacts=artifacts;
+ $.log("search#ajax call success:self.resultViewModel.originalArtifacts:"+self.resultViewModel.originalArtifacts.length);
self.resultViewModel.artifacts(artifacts);
if (!searchResultsGrid.attr("data-bind")){
+ $.log('!searchResultsGrid.attr("data-bind")');
searchResultsGrid.attr("data-bind",
"simpleGrid: gridViewModel,simpleGridTemplate:'search-results-view-grid-tmpl',pageLinksId:'search-results-view-grid-pagination'");
ko.applyBindings(self.resultViewModel,searchResultsGrid.get(0));
ko.applyBindings(self,mainContent.find("#remove-filter-id" ).get(0));
- mainContent.find("#search-result-number-div").attr("data-bind",
- "template:{name:'search-result-number-div-tmpl'}");
+ mainContent.find("#search-result-number-div").attr("data-bind","template:{name:'search-result-number-div-tmpl'}");
ko.applyBindings(self,mainContent.find("#search-result-number-div" ).get(0));
}
}
- displaySearch=function(successCallbackFn){
+ /**
+ * display a search result (collection of Artifacts) in a grid
+ * see template with id #search-artifacts-div-tmpl
+ * @param successCallbackFn can be a callback function called on success getting observable repositories.
+ * @param searchViewModelCurrent model to reuse if not null whereas a new one is created.
+ */
+ displaySearch=function(successCallbackFn,searchViewModelCurrent){
clearUserMessages();
var mainContent=$("#main-content");
mainContent.html(mediumSpinnerImg());
dataType: 'json',
success: function(data) {
mainContent.html($("#search-artifacts-div-tmpl" ).tmpl());
- var searchViewModel=new SearchViewModel();
+ var searchViewModel;
+ if (searchViewModelCurrent){
+ $.log("searchViewModelCurrent not null");
+ searchViewModel=searchViewModelCurrent
+ }else {
+ $.log("searchViewModelCurrent null");
+ searchViewModel=new SearchViewModel();
+ }
var repos=mapStringList(data);
$.log("repos:"+repos);
searchViewModel.observableRepoIds(repos);