From 8b295e674daff3f8204eb26a6f06f4920a022887 Mon Sep 17 00:00:00 2001 From: "G. Torres" Date: Wed, 30 Oct 2024 14:35:03 -0400 Subject: [PATCH] Refactored csv generation into a method --- app/controllers/stories_controller.rb | 47 ++++++++++----------------- 1 file changed, 18 insertions(+), 29 deletions(-) diff --git a/app/controllers/stories_controller.rb b/app/controllers/stories_controller.rb index 7db6aad9..57b78b05 100644 --- a/app/controllers/stories_controller.rb +++ b/app/controllers/stories_controller.rb @@ -87,44 +87,33 @@ def import end def export - csv = if params[:export_with_comments] == "1" - generate_csv_with_comments - else - generate_csv_without_comments - end + csv = generate_csv(params[:export_with_comments], params[:export_all]) filename = "#{@project.title.gsub(/[^\w]/, "_")}-#{Time.now.to_formatted_s(:short).tr(" ", "_")}.csv" send_data csv, filename: filename end - def generate_csv_with_comments - CSV.generate(headers: true) do |csv| - csv << CSV_HEADERS + ["comment"] - stories = if params.include?(:export_all) && params[:export_all] == "1" - @project.stories.includes(:comments) - else - @project.stories.includes(:comments).approved - end - stories.by_position.each do |story| - comments = [] - story.comments.each do |comment| - comments << "#{display_name(comment.user)}: #{comment.body}" - end - csv << [story.id, story.title, story.description, story.position] + comments - end + def generate_csv(with_comments, export_all) + stories = if with_comments == "1" && export_all == "1" + @project.stories.includes(:comments) + elsif with_comments == "1" + @project.stories.includes(:comments).approved + elsif export_all == "1" + @project.stories + else + @project.stories.approved end - end - def generate_csv_without_comments CSV.generate(headers: true) do |csv| - csv << CSV_HEADERS - stories = if params.include?(:export_all) && params[:export_all] == "1" - @project.stories - else - @project.stories.approved - end + csv << ((with_comments == "1") ? (CSV_HEADERS + ["comment"]) : CSV_HEADERS) stories.by_position.each do |story| - csv << story.attributes.slice(*CSV_HEADERS) + if with_comments == "1" + comments = [] + story.comments.each do |comment| + comments << "#{display_name(comment.user)}: #{comment.body}" + end + end + csv << ((with_comments == "1") ? ([story.id, story.title, story.description, story.position] + comments) : story.attributes.slice(*CSV_HEADERS)) end end end