From c342f827d192fb7660fdce221d45ac8f38b30851 Mon Sep 17 00:00:00 2001 From: Bart Mesuere Date: Sun, 12 Nov 2023 16:39:57 +0100 Subject: [PATCH] handle the case where there are no groups --- .../renderers/feedback_table_renderer.rb | 22 ++++++++++--------- 1 file changed, 12 insertions(+), 10 deletions(-) diff --git a/app/helpers/renderers/feedback_table_renderer.rb b/app/helpers/renderers/feedback_table_renderer.rb index 067c428a59..a7647888f7 100644 --- a/app/helpers/renderers/feedback_table_renderer.rb +++ b/app/helpers/renderers/feedback_table_renderer.rb @@ -145,21 +145,23 @@ def tab_content(t, tab_i) @diff_type = determine_tab_diff_type(t) show_hide_correct = show_hide_correct_switch t show_diff_type = show_diff_type_switch t - groups_correct = t[:groups].count { |g| g[:accepted] } - groups_total = t[:groups].count + groups_correct = t[:groups]&.count { |g| g[:accepted] } || 0 + groups_total = t[:groups]&.count || 0 expand_all = groups_correct == groups_total @builder.div(class: 'feedback-table-options sticky') do # summary of tests @builder.div(class: 'tab-summary') do - @builder.span(class: 'tab-summary-text') do - @builder.text! "#{groups_correct}/#{groups_total} #{I18n.t('submissions.show.correct_group').downcase}:" - end - @builder.div(class: 'tab-summary-icons') do - t[:groups]&.each_with_index do |g, i| - @builder.div(class: g[:accepted] ? 'correct' : 'wrong') do - @builder.a(href: "#tab-#{tab_i + 1}-group-#{i + 1}", title: "##{i + 1}") do - @builder.i(class: "mdi mdi-12 #{g[:accepted] ? 'mdi-check' : 'mdi-close'}") {} + if groups_total > 0 + @builder.span(class: 'tab-summary-text') do + @builder.text! "#{groups_correct}/#{groups_total} #{I18n.t('submissions.show.correct_group').downcase}:" + end + @builder.div(class: 'tab-summary-icons') do + t[:groups]&.each_with_index do |g, i| + @builder.div(class: g[:accepted] ? 'correct' : 'wrong') do + @builder.a(href: "#tab-#{tab_i + 1}-group-#{i + 1}", title: "##{i + 1}") do + @builder.i(class: "mdi mdi-12 #{g[:accepted] ? 'mdi-check' : 'mdi-close'}") {} + end end end end