X-Git-Url: http://git.indexdata.com/?a=blobdiff_plain;f=mkdru.client.js;h=352cae0523866ac91698d26f7708e336a87055e3;hb=f56694d19c033aa03d48a264705a7481e188957b;hp=86fcf50b39e542c5d3403d4f95712f4d33e71611;hpb=47606bbe03dc3004f1d98c59bc01d6ba12654008;p=mkdru-moved-to-drupal.org.git diff --git a/mkdru.client.js b/mkdru.client.js index 86fcf50..352cae0 100644 --- a/mkdru.client.js +++ b/mkdru.client.js @@ -7,6 +7,7 @@ var mkdru = { submitted: false, pz2: null, totalRec: 0, + pagerRange: 6, sourceMax: Drupal.settings.mkdru.source_max, subjectMax: Drupal.settings.mkdru.subject_max, authorMax: Drupal.settings.mkdru.author_max, @@ -18,48 +19,52 @@ var mkdru = { sort: 'relevance', filter: null, query:null, + recid:null }, - state: {}, + state: {} }; // So we can use jQuery BBQ with Drupal 6 and its 1.2.6 jQuery -if (!$.isArray) $.isArray = function( obj ) { - return toString.call(obj) === "[object Array]"; +if (!$.isArray) $.isArray = function(obj) { + return Object.prototype.toString.call(obj) === "[object Array]"; }, // pz2.js event handlers: mkdru.pz2Init = function () { - if (mkdru.state.query) mkdru.triggerSearch(); + if (mkdru.state.query) { + mkdru.search(); + } //mkdru.pz2.stat(); //mkdru.pz2.bytarget(); }; mkdru.pz2Show = function (data) { mkdru.totalRec = data.merged; - - var pagerHtml = Drupal.theme('mkdruPager', data, mkdru.state.page, - Math.ceil(mkdru.totalRec / mkdru.state.perpage)); - $('.mkdru-pager').html(pagerHtml); - $('.mkdru-next').bind('click', mkdru.nextPage); - $('.mkdru-prev').bind('click', mkdru.prevPage); - - var countsHtml = 'Displaying: ' + (data.start + 1) + ' to ' - + (data.start + data.num) + ' of ' + data.merged + ' (found: ' + data.total + ')'; + $('.mkdru-pager').html(mkdru.generatePager()); + var countsHtml = Drupal.t('Displaying: ') + (data.start + 1) + + Drupal.t(' to ') + (data.start + data.num) + Drupal.t(' of ') + + data.merged + Drupal.t(' (found: ') + data.total + ')'; $('.mkdru-counts').html(countsHtml); var html = ""; for (var i = 0; i < data.hits.length; i++) { html += Drupal.theme('mkdruResult', data.hits[i], - i + 1 + mkdru.state.perpage * - (mkdru.state.page - 1)); + i + 1 + mkdru.state.perpage * (mkdru.state.page - 1), + "#" + $.param.fragment($.param.fragment( + window.location.href, {recid: data.hits[i].recid})) + "\n" + ); } $('.mkdru-result-list').html(html); - $('.mkdru-result-title').bind('click', mkdru.requestDetail); - $('.mkdru-results').show(); + if (mkdru.state.recid) { + mkdru.pz2.record(mkdru.state.recid); + } + else { + $('.mkdru-results').show(); + } }; mkdru.pz2Status = function (data) { @@ -111,7 +116,7 @@ mkdru.pz2Record = function (data) { clearTimeout(mkdru.pz2.showTimer); $('.mkdru-results').hide(); $('.mkdru-detail').html(Drupal.theme('mkdruDetail', data)); - $('.mkdru-detail').bind('click', function () {$('.mkdru-detail').hide()}); + $('.mkdru-detail-back').bind('click', function () {$.bbq.removeState('recid');}); $('.mkdru-detail').show(); clearTimeout(mkdru.pz2.recordTimer); }; @@ -124,7 +129,6 @@ mkdru.pz2Record = function (data) { mkdru.stateFromObject = function (obj) { for (var key in mkdru.defaultState) { if (typeof(obj[key]) != "undefined") { - dump (key + " :: " + obj[key] + "\n"); mkdru.state[key] = obj[key]; } else { @@ -140,6 +144,7 @@ mkdru.stateFromHash = function () { // set current window's hash string from state mkdru.hashFromState = function () { + // only include non-default settings in the URL var alteredState = {}; for (var key in mkdru.defaultState) { if (mkdru.state[key] != mkdru.defaultState[key]) { @@ -167,42 +172,56 @@ mkdru.uiFromState = function () { }; mkdru.hashChange = function () { - dump("Submidded? " + mkdru.submitted + "\n"); + mkdru.stateFromHash(); + // Request for details + if (mkdru.state.recid) { + mkdru.pz2.record(mkdru.state.recid); + } + // Other internal link + else { + mkdru.pz2.showPage(mkdru.state.page-1); + $('.mkdru-detail').hide(); + $('.mkdru-results').show(); + } }; -// UI functions: +//search bo handler ONLY mkdru.submitQuery = function () { mkdru.state.query = $('.mkdru-search input:text').attr('value'); - mkdru.resetPage(); mkdru.pollDropDowns(); + mkdru.resetPage(); mkdru.hashFromState(); mkdru.search(); mkdru.submitted = true; return false; }; -mkdru.triggerSearch = function () { - mkdru.search(); - mkdru.submitted = true; -}; +//criteria drop-downs (perpage,sort) handler ONLY +mkdru.submitCriteria = function () { + mkdru.pollDropDowns(); + //search is not ON, do nothing + if (!mkdru.submitted) return false; + mkdru.resetPage(); + mkdru.hashFromState(); + mkdru.pz2.show(0, mkdru.state.perpage, mkdru.state.sort); + return false; +} mkdru.search = function () { - $('.mkdru-detail').hide(); mkdru.pz2.search(mkdru.state.query, mkdru.state.perpage, mkdru.state.sort, mkdru.state.filter); + //inform others that the search is ON + mkdru.submitted = true; }; mkdru.pollDropDowns = function () { mkdru.state.perpage = $('.mkdru-perpage').attr('value'); mkdru.state.sort = $('.mkdru-sort').attr('value'); - if (!mkdru.submitted) return false; - mkdru.resetPage(); - mkdru.pz2.show(0, mkdru.state.perpage, mkdru.state.sort); - return false; }; +//TODO it's rude to mess with user's query, we should have a breadcrumb mkdru.limitQuery = function (field, value) { $('.mkdru-search input:text').attr('value', function () { return this.value += ' and ' + field + '="' + value + '"'; @@ -217,37 +236,48 @@ mkdru.limitTarget = function (id, name) { + name + ''; navi.innerHTML += '
'; mkdru.state.filter = 'pz:id=' + id; - mkdru.resetPage(); mkdru.pollDropDowns(); + mkdru.resetPage(); + mkdru.hashFromState(); mkdru.search(); return false; }; -mkdru.resetPage = function () { - mkdru.state.page = 1; - mkdru.totalRec = 0; -}; - -mkdru.showPage = function (pageNum) { - mkdru.state.page = pageNum; - mkdru.pz2.showPage(pageNum-1); -}; - -mkdru.requestDetail = function (e) { - mkdru.pz2.record(e.target.parentNode.id.replace('rec_', '')); -}; +mkdru.generatePager = function () { + // make sure page param is a number, otherwise pageing frwd will be broken + if (typeof mkdru.state.page == "string") { + mkdru.state.page = Number(mkdru.state.page); + } + var total = Math.ceil(mkdru.totalRec / mkdru.state.perpage); + var first = (mkdru.state.page - mkdru.pagerRange > 0) + ? mkdru.state.page - mkdru.pagerRange : 1; + var last = first + 2 * mkdru.pagerRange < total + ? first + 2 * mkdru.pagerRange : total; + var prev = null; + var next = null; + var pages = []; + + if ((mkdru.state.page - 1) >= first) { + prev = "#" + $.param.fragment($.param.fragment( + window.location.href, {page: mkdru.state.page - 1})) + } + if ((mkdru.state.page + 1) <= total) { + next = "#" + $.param.fragment($.param.fragment( + window.location.href, {page: mkdru.state.page + 1})) + } -mkdru.nextPage = function () { - if (mkdru.totalRec - mkdru.state.perpage * mkdru.state.page > 0) { - mkdru.pz2.showNext(); - mkdru.state.page++; + for (var i = first; i <= last; i++) { + pages.push("#" + $.param.fragment($.param.fragment( + window.location.href, {page: i}))); } + + return Drupal.theme('mkdruPager', pages, first, mkdru.state.page, + total, prev, next); }; -mkdru.prevPage = function () { - if (mkdru.pz2.showPrev() != false) { - mkdru.state.page--; - } +mkdru.resetPage = function () { + mkdru.state.page = 1; + mkdru.totalRec = 0; }; @@ -258,10 +288,9 @@ $(document).ready(function () { $(window).bind( 'hashchange', mkdru.hashChange); $('.mkdru-search').bind('submit', mkdru.submitQuery); $('.mkdru-search input:text').attr('value', ''); - $('.mkdru-perpage').bind('change', function () { mkdru.pollDropDowns() }); - $('.mkdru-sort').bind('change', function () { mkdru.pollDropDowns() }); + $('.mkdru-perpage').bind('change', mkdru.submitCriteria); + $('.mkdru-sort').bind('change', mkdru.submitCriteria); - dump("NEW PZ2!\n"); mkdru.pz2 = new pz2( { "onshow": mkdru.pz2Show, "showtime": 500, //each timer (show, stat, term, bytarget) can be specified this way "pazpar2path": mkdru.pazpar2path, @@ -279,8 +308,7 @@ $(document).ready(function () { mkdru.stateFromHash(); // and update UI to match mkdru.uiFromState(); - dump("QUERY:" + mkdru.state.query + "\n"); - + // ting thing if (typeof(Drupal.settings.mkdru.query) !== "undefined") { mkdru.state.query = Drupal.settings.mkdru.query @@ -288,7 +316,11 @@ $(document).ready(function () { if (mkdru.usesessions) { mkdru.pz2.init(); - } else if (mkdru.state.query) { - mkdru.triggerSearch(); + } + else if (mkdru.state.recid) { + mkdru.pz2.record(mkdru.state.recid); + } + else if (mkdru.state.query) { + mkdru.search(); } });