From 8389ea71b84bd20f4a2d68903b87f8db1e40acf0 Mon Sep 17 00:00:00 2001 From: phasefx Date: Tue, 17 Nov 2009 04:52:34 +0000 Subject: [PATCH] wired up patron editor for staged patron list; some refactoring git-svn-id: svn://svn.open-ils.org/ILS/trunk@14935 dcc99617-32d9-48b4-a31d-7c20da2025e4 --- .../server/locale/en-US/patron.properties | 1 + Open-ILS/xul/staff_client/server/patron/staged.js | 130 ++++++++++++++------- 2 files changed, 91 insertions(+), 40 deletions(-) diff --git a/Open-ILS/xul/staff_client/server/locale/en-US/patron.properties b/Open-ILS/xul/staff_client/server/locale/en-US/patron.properties index 69a26800ae..8a436bc957 100644 --- a/Open-ILS/xul/staff_client/server/locale/en-US/patron.properties +++ b/Open-ILS/xul/staff_client/server/locale/en-US/patron.properties @@ -318,6 +318,7 @@ staff.patron.summary.patron_net_access=Internet staff.patron.summary.expires_on=Expires on staff.patron.summary.standing_penalty.remove=Remove staff.patron.summary.standing_penalty.none=No Blocks/Penalties +staff.patron.staged.register_patron=Registering Staged Patron: %1$s staff.patron.standing_penalty.apply_error=Error applying %1$s block/standing penalty. staff.patron.standing_penalty.remove_error=Error removing %1$s block/standing penalty. staff.patron.standing_penalty.update_error=Error updating block/standing penalty. diff --git a/Open-ILS/xul/staff_client/server/patron/staged.js b/Open-ILS/xul/staff_client/server/patron/staged.js index b9f0aae547..37b42b6187 100644 --- a/Open-ILS/xul/staff_client/server/patron/staged.js +++ b/Open-ILS/xul/staff_client/server/patron/staged.js @@ -53,47 +53,12 @@ function gen_event_handler(method) { // cancel or load? return function(ev) { try { var sel = list.retrieve_selection(); - var ids = util.functional.map_list( sel, function(o) { return JSON2js( o.getAttribute('retrieve_id') ); } ); + var ids = util.functional.map_list( sel, function(o) { return o.getAttribute('retrieve_id'); } ); if (method == 'cancel') { - - var pm = $('progress'); pm.value = 0; pm.hidden = false; - var idx = -1; - - fieldmapper.standardRequest( - [ api['FM_STGU_CANCEL'].app, api['FM_STGU_CANCEL'].method ], - { async: true, - params: [ses(), ids], - onresponse: function(r) { - try { - idx++; pm.value = Number( pm.value ) + 100/ids.length; - var result = openils.Util.readResponse(r); - if (typeof result.ilsevent != 'undefined') { throw(result); } - } catch(E) { - error.standard_unexpected_error_alert('In patron/staged.js, handle_'+i+'_event onresponse.',E); - } - }, - onerror: function(r) { - try { - var result = openils.Util.readResponse(r); - throw(result); - } catch(E) { - error.standard_unexpected_error_alert('In patron/staged.js, handle_'+i+'_event onerror.',E); - } - pm.hidden = true; pm.value = 0; populate_list(); - }, - oncomplete: function(r) { - try { - var result = openils.Util.readResponse(r); - } catch(E) { - error.standard_unexpected_error_alert('In patron/staged.js, handle_'+i+'_event oncomplete.',E); - } - pm.hidden = true; pm.value = 0; populate_list(); - } - } - ); + cancel( ids ); } else { - // load + load( ids ); } } catch(E) { @@ -102,6 +67,91 @@ function gen_event_handler(method) { // cancel or load? }; } +function cancel(ids) { + try { + var pm = $('progress'); pm.value = 0; pm.hidden = false; + var idx = -1; + + fieldmapper.standardRequest( + [ api['FM_STGU_CANCEL'].app, api['FM_STGU_CANCEL'].method ], + { async: true, + params: [ses(), ids], + onresponse: function(r) { + try { + idx++; pm.value = Number( pm.value ) + 100/ids.length; + var result = openils.Util.readResponse(r); + if (typeof result.ilsevent != 'undefined') { throw(result); } + } catch(E) { + error.standard_unexpected_error_alert('In patron/staged.js, handle_'+i+'_event onresponse.',E); + } + }, + onerror: function(r) { + try { + var result = openils.Util.readResponse(r); + throw(result); + } catch(E) { + error.standard_unexpected_error_alert('In patron/staged.js, handle_'+i+'_event onerror.',E); + } + pm.hidden = true; pm.value = 0; populate_list(); + }, + oncomplete: function(r) { + try { + var result = openils.Util.readResponse(r); + } catch(E) { + error.standard_unexpected_error_alert('In patron/staged.js, handle_'+i+'_event oncomplete.',E); + } + pm.hidden = true; pm.value = 0; populate_list(); + } + } + ); + } catch(E) { + alert('Error in staged.js, cancel(): ' + E); + } +} + +function spawn_search(s) { + data.stash_retrieve(); + xulG.new_patron_tab( {}, { 'doit' : 1, 'query' : s } ); +} + +function spawn_editor(p) { + var url = urls.XUL_PATRON_EDIT; + var loc = xulG.url_prefix( urls.XUL_REMOTE_BROWSER ); + xulG.new_tab( + loc, + {}, + { + 'url' : url, + 'show_print_button' : true , + 'tab_name' : $("patronStrings").getFormattedString('staff.patron.staged.register_patron',[p.stage]), + 'passthru_content_params' : { + 'spawn_search' : spawn_search, + 'spawn_editor' : spawn_editor, + 'url_prefix' : xulG.url_prefix, + 'new_tab' : xulG.new_tab, + 'new_patron_tab' : xulG.new_patron_tab, + 'params' : p + } + } + ); +} + +function load( ids ) { + try { + var seen = {}; + + for (var i = 0; i < ids.length; i++) { + if (! seen[ ids[i] ]) { + seen[ ids[i] ] = true; + spawn_editor( { 'stage' : ids[i] } ); + } + } + + } catch(E) { + alert('Error in staged.js, load(): ' + E); + } +} + function init_list() { try { @@ -127,7 +177,7 @@ function init_list() { function retrieve_row(params) { // callback function for fleshing rows in a list try { - params.row_node.setAttribute('retrieve_id',params.row.my.stgu.row_id()); + params.row_node.setAttribute('retrieve_id',params.row.my.stgu.usrname()); params.on_retrieve(params.row); } catch(E) { alert('Error in staged.js, retrieve_row(): ' + E); @@ -161,7 +211,7 @@ function populate_list() { } } }; - rows[ blob.user.row_id() ] = list.append( row_params ); + rows[ blob.user.usrname() ] = list.append( row_params ); } function onError(r) { -- 2.11.0