From 6c6982b983381bc6344fff1b7fb6a39bd9af157c Mon Sep 17 00:00:00 2001 From: Brendan Lawlor Date: Fri, 14 Jun 2024 19:11:56 +0000 Subject: [PATCH] Bug 37077: Fix report mutli-select for zero and single selections This patch updates the javascript overriding the form submission when reports have multi select parameters. When there are more than one multi selects, and the user selcts one value from each, it skips updating the value of the select, so it doens't send duplicate parameters anymore. If there are no selections made it will pass '%' for all values. This allows the multi select to be optional in the report. If no selections are made it is assumed that you are not using that parameter to limit the report. Test plan: 1. Go to Reports and create a report from SQL select * from items where homebranch in <> and itype in <> 3. Run the report but pick only 1 library and 1 item type 4. Click the "Show SQL code" 5. Notice that the two parameters were filled correctly 6. Run the report again with zero selections 7. Click the "Show SQL code" 8. Notice that the '%' is used for the parameter 9. Run the report again with combinations of single, multiple and zero selections 10. confirm the SQL code is generated as you would expect. Signed-off-by: Pedro Amorim Signed-off-by: Marcel de Rooy Signed-off-by: Katrin Fischer --- .../prog/en/modules/reports/guided_reports_start.tt | 11 ++++++++--- 1 file changed, 8 insertions(+), 3 deletions(-) diff --git a/koha-tmpl/intranet-tmpl/prog/en/modules/reports/guided_reports_start.tt b/koha-tmpl/intranet-tmpl/prog/en/modules/reports/guided_reports_start.tt index e1db08685a..9dd38ba53b 100644 --- a/koha-tmpl/intranet-tmpl/prog/en/modules/reports/guided_reports_start.tt +++ b/koha-tmpl/intranet-tmpl/prog/en/modules/reports/guided_reports_start.tt @@ -877,7 +877,7 @@ [% IF (sql_param.select_multiple) %] [% END %] @@ -1584,8 +1584,13 @@ $('#report_param_form').on('submit', function(e) { $('#report_param_form').find('select[multiple]').each( function (i) { - var $selected = $('option:first', this).val(); - $(this).val($selected); + if( $(this).find('option:selected').length === 0 ) { + $(this).val(['%']); + } + else if( $(this).find('option:selected').length > 1 ) { + var $selected = $('option:first', this).val(); + $(this).val($selected); + } }); }); } -- 2.39.5