From bd9fc8a16fa8d84176e2fbc065bd7ea7ea9295aa Mon Sep 17 00:00:00 2001 From: Galen Charlton Date: Mon, 23 May 2022 19:06:48 -0400 Subject: [PATCH] LP#1930617: reduce parallel requests initiated by AngularJS holdings editor This patch decreases the number of parallel requests spawned by the AngularJS holdings editor. This can reduce load on open-ils.pcrud when the editor is used to handle a large number of items in one batch. This patch takes the following approaches: - the fetching of call number affixes now only makes one request per relevant org unit - item alerts are now retrieved via fleshing when the batch of items is requested (as opposed to doing a PCRUD request for each copy) - fetching monograph parts is now done serially To test ------- [1] Apply the patch. [2] Create a bucket with a few hundred items and edit all of them in the AngularJS holdings editor (which is what you get when you edit items from the bucket interface). [3] Verify that the editing loads itself without causing errors or PCRUD drone spikes. [4] Verify that item alerts and monograph parts are loaded [5] Verify that the call number prefix and suffix drop-downs are correctly populated. [6] Verify that copy alerts can be attached to newly-created items and saved. Signed-off-by: Galen Charlton Signed-off-by: Jeff Davis --- .../web/js/ui/default/staff/cat/volcopy/app.js | 97 +++++++++++++++------- 1 file changed, 68 insertions(+), 29 deletions(-) diff --git a/Open-ILS/web/js/ui/default/staff/cat/volcopy/app.js b/Open-ILS/web/js/ui/default/staff/cat/volcopy/app.js index 3a479b7069..feb28bc054 100644 --- a/Open-ILS/web/js/ui/default/staff/cat/volcopy/app.js +++ b/Open-ILS/web/js/ui/default/staff/cat/volcopy/app.js @@ -116,12 +116,34 @@ function(egCore , $q) { }); }; + var _acnp_promises = {}; + var _acnp_cache = {}; service.get_prefixes = function(org) { - return egCore.pcrud.search('acnp', - {owning_lib : egCore.org.fullPath(org, true)}, - {order_by : { acnp : 'label_sortkey' }}, {atomic : true} - ); + var _org_id; + if (angular.isObject(org)) { + _org_id = org.id(); + } else { + _org_id = org; + } + + if (!(_org_id in _acnp_promises)) { + _acnp_promises[_org_id] = $q.defer(); + + if (_org_id in _acnp_cache) { + $_acnp_promises[_org_id].resolve(_acnp_cache[_org_id]); + } else { + egCore.pcrud.search('acnp', + {owning_lib : egCore.org.fullPath(org, true)}, + {order_by : { acnp : 'label_sortkey' }}, {atomic : true} + ).then(function(list) { + _acnp_cache[_org_id] = list; + _acnp_promises[_org_id].resolve(list); + }); + } + } + + return _acnp_promises[_org_id].promise; }; service.get_statcats = function(orgs) { @@ -145,13 +167,6 @@ function(egCore , $q) { ); }; - service.get_copy_alerts = function(copy_id) { - return egCore.pcrud.search('aca', { copy : copy_id, ack_time : null }, - { flesh : 1, flesh_fields : { aca : ['alert_type'] } }, - { atomic : true } - ); - }; - service.get_locations_by_org = function(orgs) { return egCore.pcrud.search('acpl', {owning_lib : orgs, deleted : 'f'}, @@ -180,12 +195,34 @@ function(egCore , $q) { ); }; + var _acns_promises = {}; + var _acns_cache = {}; service.get_suffixes = function(org) { - return egCore.pcrud.search('acns', - {owning_lib : egCore.org.fullPath(org, true)}, - {order_by : { acns : 'label_sortkey' }}, {atomic : true} - ); + var _org_id; + if (angular.isObject(org)) { + _org_id = org.id(); + } else { + _org_id = org; + } + + if (!(_org_id in _acns_promises)) { + _acns_promises[_org_id] = $q.defer(); + + if (_org_id in _acns_cache) { + $_acns_promises[_org_id].resolve(_acns_cache[_org_id]); + } else { + egCore.pcrud.search('acns', + {owning_lib : egCore.org.fullPath(org, true)}, + {order_by : { acns : 'label_sortkey' }}, {atomic : true} + ).then(function(list) { + _acns_cache[_org_id] = list; + _acns_promises[_org_id].resolve(list); + }); + } + } + + return _acns_promises[_org_id].promise; }; service.get_magic_statuses = function() { @@ -266,19 +303,24 @@ function(egCore , $q) { }; service.bmp_parts = {}; + var _bmp_chain = $q.when(); // use a promise chain to serialize + // the requests service.get_parts = function(rec) { if (service.bmp_parts[rec]) return $q.when(service.bmp_parts[rec]); - return egCore.pcrud.search('bmp', - {record : rec, deleted : 'f'}, - {order_by: {bmp : 'label_sortkey DESC'}}, - {atomic : true} - ).then(function(list) { - service.bmp_parts[rec] = list; - return list; + var deferred = $q.defer(); + _bmp_chain = _bmp_chain.then(function() { + return egCore.pcrud.search('bmp', + {record : rec, deleted : 'f'}, + {order_by: {bmp : 'label_sortkey DESC'}}, + {atomic : true} + ).then(function(list) { + service.bmp_parts[rec] = list; + deferred.resolve(list); + }); }); - + return deferred.promise; }; service.get_acp_templates = function() { @@ -395,9 +437,10 @@ function(egCore , $q) { service.flesh = { flesh : 3, flesh_fields : { - acp : ['call_number','parts','stat_cat_entries', 'notes', 'tags', 'creator', 'editor'], + acp : ['call_number','parts','stat_cat_entries', 'notes', 'tags', 'creator', 'editor', 'copy_alerts'], acn : ['label_class','prefix','suffix'], - acptcm : ['tag'] + acptcm : ['tag'], + aca : ['alert_type'] } } @@ -405,10 +448,6 @@ function(egCore , $q) { if (!cp.parts()) cp.parts([]); // just in case... - service.get_copy_alerts(cp.id()).then(function(aca) { - cp.copy_alerts(aca); - }); - var lib = cp.call_number().owning_lib(); var cn = cp.call_number().id(); -- 2.11.0