From: phasefx Date: Thu, 10 Aug 2006 20:37:13 +0000 (+0000) Subject: stash push of copy and other tweaks X-Git-Url: https://old-git.evergreen-ils.org/?a=commitdiff_plain;h=84c5dc74172fbaa5bec28fd72786e81e6d6e4437;p=evergreen%2Fpines.git stash push of copy and other tweaks git-svn-id: svn://svn.open-ils.org/ILS/trunk@5435 dcc99617-32d9-48b4-a31d-7c20da2025e4 --- diff --git a/Open-ILS/xul/staff_client/server/cat/copy_summary.xul b/Open-ILS/xul/staff_client/server/cat/copy_summary.xul index 2af0a11b54..dd1a35737d 100644 --- a/Open-ILS/xul/staff_client/server/cat/copy_summary.xul +++ b/Open-ILS/xul/staff_client/server/cat/copy_summary.xul @@ -51,60 +51,67 @@ JSAN.use('util.network'); g.network = new util.network(); JSAN.use('util.date'); JSAN.use('util.widgets'); JSAN.use('OpenILS.data'); g.data = new OpenILS.data(); g.data.stash_retrieve(); + var copy; + if (g.data.temp_copy) { + copy = g.data.temp_copy; g.data.temp_copy = null; g.data.stash('temp_copy'); + } - $('caption').setAttribute('tooltiptext','Copy ID = ' + copy_id); - - g.network.simple_request( - 'FM_ACP_RETRIEVE', - [ copy_id ], - function (req) { - try { - var copy = req.getResultObject(); - if (typeof copy.ilsevent != 'undefined') throw(copy); - g.network.simple_request( - 'FM_ACN_RETRIEVE', - [ copy.call_number() ], - function (rreq) { - try { - $w('barcode',copy.barcode()); - $w('ref',get_bool(copy.ref()) ? 'Yes' : 'No'); - $w('opac_visible',get_bool(copy.opac_visible()) ? 'Yes' : 'No'); - $w('circulate',get_bool(copy.circulate()) ? 'Yes' : 'No'); - $w('holdable',get_bool(copy.holdable()) ? 'Yes' : 'No'); - $w('age_protect',copy.age_protect() == null ? '' : ( typeof copy.age_protect() == 'object' ? copy.age_protect().name() : g.data.hash.crahp[ copy.age_protect() ].name() ) ); - $w('location',copy.location().name()); - $w('create_date',util.date.formatted_date(copy.create_date(),'%F')); - $w('edit_date',util.date.formatted_date(copy.edit_date(),'%F')); - $w('status',copy.status().name()); - } catch(E) { - g.error.standard_unexpected_error_alert('rendering copy',E); - } - try { - var cn = rreq.getResultObject(); - if (typeof cn.ilsevent != 'undefined') { - switch(cn.ilsevent) { - case 1508 /* ASSET_CALL_NUMBER_NOT_FOUND */ : - $w('callnumber','Not Cataloged'); - break; - default: - throw(cn); - break; - } - } else { - $w('callnumber',cn.label()); + $('caption').setAttribute('tooltiptext','Copy ID = ' + (copy_id || copy.id() ) ); + + function acp_callback(req) { + try { + var copy = req.getResultObject(); + if (typeof copy.ilsevent != 'undefined') throw(copy); + g.network.simple_request( + 'FM_ACN_RETRIEVE', + [ copy.call_number() ], + function (rreq) { + try { + $w('barcode',copy.barcode()); + $w('ref',get_bool(copy.ref()) ? 'Yes' : 'No'); + $w('opac_visible',get_bool(copy.opac_visible()) ? 'Yes' : 'No'); + $w('circulate',get_bool(copy.circulate()) ? 'Yes' : 'No'); + $w('holdable',get_bool(copy.holdable()) ? 'Yes' : 'No'); + $w('age_protect',copy.age_protect() == null ? '' : ( typeof copy.age_protect() == 'object' ? copy.age_protect().name() : g.data.hash.crahp[ copy.age_protect() ].name() ) ); + $w('location',typeof copy.location() == 'object' ? copy.location().name() : g.data.lookup('acpl',copy.location()).name() ); + $w('create_date',util.date.formatted_date(copy.create_date(),'%F')); + $w('edit_date',util.date.formatted_date(copy.edit_date(),'%F')); + $w('status',typeof copy.status() == 'object' ? copy.status().name() : g.data.hash.ccs[ copy.status() ].name() ); + } catch(E) { + g.error.standard_unexpected_error_alert('rendering copy',E); + } + try { + var cn = rreq.getResultObject(); + if (typeof cn.ilsevent != 'undefined') { + switch(cn.ilsevent) { + case 1508 /* ASSET_CALL_NUMBER_NOT_FOUND */ : + $w('callnumber','Not Cataloged'); + break; + default: + throw(cn); + break; } - } catch(E) { - g.error.standard_unexpected_error_alert('retrieving volume',E); + } else { + $w('callnumber',cn.label()); } + } catch(E) { + g.error.standard_unexpected_error_alert('retrieving volume',E); } - ); - } catch(E) { - g.error.standard_unexpected_error_alert('retrieving copy',E); - } + } + ); + } catch(E) { + g.error.standard_unexpected_error_alert('retrieving copy',E); } - ); + } + + if (copy_id) { + g.network.simple_request( 'FM_ACP_RETRIEVE', [ copy_id ], acp_callback); + } else { + acp_callback( { 'getResultObject' : function() { return copy; } } ); + copy_id = copy.id(); + } - g.network.simple_request('FM_CIRC_COUNT_RETRIEVE_VIA_COPY',[ g.copy_id ],function(req) { + g.network.simple_request('FM_CIRC_COUNT_RETRIEVE_VIA_COPY',[ copy_id ],function(req) { try { var robj = req.getResultObject(); if (typeof robj.ilsevent != 'undefined') throw(robj); @@ -114,8 +121,6 @@ } }); - - } catch(E) { var err_msg = "!! This software has encountered an error. Please tell your friendly " + "system administrator or software developer the following:\ncat/copy_summary.xul\n" + E + '\n';