|
@@ -14,13 +14,10 @@ MaterioBaseMod = function(){
|
|
|
function init(){
|
|
|
trace('init module');
|
|
|
|
|
|
- // $('#root').bind('resultsupdated', function(event) {
|
|
|
- // alert('HO');
|
|
|
- // });
|
|
|
- $(window).trigger('resultsupdated');
|
|
|
initSearchAjax();
|
|
|
initHistoryNav();
|
|
|
initViewMode();
|
|
|
+
|
|
|
};
|
|
|
|
|
|
/**
|
|
@@ -28,14 +25,12 @@ MaterioBaseMod = function(){
|
|
|
*/
|
|
|
function initSearchAjax(){
|
|
|
// trace('initSearchAjax');
|
|
|
- $('#edit-searchfield').focus();
|
|
|
-
|
|
|
+ // $('#edit-searchfield').focus();
|
|
|
|
|
|
$('#materio-search-api-search-form').bind('submit', function(event) {
|
|
|
// trace('search submited', event);
|
|
|
var $this = $(this);
|
|
|
setTimeout(function(){
|
|
|
- // trace('submit load');
|
|
|
loadResults(getSearchKeys());
|
|
|
},10);
|
|
|
return false;
|
|
@@ -44,13 +39,11 @@ MaterioBaseMod = function(){
|
|
|
|
|
|
// /!\ AUTOCOMPLETE SELECT EVENT need a patch http://drupal.org/node/365241#comment-5374686
|
|
|
$("#edit-searchfield").bind('autocompleteSelect', function(event) {
|
|
|
- // trace('autocompleteSelect - event', event);
|
|
|
- // trace('val', $(this).val());
|
|
|
- // var $form = $(this).parents('form');
|
|
|
- // setTimeout(function(){
|
|
|
- // $form.submit();
|
|
|
- // }, 10);
|
|
|
- loadResults($(this).val());
|
|
|
+ setTimeout(function(){
|
|
|
+ loadResults(getSearchKeys());
|
|
|
+ },10);
|
|
|
+
|
|
|
+ // loadResults($(this).val());
|
|
|
});
|
|
|
|
|
|
|
|
@@ -67,19 +60,32 @@ MaterioBaseMod = function(){
|
|
|
loadNextResultsPage();
|
|
|
});
|
|
|
|
|
|
+ // trigger updated event on search results for direct html loading
|
|
|
+ if($('.search-results', _$content).length){
|
|
|
+ setTimeout(function(){
|
|
|
+ var event = jQuery.Event('resultsupdated');
|
|
|
+ event.container = $('.search-results', _$content);
|
|
|
+ $(window).trigger(event);
|
|
|
+ }, 10);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
};
|
|
|
-
|
|
|
+
|
|
|
+
|
|
|
function loadResults(keys){
|
|
|
// trace('keys', keys);
|
|
|
if(keys !== undefined){
|
|
|
keys = keys.replace('/', ' ');
|
|
|
if(!_isloadingresults){
|
|
|
_isloadingresults = true;
|
|
|
+ $('#materio-search-api-search-form').addClass('loading');
|
|
|
// TODO: record ajax path in a variable from materio_search_api_ajax_init
|
|
|
$.getJSON('/materio_search_api_ajax/search/'+keys, function(json){
|
|
|
// trace('json', json);
|
|
|
$(window).trigger('resultsloaded');
|
|
|
_isloadingresults = false;
|
|
|
+ $('#materio-search-api-search-form').removeClass('loading');
|
|
|
updateContent(json);
|
|
|
});
|
|
|
}
|
|
@@ -103,17 +109,17 @@ MaterioBaseMod = function(){
|
|
|
// $('.node-materiau','#content').fadeIn(500);
|
|
|
// },300);
|
|
|
|
|
|
-
|
|
|
- var event = jQuery.Event('resultsupdated');
|
|
|
- event.container = $('.search-results', _$content);
|
|
|
- $(window).trigger(event);
|
|
|
|
|
|
_History.pushState({content:json.return}, json.keys, '/'+json.search_path + '/' +json.keys);
|
|
|
// navigate({content:json.return}, '', '/'+json.page.path + '/' +json.keys);
|
|
|
|
|
|
+ var event = jQuery.Event('resultsupdated');
|
|
|
+ event.container = $('.search-results', _$content);
|
|
|
+ $(window).trigger(event);
|
|
|
+
|
|
|
|
|
|
}else{
|
|
|
- alert('no results');
|
|
|
+ trace('no results');
|
|
|
}
|
|
|
};
|
|
|
|
|
@@ -134,9 +140,11 @@ MaterioBaseMod = function(){
|
|
|
|
|
|
if(!_isloadingresults){
|
|
|
_isloadingresults = true;
|
|
|
+ $('.materiobase-results', _$content).addClass('loading');
|
|
|
$.getJSON('/materio_search_api_ajax/search/'+keys[1]+'/'+page[1], function(json){
|
|
|
// trace('json', json);
|
|
|
_isloadingresults = false;
|
|
|
+ $('.materiobase-results', _$content).removeClass('loading');
|
|
|
addNextpage(json);
|
|
|
});
|
|
|
}
|
|
@@ -147,12 +155,20 @@ MaterioBaseMod = function(){
|
|
|
|
|
|
function addNextpage(json){
|
|
|
var $newcontent = $(json.return),
|
|
|
- $newresults = $('.search-results article', $newcontent),
|
|
|
+ $newresults = $('.search-results', $newcontent).children('article').addClass('just-added'),
|
|
|
$newpager = $('ul.pager', $newcontent);
|
|
|
|
|
|
$('.search-results', _$content).append($newresults);
|
|
|
$('ul.pager', _$content).replaceWith($newpager);
|
|
|
|
|
|
+ $('.search-results', _$content).children('.just-added').each(function(i){
|
|
|
+ // $(this).delay(5000*i).removeClass('just-added');
|
|
|
+ var $this = $(this);
|
|
|
+ setTimeout(function(){
|
|
|
+ $this.removeClass('just-added');
|
|
|
+ }, 150*i);
|
|
|
+ });
|
|
|
+
|
|
|
var event = jQuery.Event('resultscompleted');
|
|
|
event.container = $('.search-results', _$content);
|
|
|
$(window).trigger(event);
|