From da3a453442050482a419deff91d3dc92fdbf132a Mon Sep 17 00:00:00 2001 From: berick Date: Wed, 4 May 2011 17:15:03 -0400 Subject: [PATCH] Best Match w/ quality ratio merging * Mew Best Match option in merge/overlay * support for upload time minimum record quality ratio * We now /only/ create new records if no matches exist and the user selected a match-free import * Selecting a match-free import no longer trumps other merge imports. They both work together now. TODO: find out why queued record quality is not getting set at queued rec creation time. --- .../perlmods/lib/OpenILS/Application/Vandelay.pm | 38 ++++++++++++++- Open-ILS/src/sql/Pg/950.data.seed-values.sql | 1 + Open-ILS/web/js/ui/default/vandelay/vandelay.js | 57 ++++++++++++++++------ Open-ILS/web/opac/locale/en-US/vandelay.dtd | 1 + .../web/templates/default/vandelay/inc/matches.tt2 | 2 +- .../web/templates/default/vandelay/inc/upload.tt2 | 7 ++- 6 files changed, 86 insertions(+), 20 deletions(-) diff --git a/Open-ILS/src/perlmods/lib/OpenILS/Application/Vandelay.pm b/Open-ILS/src/perlmods/lib/OpenILS/Application/Vandelay.pm index 510d6bf498..759a624d14 100644 --- a/Open-ILS/src/perlmods/lib/OpenILS/Application/Vandelay.pm +++ b/Open-ILS/src/perlmods/lib/OpenILS/Application/Vandelay.pm @@ -708,11 +708,15 @@ sub import_record_list_impl { my $auto_overlay_exact = $$args{auto_overlay_exact}; my $auto_overlay_1match = $$args{auto_overlay_1match}; + my $auto_overlay_best = $$args{auto_overlay_best_match}; + my $match_quality_ratio = $$args{match_quality_ratio}; my $merge_profile = $$args{merge_profile}; my $bib_source = $$args{bib_source}; + my $import_no_match = $$args{import_no_match}; my $overlay_func = 'vandelay.overlay_bib_record'; my $auto_overlay_func = 'vandelay.auto_overlay_bib_record'; + my $auto_overlay_best_func = 'vandelay.auto_overlay_bib_record_with_best'; # XXX bib-only my $retrieve_func = 'retrieve_vandelay_queued_bib_record'; my $update_func = 'update_vandelay_queued_bib_record'; my $search_func = 'search_vandelay_queued_bib_record'; @@ -863,7 +867,39 @@ sub import_record_list_impl { } } - if(!$imported and !$error) { + if(!$imported and !$error and $auto_overlay_best and scalar(@{$rec->matches}) > 0 ) { + + # caller says to overlay the best match + + my $res = $e->json_query( + { + from => [ + $auto_overlay_best_func, + $rec->id, + $merge_profile, + $match_quality_ratio + ] + } + ); + + if($res and ($res = $res->[0])) { + + if($res->{$auto_overlay_best_func} eq 't') { + $logger->info("vl: $type auto-overlay-best succeeded for queued rec " . $rec->id); + $imported = 1; + } else { + $report_args{import_error} = 'overlay.record.quality' if $match_quality_ratio > 0; + $logger->info("vl: $type auto-overlay-best failed for queued rec " . $rec->id); + } + + } else { + $error = 1; + $logger->error("vl: Error attempting overlay with func=$auto_overlay_best_func, ". + "quality_ratio=$match_quality_ratio, profile=$merge_profile, record=$rec_id"); + } + } + + if(!$imported and !$error and $import_no_match and scalar(@{$rec->matches}) == 0) { # No overlay / merge occurred. Do a traditional record import by creating a new record diff --git a/Open-ILS/src/sql/Pg/950.data.seed-values.sql b/Open-ILS/src/sql/Pg/950.data.seed-values.sql index e45999df88..0ad9ad0452 100644 --- a/Open-ILS/src/sql/Pg/950.data.seed-values.sql +++ b/Open-ILS/src/sql/Pg/950.data.seed-values.sql @@ -8667,6 +8667,7 @@ INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'overlay.missin INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'import.auth.duplicate.acn', oils_i18n_gettext('import.auth.duplicate.acn', 'Import failed due to Accession Number collision', 'vie', 'description') ); INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'import.xml.malformed', oils_i18n_gettext('import.xml.malformed', 'Malformed record cause Import failure', 'vie', 'description') ); INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'overlay.xml.malformed', oils_i18n_gettext('overlay.xml.malformed', 'Malformed record cause Overlay failure', 'vie', 'description') ); +INSERT INTO vandelay.import_error ( code, description ) VALUES ( 'overlay.record.quality', oils_i18n_gettext('overlay.record.quality', 'New record had insufficient quality', 'vie', 'description') ); INSERT INTO config.org_unit_setting_type ( name, label, description, datatype ) VALUES ( 'ui.cat.volume_copy_editor.horizontal', diff --git a/Open-ILS/web/js/ui/default/vandelay/vandelay.js b/Open-ILS/web/js/ui/default/vandelay/vandelay.js index 5b000b7737..4aeef8f9cb 100644 --- a/Open-ILS/web/js/ui/default/vandelay/vandelay.js +++ b/Open-ILS/web/js/ui/default/vandelay/vandelay.js @@ -974,7 +974,7 @@ function vlHandleQueueItemsAction(action) { queueItemsImportDialog.hide(); // hack to set the widgets the import funcs will be looking at. Reset them below. - vlUploadQueueAutoImport.attr('value', vlUploadQueueAutoImport2.attr('value')); + vlUploadQueueImportNoMatch.attr('value', vlUploadQueueImportNoMatch2.attr('value')); vlUploadQueueAutoOverlayExact.attr('value', vlUploadQueueAutoOverlayExact2.attr('value')); vlUploadQueueAutoOverlay1Match.attr('value', vlUploadQueueAutoOverlay1Match2.attr('value')); vlUploadMergeProfile.attr('value', vlUploadMergeProfile2.attr('value')); @@ -986,8 +986,8 @@ function vlHandleQueueItemsAction(action) { } // reset the widgets to prevent accidental future actions - vlUploadQueueAutoImport.attr('value', false); - vlUploadQueueAutoImport2.attr('value', false); + vlUploadQueueImportNoMatch.attr('value', false); + vlUploadQueueImportNoMatch2.attr('value', false); vlUploadQueueAutoOverlayExact.attr('value', false); vlUploadQueueAutoOverlayExact2.attr('value', false); vlUploadQueueAutoOverlay1Match.attr('value', false); @@ -1054,23 +1054,45 @@ function vlImportAllRecords() { function(){displayGlobalDiv('vl-queue-div');}); } -function vlImportRecordQueue(type, queueId, noMatchOnly, onload) { +function vlImportRecordQueue(type, queueId, onload) { displayGlobalDiv('vl-generic-progress-with-total'); var method = 'open-ils.vandelay.bib_queue.import'; - if(noMatchOnly) - method = method.replace('import', 'nomatch.import'); if(type == 'auth') method = method.replace('bib', 'auth'); + + var mergeOpt = false; var options = {}; + + if(vlUploadQueueImportNoMatch.checked) { + options.import_no_match = true; + vlUploadQueueImportNoMatch.checked = false; + } + if(vlUploadQueueAutoOverlayExact.checked) { options.auto_overlay_exact = true; vlUploadQueueAutoOverlayExact.checked = false; + mergeOpt = true; + } + + if(vlUploadQueueAutoOverlayBestMatch.checked) { + options.auto_overlay_best_match = true; + vlUploadQueueAutoOverlayBestMatch.checked = false; + options.match_quality_ratio = vlUploadQueueAutoOverlayBestMatchRatio.attr('value'); + mergeOpt = true; } if(vlUploadQueueAutoOverlay1Match.checked) { options.auto_overlay_1match = true; vlUploadQueueAutoOverlay1Match.checked = false; + mergeOpt = true; + } + + if(!mergeOpt) { + // in the interest of speed, if no merge options are + // chosen, tell the back-end code to only process records + // that have no matches + method = method.replace('.import', 'nomatch.import'); } var profile = vlUploadMergeProfile.attr('value'); @@ -1102,16 +1124,19 @@ function batchUpload() { currentType = dijit.byId('vl-record-type').getValue(); var handleProcessSpool = function() { - if(vlUploadQueueAutoImport.checked || vlUploadQueueAutoOverlayExact.checked || vlUploadQueueAutoOverlay1Match.checked) { - var noMatchOnly = !vlUploadQueueAutoOverlayExact.checked && !vlUploadQueueAutoOverlay1Match.checked; - vlImportRecordQueue( - currentType, - currentQueueId, - noMatchOnly, - function() { - retrieveQueuedRecords(currentType, currentQueueId, handleRetrieveRecords); - } - ); + if( + vlUploadQueueImportNoMatch.checked || + vlUploadQueueAutoOverlayExact.checked || + vlUploadQueueAutoOverlay1Match.checked || + vlUploadQueueAutoOverlayBestMatch.checked ) { + + vlImportRecordQueue( + currentType, + currentQueueId, + function() { + retrieveQueuedRecords(currentType, currentQueueId, handleRetrieveRecords); + } + ); } else { retrieveQueuedRecords(currentType, currentQueueId, handleRetrieveRecords); } diff --git a/Open-ILS/web/opac/locale/en-US/vandelay.dtd b/Open-ILS/web/opac/locale/en-US/vandelay.dtd index 48db0a658f..d2d1789d9b 100644 --- a/Open-ILS/web/opac/locale/en-US/vandelay.dtd +++ b/Open-ILS/web/opac/locale/en-US/vandelay.dtd @@ -6,6 +6,7 @@ + diff --git a/Open-ILS/web/templates/default/vandelay/inc/matches.tt2 b/Open-ILS/web/templates/default/vandelay/inc/matches.tt2 index 9cccbdb19f..40d6a80d82 100644 --- a/Open-ILS/web/templates/default/vandelay/inc/matches.tt2 +++ b/Open-ILS/web/templates/default/vandelay/inc/matches.tt2 @@ -15,7 +15,7 @@ formatter : vlFormatViewMatchMARC }, {name: 'Match Score', field:'match_score'}, - {name: 'Match Quality', field:'match_quality'}, + {name: 'Matched Record Quality', field:'match_quality'}, {name: '&vandelay.creator;', get: vlGetCreator}, {name: '&vandelay.create.date;', field:'create_date', get: vlGetDateTimeField}, {name: '&vandelay.last.edit.date;', field:'edit_date', get: vlGetDateTimeField}, diff --git a/Open-ILS/web/templates/default/vandelay/inc/upload.tt2 b/Open-ILS/web/templates/default/vandelay/inc/upload.tt2 index 8462ebc86a..f7421046fe 100644 --- a/Open-ILS/web/templates/default/vandelay/inc/upload.tt2 +++ b/Open-ILS/web/templates/default/vandelay/inc/upload.tt2 @@ -54,7 +54,7 @@ &vandelay.auto.import.noncolliding; - + @@ -75,7 +75,10 @@ &vandelay.auto.import.auto_overlay_best_ratio; - + + + (&vandelay.auto.import.auto_overlay_best_ratio.desc;) + -- 2.11.0