materio_search_api_ajax.js 6.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226
  1. // @codekit-prepend "gui.js"
  2. (function($) {
  3. MaterioSearchApiAjax = function(){
  4. var _History = window.History,
  5. _isloadingresults = false;
  6. _$content = $('#content');
  7. // TODO: define $content by module settings
  8. /**
  9. * init()
  10. */
  11. function init(){
  12. trace('init module');
  13. initSearchAjax();
  14. initHistoryNav();
  15. initViewMode();
  16. };
  17. /**
  18. * searchAjax
  19. */
  20. function initSearchAjax(){
  21. // trace('initSearchAjax');
  22. // $('#edit-searchfield').focus();
  23. $('#materio-search-api-search-form').bind('submit', function(event) {
  24. // trace('search submited', event);
  25. var $this = $(this);
  26. setTimeout(function(){
  27. loadResults(getSearchKeys());
  28. },10);
  29. return false;
  30. });
  31. // /!\ AUTOCOMPLETE SELECT EVENT need a patch http://drupal.org/node/365241#comment-5374686
  32. $("#edit-searchfield").bind('autocompleteSelect', function(event) {
  33. $(this).parents('.form').trigger('submit');
  34. });
  35. _$content
  36. .bind('jsp-initialised', function(event, isScrollable){
  37. // trace('isScrollable = '+isScrollable);
  38. // TODO: better to check scroll-y than isscrollable, load next page before the end of scroll
  39. if(!isScrollable)
  40. loadNextResultsPage();
  41. // TODO: what happend when there is no more page
  42. })
  43. .bind('jsp-scroll-y', function(event, scrollPositionY, isAtTop, isAtBottom){
  44. if(isAtBottom)
  45. loadNextResultsPage();
  46. });
  47. // trigger updated event on search results for direct html loading
  48. if($('.search-results', _$content).length){
  49. setTimeout(function(){
  50. var event = jQuery.Event('resultsupdated');
  51. event.container = $('.search-results', _$content);
  52. $(window).trigger(event);
  53. }, 10);
  54. }
  55. };
  56. function getSearchKeys(){
  57. return $('#materio-search-api-search-form').find('input[name*="searchfield"]').val();
  58. };
  59. function loadResults(keys){
  60. // trace('keys', keys);
  61. if(keys !== undefined){
  62. keys = keys.replace('/', ' ');
  63. var types = {};
  64. $('#edit-bundles-filter', '#materio-search-api-search-form').find('input[type*="checkbox"]').each(function(i){
  65. $this = $(this);
  66. // if ( $this.attr('checked') ) {
  67. types[$this.val()] = $this.attr('checked');
  68. // }
  69. });
  70. trace('types', types);
  71. if(!_isloadingresults){
  72. _isloadingresults = true;
  73. $('#materio-search-api-search-form').addClass('loading');
  74. // TODO: record ajax path in a variable from materio_search_api_ajax_init
  75. $.getJSON(Drupal.settings.basePath+Drupal.settings.pathPrefix+'materio_search_api_ajax/search/'+keys,
  76. {'types':types},
  77. function(json){
  78. trace('json', json);
  79. $.event.trigger('resultsloaded');
  80. _isloadingresults = false;
  81. $('#materio-search-api-search-form').removeClass('loading');
  82. updateContent(json);
  83. });
  84. }
  85. }
  86. };
  87. function updateContent(json){
  88. if(json.return){
  89. $('.inner-content',_$content).html(json.return);
  90. var path = Drupal.settings.basePath + Drupal.settings.pathPrefix + json.search_path + '/' + json.keys;
  91. _History.pushState({content:json.return}, json.keys, path);
  92. $('input[name=location]','#feedback-form').attr('value', path);
  93. for (language in Drupal.settings.materio_search_api_ajax.languages) {
  94. var l = Drupal.settings.materio_search_api_ajax.languages[language];
  95. $('#block-locale-language li.'+language+' a').attr('href', Drupal.settings.basePath + l.prefix+'/' + json.search_path + '/' + json.keys)
  96. };
  97. var event = jQuery.Event('resultschanged');
  98. event.container = $('.search-results', _$content);
  99. $.event.trigger(event);
  100. }else{
  101. trace('no results');
  102. }
  103. };
  104. /**
  105. * infinit scroll
  106. */
  107. function loadNextResultsPage(){
  108. var $nextpage = $('ul.pager .pager-current', _$content).next(),
  109. href = $('a', $nextpage).attr('href');
  110. if(href){
  111. var keys = href.match(/explore\/([^\/|\?]+)/);
  112. var page = href.match(/\?page=([0-9]+)/);
  113. if(!_isloadingresults){
  114. _isloadingresults = true;
  115. $('.materiobase-results', _$content).addClass('loading');
  116. $.getJSON('/materio_search_api_ajax/search/'+keys[1]+'/'+page[1], function(json){
  117. // trace('json', json);
  118. _isloadingresults = false;
  119. $('.materiobase-results', _$content).removeClass('loading');
  120. addNextpage(json);
  121. });
  122. }
  123. }
  124. };
  125. function addNextpage(json){
  126. var $newcontent = $(json.return),
  127. $newresults = $('.search-results', $newcontent).children('article').addClass('just-added'),
  128. $newpager = $('ul.pager', $newcontent);
  129. $('.search-results', _$content).append($newresults);
  130. $('ul.pager', _$content).replaceWith($newpager);
  131. $('.search-results', _$content).children('.just-added').each(function(i){
  132. // $(this).delay(5000*i).removeClass('just-added');
  133. var $this = $(this);
  134. setTimeout(function(){
  135. $this.removeClass('just-added');
  136. }, 150*i);
  137. });
  138. var event = jQuery.Event('resultscompleted');
  139. event.container = $('.search-results', _$content);
  140. $(window).trigger(event);
  141. };
  142. /**
  143. * history navigation
  144. */
  145. function initHistoryNav(){
  146. var state = _History.getState();
  147. _History.log('initial:', state.data, state.title, state.url);
  148. _History.Adapter.bind(window,'statechange',function(){
  149. var state = _History.getState();
  150. _History.log('statechange:', state.data, state.title, state.url);
  151. // TODO: History : empty content if we go back to the homepage
  152. $('.inner-content',_$content).html(state.data.content);
  153. });
  154. };
  155. /**
  156. * viewmode
  157. */
  158. function initViewMode(){
  159. $('.viewmode-link').click(function(event){
  160. changeViewMode($(this).attr('rel'), $(this));
  161. });
  162. };
  163. function changeViewMode(vm, $btn){
  164. $.getJSON(Drupal.settings.basePath+'materio_search_api_ajax/viewmode/change/'+vm, function(json){
  165. trace('viewmode json', json);
  166. if (json.statut == "saved"){
  167. loadResults(getSearchKeys());
  168. $('.viewmode-link').removeClass('active');
  169. $btn.addClass('active');
  170. }
  171. });
  172. };
  173. init();
  174. };
  175. var materiosearchapiajax = new MaterioSearchApiAjax();
  176. })(jQuery);