Forward-porting r15845: Fixing broken multi-question surveys
authormiker <miker@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Tue, 16 Mar 2010 16:37:31 +0000 (16:37 +0000)
committermiker <miker@dcc99617-32d9-48b4-a31d-7c20da2025e4>
Tue, 16 Mar 2010 16:37:31 +0000 (16:37 +0000)
git-svn-id: svn://svn.open-ils.org/ILS/trunk@15869 dcc99617-32d9-48b4-a31d-7c20da2025e4

Open-ILS/xul/staff_client/server/patron/info_surveys.xul
Open-ILS/xul/staff_client/server/patron/ue_ui.js

index 632d997..5787a96 100644 (file)
             retrieve_surveys(); render_surveys();
         }
 
-        function retrieve_surveys() {
-            try {
-                var surveys = g.data.list.my_asv;
-                g.survey_responses = {};
-                for (var i = 0; i < surveys.length; i++) {
-                    var responses = g.network.simple_request(
-                        'FM_ASVR_RETRIEVE',
-                        [ ses(), surveys[i].id(), g.patron_id ]
-                    );
-                    g.survey_responses[ surveys[i].id() ] = responses;
-                }
-            } catch(E) {
-                g.error.standard_unexpected_error_alert($("patronStrings").getString('staff.patron.info_surveys.retrieve_surveys.failed'),E);
-            }
+               function retrieve_surveys() {
+                       try {
+                               var surveys = g.data.list.my_asv;
+                               g.survey_responses = {};
+                               for (var i = 0; i < surveys.length; i++) {
+                                       var responses = g.network.simple_request(
+                                               'FM_ASVR_RETRIEVE',
+                                               [ ses(), surveys[i].id(), g.patron_id ]
+                                       );
+                                       g.survey_responses[ surveys[i].id() ] = {};
+                                       for (var j = 0; j < responses.length; j++) {
+                                               if (! g.survey_responses[ responses[j].survey() ]) {
+                                                       g.survey_responses[ responses[j].survey() ] = {};
+                                               }
+                                               if (! g.survey_responses[ responses[j].survey() ][ responses[j].question() ]) {
+                                                       g.survey_responses[ responses[j].survey() ][ responses[j].question() ] = [];
+                                               }
+                                               g.survey_responses[ responses[j].survey() ][ responses[j].question() ].push( responses[j] );
+                                       }
+                               }
+                       } catch(E) {
+                               g.error.standard_unexpected_error_alert($("patronStrings").getString('staff.patron.info_surveys.retrieve_surveys.failed'),E);
+                       }
 
         }
 
         function render_surveys() {
             JSAN.use('util.widgets'); util.widgets.remove_children('surveys_panel');
             var sp = $('surveys_panel');
-
-            for (var i in g.survey_responses) {
-
-                /* template */
-                var asv_node = $('asv_template').cloneNode(true); sp.appendChild(asv_node); asv_node.hidden = false;
-                apply(asv_node,'id',g.data.hash.asv[i].id());
-                apply(asv_node,'description',g.data.hash.asv[i].description());
-                if (g.data.hash.asv[i].required()) {
-                    apply(asv_node, 'required', $("patronStrings").getString('staff.patron.info_surveys.render_surveys.required'));
-                } else {
-                    apply(asv_node, 'required', $("patronStrings").getString('staff.patron.info_surveys.render_surveys.not_required'));
-                }
-                if (g.data.hash.asv[i].opac()) {
-                    apply(asv_node, 'opac', $("patronStrings").getString('staff.patron.info_stat_cats.render_stat_cats.opac_visible'));
-                } else {
-                    apply(asv_node, 'opac', $("patronStrings").getString('staff.patron.info_stat_cats.render_stat_cats.not_opac_visible'));
-                }
+                       for (var survey_id in g.survey_responses) {
+
+                               /* template */
+                               var asv_node = $('asv_template').cloneNode(true); sp.appendChild(asv_node); asv_node.hidden = false;
+                               apply(asv_node,'id',g.data.hash.asv[survey_id].id());
+                               apply(asv_node,'description',g.data.hash.asv[survey_id].description());
+                               if (g.data.hash.asv[survey_id].required()) {
+                                       apply(asv_node, 'required', $("patronStrings").getString('staff.patron.info_surveys.render_surveys.required'));
+                               } else {
+                                       apply(asv_node, 'required', $("patronStrings").getString('staff.patron.info_surveys.render_surveys.not_required'));
+                               }
+                               if (g.data.hash.asv[survey_id].opac()) {
+                                       apply(asv_node, 'opac', $("patronStrings").getString('staff.patron.info_stat_cats.render_stat_cats.opac_visible'));
+                               } else {
+                                       apply(asv_node, 'opac', $("patronStrings").getString('staff.patron.info_stat_cats.render_stat_cats.not_opac_visible'));
+                               }
 
                 var nl = asv_node.getElementsByAttribute('name','questions');
                 var question_placeholder;
                 if (nl.length>0) question_placeholder = nl[0];
                 if (question_placeholder) {
 
-                    var questions = g.data.hash.asv[i].questions();
-                    for (var j = 0; j < questions.length; j++) {
+                                       var questions = g.data.hash.asv[survey_id].questions();
+                                       for (var j = 0; j < questions.length; j++) {
 
                         /* template */
                         var asvq_node = $('asvq_template').cloneNode(true);
                         apply(asvq_node,'ordinal',j+1);
                         apply(asvq_node,'question',questions[j].question());
 
-                        var nl2 = asvq_node.getElementsByAttribute('name','answer');
-                        var answer_placeholder;
-                        if (nl2.length>0) answer_placeholder = nl2[0];
-                        if (answer_placeholder && g.survey_responses[i].length > 0) {
+                                               var nl2 = asvq_node.getElementsByAttribute('name','answer');
+                                               var answer_placeholder;
+                                               if (nl2.length>0) answer_placeholder = nl2[0];
+                                               if (answer_placeholder && g.survey_responses[survey_id]) {
 
                             /* template */
                             var asva_node = $('asva_template').cloneNode(true); answer_placeholder.appendChild(asva_node); asva_node.hidden = false;
 
-                            var last_response = g.survey_responses[i][ g.survey_responses[i].length - 1 ];
-                            var date = last_response.effective_date() ? last_response.effective_date() : last_response.answer_date();
-                            date = util.date.formatted_date( date, '%D' );
-                            var answer = util.functional.find_id_object_in_list( questions[j].answers(), last_response.answer() );
-
+                                                       var question_responses = g.survey_responses[survey_id][ questions[j].id() ];
+                                                       if (!question_responses || question_responses.length < 1) { continue; }
+                                                       var last_response = question_responses[ question_responses.length - 1 ];
+                                                       var date = last_response.effective_date() ? last_response.effective_date() : last_response.answer_date();
+                                                       date = util.date.formatted_date( date, '%D' );
+                                                       var answer = util.functional.find_id_object_in_list( questions[j].answers(), last_response.answer() );
                             apply(asva_node,'answer',answer.answer());
                             apply(asva_node,'date',date);
                         }
index 4bf4967..e9a8202 100644 (file)
@@ -216,9 +216,11 @@ function uEditInsertCat( row, cat, idx ) {
 /* draw the surveys */
 function uEditDrawSurveys(surveys) {
 
-    var div = $('uedit_surveys');
-    var table = div.removeChild($('ue_survey_table'));
-    if( surveys.length == 0 ) unHideMe($('uedit_no_surveys'));
+       patron.survey_responses([]); /* clear out all surveys up front */
+
+       var div = $('uedit_surveys');
+       var table = div.removeChild($('ue_survey_table'));
+       if( surveys.length == 0 ) unHideMe($('uedit_no_surveys'));
 
     for( var s in surveys ) {
         var survey = surveys[s];
@@ -265,14 +267,14 @@ function uEditInsertSurveyQuestion( row, survey, question ) {
 
     selector.onchange = function() {
 
-        /* remove any existing responses for this survey */
-        patron.survey_responses(
-            grep( patron.survey_responses(),
-                function(item) {
-                    return (item.survey() != survey.id());
-                }
-            )
-        );
+               /* remove any existing responses for this question */
+               patron.survey_responses(
+                       grep( patron.survey_responses(),
+                               function(item) {
+                                       return (item.question() != row.getAttribute('question'));
+                               }
+                       )
+               );
 
 
         if(!patron.survey_responses())