From 8b6962649c6d0dbbce950d3946d8ad9c10e45341 Mon Sep 17 00:00:00 2001 From: Bilka Date: Wed, 27 Nov 2024 14:14:46 +0100 Subject: [PATCH 01/10] AO3-6848 Create challenge_assignment_notification mailer preview --- app/mailers/user_mailer.rb | 10 ++-- app/models/challenge_assignment.rb | 6 ++- test/mailers/previews/user_mailer_preview.rb | 56 ++++++++++++++++++++ 3 files changed, 65 insertions(+), 7 deletions(-) diff --git a/app/mailers/user_mailer.rb b/app/mailers/user_mailer.rb index 0e487fb387d..82de6f82321 100644 --- a/app/mailers/user_mailer.rb +++ b/app/mailers/user_mailer.rb @@ -211,12 +211,10 @@ def challenge_assignment_notification(collection_id, assigned_user_id, assignmen @assigned_user = User.find(assigned_user_id) assignment = ChallengeAssignment.find(assignment_id) @request = (assignment.request_signup || assignment.pinch_request_signup) - I18n.with_locale(@assigned_user.preference.locale.iso) do - mail( - to: @assigned_user.email, - subject: default_i18n_subject(app_name: ArchiveConfig.APP_SHORT_NAME, collection_title: @collection.title) - ) - end + mail( + to: @assigned_user.email, + subject: default_i18n_subject(app_name: ArchiveConfig.APP_SHORT_NAME, collection_title: @collection.title) + ) end # Asks a user to validate and activate their new account diff --git a/app/models/challenge_assignment.rb b/app/models/challenge_assignment.rb index 80b37738451..714fecdf537 100755 --- a/app/models/challenge_assignment.rb +++ b/app/models/challenge_assignment.rb @@ -271,7 +271,11 @@ def send_out (self.pinch_hitter ? self.pinch_hitter.user : nil) end request = self.request_signup || self.pinch_request_signup - UserMailer.challenge_assignment_notification(collection.id, assigned_to.id, self.id).deliver_later if assigned_to && request + if assigned_to && request + I18n.with_locale(assigned_to.preference.locale.iso) do + UserMailer.challenge_assignment_notification(collection.id, assigned_to.id, self.id).deliver_later + end + end end end diff --git a/test/mailers/previews/user_mailer_preview.rb b/test/mailers/previews/user_mailer_preview.rb index 19ae2739bb0..29dba39644e 100644 --- a/test/mailers/previews/user_mailer_preview.rb +++ b/test/mailers/previews/user_mailer_preview.rb @@ -34,6 +34,62 @@ def feedback UserMailer.feedback(feedback.id) end + def challenge_assignment_notification_any + assignment = create(:challenge_assignment) + + signup = assignment.request_signup + signup.pseud = create(:user, :for_mailer_preview).default_pseud + signup.save! + + # Fill all tag fields with "Any" + prompt = signup.requests.first + TagSet::TAG_TYPES.each do |type| + prompt.send(:"any_#{type}=", true) + end + prompt.title = "This is a title" + prompt.save! + + UserMailer.challenge_assignment_notification(assignment.collection.id, assignment.offering_user.id, assignment.id) + end + + def challenge_assignment_notification_filled + assignment = create(:challenge_assignment) + + signup = assignment.request_signup + signup.pseud = create(:user, :for_mailer_preview).default_pseud + signup.save! + + challenge = assignment.collection.challenge + challenge.assignments_due_at = params[:due] ? params[:due].to_time : Time.current + challenge.save! + + # Allow up to 3 tags per type + request_restriction = challenge.request_restriction + TagSet::TAG_TYPES.each do |type| + request_restriction.send(:"#{type}_num_allowed=", 3) + end + request_restriction.save! + + # Tag set with 3 tags per type + tag_set = create(:tag_set, tags: []) + tag_set.archive_warning_tagnames = [ArchiveConfig.WARNING_VIOLENCE_TAG_NAME, ArchiveConfig.WARNING_DEATH_TAG_NAME, ArchiveConfig.WARNING_NONCON_TAG_NAME].join(ArchiveConfig.DELIMITER_FOR_OUTPUT) + tag_set.rating_tagnames = [ArchiveConfig.RATING_EXPLICIT_TAG_NAME, ArchiveConfig.RATING_MATURE_TAG_NAME, ArchiveConfig.RATING_TEEN_TAG_NAME].join(ArchiveConfig.DELIMITER_FOR_OUTPUT) + tag_set.category_tagnames = [ArchiveConfig.CATEGORY_GEN_TAG_NAME, ArchiveConfig.CATEGORY_HET_TAG_NAME, ArchiveConfig.CATEGORY_SLASH_TAG_NAME].join(ArchiveConfig.DELIMITER_FOR_OUTPUT) + %w(fandom character relationship freeform).each do |type| + tag_set.tags += [create(:"canonical_#{type}"), create(:"canonical_#{type}"), create(:"canonical_#{type}")] + end + tag_set.save! + + prompt = signup.requests.first + prompt.tag_set = tag_set + prompt.title = "This is a title" + prompt.url = "https://example.com/" + prompt.optional_tag_set = create(:tag_set, tags: [create(:freeform), create(:freeform), create(:freeform)]) + prompt.save! + + UserMailer.challenge_assignment_notification(assignment.collection.id, assignment.offering_user.id, assignment.id) + end + def claim_notification_registered work = create(:work) creator_id = work.pseuds.first.user.id From 18b850a9238d213d7f8f7ed87407fbcf5578d588 Mon Sep 17 00:00:00 2001 From: Bilka Date: Wed, 27 Nov 2024 15:38:18 +0100 Subject: [PATCH 02/10] AO3-6848 Use sent_at from assignment --- app/mailers/user_mailer.rb | 4 ++-- .../challenge_assignment_notification.html.erb | 2 +- .../challenge_assignment_notification.text.erb | 2 +- test/mailers/previews/user_mailer_preview.rb | 13 +++++++++---- 4 files changed, 13 insertions(+), 8 deletions(-) diff --git a/app/mailers/user_mailer.rb b/app/mailers/user_mailer.rb index 82de6f82321..90d2be7c251 100644 --- a/app/mailers/user_mailer.rb +++ b/app/mailers/user_mailer.rb @@ -209,8 +209,8 @@ def potential_match_generation_notification(collection_id, email) def challenge_assignment_notification(collection_id, assigned_user_id, assignment_id) @collection = Collection.find(collection_id) @assigned_user = User.find(assigned_user_id) - assignment = ChallengeAssignment.find(assignment_id) - @request = (assignment.request_signup || assignment.pinch_request_signup) + @assignment = ChallengeAssignment.find(assignment_id) + @request = (@assignment.request_signup || @assignment.pinch_request_signup) mail( to: @assigned_user.email, subject: default_i18n_subject(app_name: ArchiveConfig.APP_SHORT_NAME, collection_title: @collection.title) diff --git a/app/views/user_mailer/challenge_assignment_notification.html.erb b/app/views/user_mailer/challenge_assignment_notification.html.erb index 632e0e870f7..fe93bb90bfc 100644 --- a/app/views/user_mailer/challenge_assignment_notification.html.erb +++ b/app/views/user_mailer/challenge_assignment_notification.html.erb @@ -62,5 +62,5 @@ <% end %> <% content_for :sent_at do %> - <%= l(Time.now) %> + <%= l(@assignment.sent_at) %> <% end %> diff --git a/app/views/user_mailer/challenge_assignment_notification.text.erb b/app/views/user_mailer/challenge_assignment_notification.text.erb index 8cb06b561f4..9a7e7647897 100644 --- a/app/views/user_mailer/challenge_assignment_notification.text.erb +++ b/app/views/user_mailer/challenge_assignment_notification.text.erb @@ -44,4 +44,4 @@ <%= @collection.assignment_notification %><% end %><% end %> <% content_for :footer_note do %><%= t ".text.footer", title: @collection.title, url: collection_url(@collection), profile_url: collection_profile_url(@collection) %><% end %> -<% content_for :sent_at do %><%= l(Time.now) %><% end %> +<% content_for :sent_at do %><%= l(@assignment.sent_at) %><% end %> diff --git a/test/mailers/previews/user_mailer_preview.rb b/test/mailers/previews/user_mailer_preview.rb index 29dba39644e..5fc83dd3b1e 100644 --- a/test/mailers/previews/user_mailer_preview.rb +++ b/test/mailers/previews/user_mailer_preview.rb @@ -36,6 +36,8 @@ def feedback def challenge_assignment_notification_any assignment = create(:challenge_assignment) + assignment.sent_at = params[:sent_at] ? params[:sent_at].to_time : Time.current + assignment.save! signup = assignment.request_signup signup.pseud = create(:user, :for_mailer_preview).default_pseud @@ -52,17 +54,20 @@ def challenge_assignment_notification_any UserMailer.challenge_assignment_notification(assignment.collection.id, assignment.offering_user.id, assignment.id) end + # /rails/mailers/user_mailer/challenge_assignment_notification_filled?sent_at=2025-01-23T20:00&due=2021-12-15T13:45 def challenge_assignment_notification_filled assignment = create(:challenge_assignment) - - signup = assignment.request_signup - signup.pseud = create(:user, :for_mailer_preview).default_pseud - signup.save! + assignment.sent_at = params[:sent_at] ? params[:sent_at].to_time : Time.current + assignment.save! challenge = assignment.collection.challenge challenge.assignments_due_at = params[:due] ? params[:due].to_time : Time.current challenge.save! + signup = assignment.request_signup + signup.pseud = create(:user, :for_mailer_preview).default_pseud + signup.save! + # Allow up to 3 tags per type request_restriction = challenge.request_restriction TagSet::TAG_TYPES.each do |type| From c0e61090164dc262a41079e2f16b059879641025 Mon Sep 17 00:00:00 2001 From: Bilka Date: Wed, 27 Nov 2024 17:14:33 +0100 Subject: [PATCH 03/10] AO3-6848 Update mailer templates to current i18n standard --- ...challenge_assignment_notification.html.erb | 24 ++++++++-------- ...challenge_assignment_notification.text.erb | 28 +++++++++---------- config/locales/mailers/en.yml | 18 ++++++------ 3 files changed, 35 insertions(+), 35 deletions(-) diff --git a/app/views/user_mailer/challenge_assignment_notification.html.erb b/app/views/user_mailer/challenge_assignment_notification.html.erb index fe93bb90bfc..138f0b5ede6 100644 --- a/app/views/user_mailer/challenge_assignment_notification.html.erb +++ b/app/views/user_mailer/challenge_assignment_notification.html.erb @@ -12,7 +12,7 @@ <% def styled_tag_list(tags) %> <% return nil if !tags || tags.empty? %> - <% tags.map { |tag| style_link(tag.name, tag_works_url(tag)) }.to_sentence.html_safe %> + <% to_sentence(tags.map { |tag| style_link(tag.name, tag_works_url(tag)) }) %> <% end %> <% fandoms = prompt.any_fandom ? t(".any") : styled_tag_list(tag_groups["Fandom"]) %> @@ -28,15 +28,15 @@ <%= index + 1 %>. <%= style_bold(prompt.title) %>

- <% if fandoms %><%= style_bold(Fandom.human_attribute_name("name_with_colon", count: prompt.any_fandom ? 1 : tag_groups["Fandom"].count)) %> <%= fandoms %>
<% end %> - <% if chars %><%= style_bold(Character.human_attribute_name("name_with_colon", count: prompt.any_character ? 1 : tag_groups["Character"].count)) %> <%= chars %>
<% end %> - <% if ships %><%= style_bold(Relationship.human_attribute_name("name_with_colon", count: prompt.any_relationship ? 1 : tag_groups["Relationship"].count)) %> <%= ships %>
<% end %> - <% if ratings %><%= style_bold(Rating.human_attribute_name("name_with_colon")) %> <%= ratings %>
<% end %> - <% if warnings %><%= style_bold(ArchiveWarning.human_attribute_name("name_with_colon", count: prompt.any_archive_warning ? 1 : tag_groups["ArchiveWarning"].count)) %> <%= warnings %>
<% end %> - <% if categories %><%= style_bold(Category.human_attribute_name("name_with_colon", count: prompt.any_category ? 1 : tag_groups["Category"].count)) %> <%= categories %>
<% end %> - <% if atags %><%= style_bold(Freeform.human_attribute_name("name_with_colon", count: prompt.any_freeform ? 1 : tag_groups["Freeform"].count)) %> <%= atags %>
<% end %> - <% if otags %><%= style_bold("#{t(".optional_tags")}") %> <%= otags %>
<% end %> - <% if prompt.url && !prompt.url.blank? %><%= style_bold("#{t(".prompt_url")}") %> <%= style_link(prompt.url, prompt.url) %>
<% end %> + <% if fandoms %><%= style_bold(t("activerecord.models.fandom", count: prompt.any_fandom ? 1 : tag_groups["Fandom"].count) + t("mailer.general.metadata_label_indicator")) %> <%= fandoms %>
<% end %> + <% if chars %><%= style_bold(t("activerecord.models.character", count: prompt.any_character ? 1 : tag_groups["Character"].count) + t("mailer.general.metadata_label_indicator")) %> <%= chars %>
<% end %> + <% if ships %><%= style_bold(t("activerecord.models.relationship", count: prompt.any_relationship ? 1 : tag_groups["Relationship"].count) + t("mailer.general.metadata_label_indicator")) %> <%= ships %>
<% end %> + <% if ratings %><%= style_bold(t("activerecord.models.rating", count: 1) + t("mailer.general.metadata_label_indicator")) %> <%= ratings %>
<% end %> + <% if warnings %><%= style_bold(t("activerecord.models.archive_warning", count: prompt.any_archive_warning ? 1 : tag_groups["ArchiveWarning"].count) + t("mailer.general.metadata_label_indicator")) %> <%= warnings %>
<% end %> + <% if categories %><%= style_bold(t("activerecord.models.category", count: prompt.any_category ? 1 : tag_groups["Category"].count) + t("mailer.general.metadata_label_indicator")) %> <%= categories %>
<% end %> + <% if atags %><%= style_bold(t("activerecord.models.freeform", count: prompt.any_freeform ? 1 : tag_groups["Freeform"].count) + t("mailer.general.metadata_label_indicator")) %> <%= atags %>
<% end %> + <% if otags %><%= style_bold(t(".optional_tags")) %> <%= otags %>
<% end %> + <% if prompt.url && !prompt.url.blank? %><%= style_bold(t(".prompt_url")) %> <%= style_link(prompt.url, prompt.url) %>
<% end %> <% if prompt.description && !prompt.description.blank? %> <%= style_bold(t(".description")) %> <%= style_quote(prompt.description) %> @@ -50,7 +50,7 @@ <%= style_bold(t(".due")) %> <%= time_in_zone(@collection.challenge.assignments_due_at, (@collection.challenge.time_zone || Time.zone.name), @assigned_user) %>.

-

<%= t(".html.look_up", link: style_link(t(".html.look_up_link"), user_assignments_url(@assigned_user))).html_safe %>

+

<%= t(".look_up.html", your_assignments_link: style_link(t(".look_up.your_assignments"), user_assignments_url(@assigned_user))) %>

<% if @collection && !@collection.assignment_notification.blank? %>

<%= escape_html_and_create_linebreaks(@collection.assignment_notification) %>

@@ -58,7 +58,7 @@ <% end %> <% content_for :footer_note do %> - <%= t(".html.footer", title: style_footer_link(@collection.title, collection_url(@collection)), footer_link: style_footer_link(t(".html.footer_link"), collection_profile_url(@collection))).html_safe %> + <%= t(".footer.html", title: style_footer_link(@collection.title, collection_url(@collection)), challenge_profile_link: style_footer_link(t(".footer.challenge_profile"), collection_profile_url(@collection))) %> <% end %> <% content_for :sent_at do %> diff --git a/app/views/user_mailer/challenge_assignment_notification.text.erb b/app/views/user_mailer/challenge_assignment_notification.text.erb index 9a7e7647897..254d81639b2 100644 --- a/app/views/user_mailer/challenge_assignment_notification.text.erb +++ b/app/views/user_mailer/challenge_assignment_notification.text.erb @@ -1,5 +1,5 @@ <% content_for :message do %> -<%= t ".text.assignment", collection_title: @collection.title, collection_url: collection_url(@collection) %> +<%= t ".assignment.text", collection_title: @collection.title, collection_url: collection_url(@collection) %> <%= t ".recipient" %> <%= @request.nil? ? t(".recipient_missing") : text_pseud(@request.pseud) %> @@ -22,26 +22,26 @@ <%= index + 1 %>. <%= prompt.title %> -<% if fandoms %><%= Fandom.human_attribute_name("name_with_colon", count: prompt.any_fandom ? 1 : tag_groups["Fandom"].count) %> <%= fandoms %><% end %><% if chars %> -<%= Character.human_attribute_name("name_with_colon", count: prompt.any_character ? 1 : tag_groups["Character"].count) %> <%= chars %><% end %><% if ships %> -<%= Relationship.human_attribute_name("name_with_colon", count: prompt.any_relationship ? 1 : tag_groups["Relationship"].count) %> <%= ships %><% end %><% if ratings %> -<%= Rating.human_attribute_name("name_with_colon") %> <%= ratings %><% end %><% if warnings %> -<%= ArchiveWarning.human_attribute_name("name_with_colon", count: prompt.any_archive_warning ? 1 : tag_groups["ArchiveWarning"].count) %> <%= warnings %><% end %><% if categories %> -<%= Category.human_attribute_name("name_with_colon", count: prompt.any_category ? 1 : tag_groups["Category"].count) %> <%= categories %><% end %><% if atags %> -<%= Freeform.human_attribute_name("name_with_colon", count: prompt.any_freeform ? 1 : tag_groups["Freeform"].count) %> <%= atags %><% end %><% if otags %> -<%= t ".optional_tags" %> <%= otags %><% end %><% if prompt.url && !prompt.url.blank? %> -<%= t ".prompt_url" %> <%= prompt.url %><% end %><% if prompt.description && !prompt.description.blank? %> -<%= t ".description" %> +<% if fandoms %><%= t("activerecord.models.fandom", count: prompt.any_fandom ? 1 : tag_groups["Fandom"].count) + t("mailer.general.metadata_label_indicator") %> <%= fandoms %><% end %><% if chars %> +<%= t("activerecord.models.character", count: prompt.any_character ? 1 : tag_groups["Character"].count) + t("mailer.general.metadata_label_indicator") %> <%= chars %><% end %><% if ships %> +<%= t("activerecord.models.relationship", count: prompt.any_relationship ? 1 : tag_groups["Relationship"].count) + t("mailer.general.metadata_label_indicator") %> <%= ships %><% end %><% if ratings %> +<%= t("activerecord.models.rating", count: 1) + t("mailer.general.metadata_label_indicator") %> <%= ratings %><% end %><% if warnings %> +<%= t("activerecord.models.archive_warning", count: prompt.any_archive_warning ? 1 : tag_groups["ArchiveWarning"].count) + t("mailer.general.metadata_label_indicator") %> <%= warnings %><% end %><% if categories %> +<%= t("activerecord.models.category", count: prompt.any_category ? 1 : tag_groups["Category"].count) + t("mailer.general.metadata_label_indicator") %> <%= categories %><% end %><% if atags %> +<%= t("activerecord.models.freeform", count: prompt.any_freeform ? 1 : tag_groups["Freeform"].count) + t("mailer.general.metadata_label_indicator") %> <%= atags %><% end %><% if otags %> +<%= t(".optional_tags") %> <%= otags %><% end %><% if prompt.url && !prompt.url.blank? %> +<%= t(".prompt_url") %> <%= prompt.url %><% end %><% if prompt.description && !prompt.description.blank? %> +<%= t(".description") %> <%= to_plain_text(prompt.description) %><% end %> <% end %><%= text_divider %> -<%= t '.due' %> <%= to_plain_text(time_in_zone(@collection.challenge.assignments_due_at, (@collection.challenge.time_zone || Time.zone.name), @assigned_user)).gsub(/\n\s*/, "") %>. +<%= t(".due") %> <%= to_plain_text(time_in_zone(@collection.challenge.assignments_due_at, (@collection.challenge.time_zone || Time.zone.name), @assigned_user)).gsub(/\n\s*/, "") %>. -<%= t ".text.look_up", link: user_assignments_url(@assigned_user) %> +<%= t(".look_up.text", your_assignments_link: user_assignments_url(@assigned_user)) %> <% if @collection && !@collection.assignment_notification.blank? %> <%= @collection.assignment_notification %><% end %><% end %> -<% content_for :footer_note do %><%= t ".text.footer", title: @collection.title, url: collection_url(@collection), profile_url: collection_profile_url(@collection) %><% end %> +<% content_for :footer_note do %><%= t(".footer.text", title: @collection.title, url: collection_url(@collection), challenge_profile_url: collection_profile_url(@collection)) %><% end %> <% content_for :sent_at do %><%= l(@assignment.sent_at) %><% end %> diff --git a/config/locales/mailers/en.yml b/config/locales/mailers/en.yml index 16c85b34011..67fae0ee141 100644 --- a/config/locales/mailers/en.yml +++ b/config/locales/mailers/en.yml @@ -181,23 +181,23 @@ en: any: Any assignment: html: You have been assigned the following request in the %{link} challenge at the Archive of Our Own! + text: You have been assigned the following request in the "%{collection_title}" challenge (%{collection_url}) at the Archive of Our Own! description: 'Description:' due: 'This assignment is due at:' - html: - footer: You're receiving this email because you signed up for the %{title} challenge. For more information about this challenge and contact information for the moderators, please visit %{footer_link}. - footer_link: the challenge profile page - look_up: You can look up this assignment from %{link}. - look_up_link: your Assignments page + footer: + html: You're receiving this email because you signed up for the %{title} challenge. For more information about this challenge and contact information for the moderators, please visit %{challenge_profile_link}. + text: You're receiving this email because you signed up for the %{title} challenge (%{url}). For more information about this challenge and contact information for the moderators, please visit %{challenge_profile_url}. + challenge_profile: the challenge profile page + look_up: + html: You can look up this assignment from %{your_assignments_link}. + your_assignments: your Assignments page + text: You can look up this assignment from your Assignments page at %{your_assignments_link}. optional_tags: 'Optional Tags:' prompt_url: 'Prompt URL:' prompts: 'Prompts:' recipient: 'Recipient:' recipient_missing: 'None: contact a moderator for help!' subject: "[%{app_name}][%{collection_title}] Your assignment!" - text: - assignment: You have been assigned the following request in the "%{collection_title}" challenge (%{collection_url}) at the Archive of Our Own! - footer: You're receiving this email because you signed up for the %{title} challenge (%{url}). For more information about this challenge and contact information for the moderators, please visit %{profile_url}. - look_up: You can look up this assignment from your Assignments page at %{link}. change_email: changed: html: "%{login}, the email associated with your account has been changed to %{email}" From a771efdf9e18dd8ccc34ceae035110707095177e Mon Sep 17 00:00:00 2001 From: Bilka Date: Wed, 27 Nov 2024 17:30:22 +0100 Subject: [PATCH 04/10] AO3-6848 Remove unused locale keys --- config/locales/mailers/en.yml | 4 ++-- config/locales/models/en.yml | 26 -------------------------- 2 files changed, 2 insertions(+), 28 deletions(-) diff --git a/config/locales/mailers/en.yml b/config/locales/mailers/en.yml index 67fae0ee141..ea7193e07a1 100644 --- a/config/locales/mailers/en.yml +++ b/config/locales/mailers/en.yml @@ -185,13 +185,13 @@ en: description: 'Description:' due: 'This assignment is due at:' footer: + challenge_profile: the challenge profile page html: You're receiving this email because you signed up for the %{title} challenge. For more information about this challenge and contact information for the moderators, please visit %{challenge_profile_link}. text: You're receiving this email because you signed up for the %{title} challenge (%{url}). For more information about this challenge and contact information for the moderators, please visit %{challenge_profile_url}. - challenge_profile: the challenge profile page look_up: html: You can look up this assignment from %{your_assignments_link}. - your_assignments: your Assignments page text: You can look up this assignment from your Assignments page at %{your_assignments_link}. + your_assignments: your Assignments page optional_tags: 'Optional Tags:' prompt_url: 'Prompt URL:' prompts: 'Prompts:' diff --git a/config/locales/models/en.yml b/config/locales/models/en.yml index 1c9c25b5f26..de5bb6ee0fa 100644 --- a/config/locales/models/en.yml +++ b/config/locales/models/en.yml @@ -16,35 +16,15 @@ en: support: Support tag_wrangling: Tag Wrangling translation: Translation - archive_warning: - name_with_colon: - one: 'Warning:' - other: 'Warnings:' - category: - name_with_colon: - one: 'Category:' - other: 'Categories:' chapters/creatorships: base: 'Invalid creator:' pseud_id: Pseud - character: - name_with_colon: - one: 'Character:' - other: 'Characters:' creatorships: base: 'Invalid creator:' pseud_id: Pseud external_work: author: Creator user_defined_tags_count: Fandom, relationship, and character tags - fandom: - name_with_colon: - one: 'Fandom:' - other: 'Fandoms:' - freeform: - name_with_colon: - one: 'Additional Tag:' - other: 'Additional Tags:' gift_exchange: offers_num_allowed: Number of offers allowed per sign-up offers_num_required: Number of offers required per sign-up @@ -55,12 +35,6 @@ en: meta_tag_id: Metatag sub_tag: Subtag sub_tag_id: Subtag - rating: - name_with_colon: 'Rating:' - relationship: - name_with_colon: - one: 'Relationship:' - other: 'Relationships:' role: archivist: Archivist no_resets: No Resets From 2147815827a79f06fe373d77b7ca4c2287cf7338 Mon Sep 17 00:00:00 2001 From: Bilka Date: Wed, 27 Nov 2024 19:54:31 +0100 Subject: [PATCH 05/10] AO3-6848 Reviewdog --- .../challenge_assignment_notification.html.erb | 18 +++++++++--------- test/mailers/previews/user_mailer_preview.rb | 9 +++++++-- 2 files changed, 16 insertions(+), 11 deletions(-) diff --git a/app/views/user_mailer/challenge_assignment_notification.html.erb b/app/views/user_mailer/challenge_assignment_notification.html.erb index 138f0b5ede6..9b8b20845cd 100644 --- a/app/views/user_mailer/challenge_assignment_notification.html.erb +++ b/app/views/user_mailer/challenge_assignment_notification.html.erb @@ -28,15 +28,15 @@ <%= index + 1 %>. <%= style_bold(prompt.title) %>

- <% if fandoms %><%= style_bold(t("activerecord.models.fandom", count: prompt.any_fandom ? 1 : tag_groups["Fandom"].count) + t("mailer.general.metadata_label_indicator")) %> <%= fandoms %>
<% end %> - <% if chars %><%= style_bold(t("activerecord.models.character", count: prompt.any_character ? 1 : tag_groups["Character"].count) + t("mailer.general.metadata_label_indicator")) %> <%= chars %>
<% end %> - <% if ships %><%= style_bold(t("activerecord.models.relationship", count: prompt.any_relationship ? 1 : tag_groups["Relationship"].count) + t("mailer.general.metadata_label_indicator")) %> <%= ships %>
<% end %> - <% if ratings %><%= style_bold(t("activerecord.models.rating", count: 1) + t("mailer.general.metadata_label_indicator")) %> <%= ratings %>
<% end %> - <% if warnings %><%= style_bold(t("activerecord.models.archive_warning", count: prompt.any_archive_warning ? 1 : tag_groups["ArchiveWarning"].count) + t("mailer.general.metadata_label_indicator")) %> <%= warnings %>
<% end %> - <% if categories %><%= style_bold(t("activerecord.models.category", count: prompt.any_category ? 1 : tag_groups["Category"].count) + t("mailer.general.metadata_label_indicator")) %> <%= categories %>
<% end %> - <% if atags %><%= style_bold(t("activerecord.models.freeform", count: prompt.any_freeform ? 1 : tag_groups["Freeform"].count) + t("mailer.general.metadata_label_indicator")) %> <%= atags %>
<% end %> - <% if otags %><%= style_bold(t(".optional_tags")) %> <%= otags %>
<% end %> - <% if prompt.url && !prompt.url.blank? %><%= style_bold(t(".prompt_url")) %> <%= style_link(prompt.url, prompt.url) %>
<% end %> + <% if fandoms %><%= style_bold(t("activerecord.models.fandom", count: prompt.any_fandom ? 1 : tag_groups["Fandom"].count) + t("mailer.general.metadata_label_indicator")) %> <%= fandoms %>
<% end %> + <% if chars %><%= style_bold(t("activerecord.models.character", count: prompt.any_character ? 1 : tag_groups["Character"].count) + t("mailer.general.metadata_label_indicator")) %> <%= chars %>
<% end %> + <% if ships %><%= style_bold(t("activerecord.models.relationship", count: prompt.any_relationship ? 1 : tag_groups["Relationship"].count) + t("mailer.general.metadata_label_indicator")) %> <%= ships %>
<% end %> + <% if ratings %><%= style_bold(t("activerecord.models.rating", count: 1) + t("mailer.general.metadata_label_indicator")) %> <%= ratings %>
<% end %> + <% if warnings %><%= style_bold(t("activerecord.models.archive_warning", count: prompt.any_archive_warning ? 1 : tag_groups["ArchiveWarning"].count) + t("mailer.general.metadata_label_indicator")) %> <%= warnings %>
<% end %> + <% if categories %><%= style_bold(t("activerecord.models.category", count: prompt.any_category ? 1 : tag_groups["Category"].count) + t("mailer.general.metadata_label_indicator")) %> <%= categories %>
<% end %> + <% if atags %><%= style_bold(t("activerecord.models.freeform", count: prompt.any_freeform ? 1 : tag_groups["Freeform"].count) + t("mailer.general.metadata_label_indicator")) %> <%= atags %>
<% end %> + <% if otags %><%= style_bold(t(".optional_tags")) %> <%= otags %>
<% end %> + <% if prompt.url && !prompt.url.blank? %><%= style_bold(t(".prompt_url")) %> <%= style_link(prompt.url, prompt.url) %>
<% end %> <% if prompt.description && !prompt.description.blank? %> <%= style_bold(t(".description")) %> <%= style_quote(prompt.description) %> diff --git a/test/mailers/previews/user_mailer_preview.rb b/test/mailers/previews/user_mailer_preview.rb index 5fc83dd3b1e..9a78e029d9e 100644 --- a/test/mailers/previews/user_mailer_preview.rb +++ b/test/mailers/previews/user_mailer_preview.rb @@ -34,6 +34,9 @@ def feedback UserMailer.feedback(feedback.id) end + # Sent by gift exchanges to the participants + # Variant with tag fields set to "Any" and no due date + # URL: /rails/mailers/user_mailer/challenge_assignment_notification_any?sent_at=2025-01-23T20:00 def challenge_assignment_notification_any assignment = create(:challenge_assignment) assignment.sent_at = params[:sent_at] ? params[:sent_at].to_time : Time.current @@ -54,7 +57,9 @@ def challenge_assignment_notification_any UserMailer.challenge_assignment_notification(assignment.collection.id, assignment.offering_user.id, assignment.id) end - # /rails/mailers/user_mailer/challenge_assignment_notification_filled?sent_at=2025-01-23T20:00&due=2021-12-15T13:45 + # Sent by gift exchanges to the participants + # Variant with flexible due date, 3 tags per type and all fields filled out + # URL: /rails/mailers/user_mailer/challenge_assignment_notification_filled?sent_at=2025-01-23T20:00&due=2021-12-15T13:45 def challenge_assignment_notification_filled assignment = create(:challenge_assignment) assignment.sent_at = params[:sent_at] ? params[:sent_at].to_time : Time.current @@ -80,7 +85,7 @@ def challenge_assignment_notification_filled tag_set.archive_warning_tagnames = [ArchiveConfig.WARNING_VIOLENCE_TAG_NAME, ArchiveConfig.WARNING_DEATH_TAG_NAME, ArchiveConfig.WARNING_NONCON_TAG_NAME].join(ArchiveConfig.DELIMITER_FOR_OUTPUT) tag_set.rating_tagnames = [ArchiveConfig.RATING_EXPLICIT_TAG_NAME, ArchiveConfig.RATING_MATURE_TAG_NAME, ArchiveConfig.RATING_TEEN_TAG_NAME].join(ArchiveConfig.DELIMITER_FOR_OUTPUT) tag_set.category_tagnames = [ArchiveConfig.CATEGORY_GEN_TAG_NAME, ArchiveConfig.CATEGORY_HET_TAG_NAME, ArchiveConfig.CATEGORY_SLASH_TAG_NAME].join(ArchiveConfig.DELIMITER_FOR_OUTPUT) - %w(fandom character relationship freeform).each do |type| + %w[fandom character relationship freeform].each do |type| tag_set.tags += [create(:"canonical_#{type}"), create(:"canonical_#{type}"), create(:"canonical_#{type}")] end tag_set.save! From 215d53a3dd484ef7cc0cf98add99d7cef53857b9 Mon Sep 17 00:00:00 2001 From: Bilka Date: Wed, 27 Nov 2024 20:09:21 +0100 Subject: [PATCH 06/10] AO3-6848 Fix test --- spec/mailers/user_mailer_spec.rb | 2 +- test/mailers/previews/user_mailer_preview.rb | 17 +++++------------ 2 files changed, 6 insertions(+), 13 deletions(-) diff --git a/spec/mailers/user_mailer_spec.rb b/spec/mailers/user_mailer_spec.rb index f2fc7c3e5ef..0ab0a57287f 100644 --- a/spec/mailers/user_mailer_spec.rb +++ b/spec/mailers/user_mailer_spec.rb @@ -377,7 +377,7 @@ let!(:collection) { create(:collection, challenge: gift_exchange, challenge_type: "GiftExchange") } let!(:otheruser) { create(:user) } let!(:offer) { create(:challenge_signup, collection: collection, pseud: otheruser.default_pseud) } - let!(:open_assignment) { create(:challenge_assignment, collection: collection, offer_signup: offer) } + let!(:open_assignment) { create(:challenge_assignment, collection: collection, offer_signup: offer, sent_at: Time.current) } # Test the headers it_behaves_like "an email with a valid sender" diff --git a/test/mailers/previews/user_mailer_preview.rb b/test/mailers/previews/user_mailer_preview.rb index 9a78e029d9e..75b6012e34b 100644 --- a/test/mailers/previews/user_mailer_preview.rb +++ b/test/mailers/previews/user_mailer_preview.rb @@ -38,13 +38,10 @@ def feedback # Variant with tag fields set to "Any" and no due date # URL: /rails/mailers/user_mailer/challenge_assignment_notification_any?sent_at=2025-01-23T20:00 def challenge_assignment_notification_any - assignment = create(:challenge_assignment) - assignment.sent_at = params[:sent_at] ? params[:sent_at].to_time : Time.current - assignment.save! + assignment = create(:challenge_assignment, sent_at: (params[:sent_at] ? params[:sent_at].to_time : Time.current)) signup = assignment.request_signup - signup.pseud = create(:user, :for_mailer_preview).default_pseud - signup.save! + signup.update(pseud: create(:user, :for_mailer_preview).default_pseud) # Fill all tag fields with "Any" prompt = signup.requests.first @@ -61,17 +58,13 @@ def challenge_assignment_notification_any # Variant with flexible due date, 3 tags per type and all fields filled out # URL: /rails/mailers/user_mailer/challenge_assignment_notification_filled?sent_at=2025-01-23T20:00&due=2021-12-15T13:45 def challenge_assignment_notification_filled - assignment = create(:challenge_assignment) - assignment.sent_at = params[:sent_at] ? params[:sent_at].to_time : Time.current - assignment.save! + assignment = create(:challenge_assignment, sent_at: (params[:sent_at] ? params[:sent_at].to_time : Time.current)) challenge = assignment.collection.challenge - challenge.assignments_due_at = params[:due] ? params[:due].to_time : Time.current - challenge.save! + challenge.update(assignments_due_at: params[:due] ? params[:due].to_time : Time.current) signup = assignment.request_signup - signup.pseud = create(:user, :for_mailer_preview).default_pseud - signup.save! + signup.update(pseud: create(:user, :for_mailer_preview).default_pseud) # Allow up to 3 tags per type request_restriction = challenge.request_restriction From 22591a7d9edad068b267469c136f40066da99deb Mon Sep 17 00:00:00 2001 From: Bilka Date: Wed, 27 Nov 2024 20:24:03 +0100 Subject: [PATCH 07/10] AO3-6848 Add test for sending translated email --- .../gift_exchanges/notification_emails.feature | 16 +++++++++++++++- 1 file changed, 15 insertions(+), 1 deletion(-) diff --git a/features/gift_exchanges/notification_emails.feature b/features/gift_exchanges/notification_emails.feature index c36449ba17f..5aa2a6ab8db 100644 --- a/features/gift_exchanges/notification_emails.feature +++ b/features/gift_exchanges/notification_emails.feature @@ -1,7 +1,7 @@ Feature: Gift Exchange Notification Emails Make sure that gift exchange notification emails are formatted properly - Scenario: Assignment notification emails should be sent to two owners in their respective locales when assignments are generated + Scenario: Assignment sent notification emails should be sent to two owners in their respective locales when assignments are generated Given I have created the tagless gift exchange "Holiday Swap" And I open signups for "Holiday Swap" @@ -148,3 +148,17 @@ Feature: Gift Exchange Notification Emails Then "participant1" should receive 1 email And the notification message to "participant1" should contain the no archive warnings tag + + Scenario: Assignment notifications should be sent to participants in their respective locales + Given the gift exchange "Holiday Swap" is ready for matching + And a locale with translated emails + And the user "myname1" enables translated emails + When I close signups for "Holiday Swap" + And I have generated matches for "Holiday Swap" + And I have sent assignments for "Holiday Swap" + Then "myname1" should receive 1 email + And the email should have "Your assignment!" in the subject + And the email to "myname1" should be translated + And "myname2" should receive 1 email + And the email should have "Your assignment!" in the subject + And the email to "myname2" should be non-translated From f7dcd9582770d1756b516924ab6b2d123e2c69e6 Mon Sep 17 00:00:00 2001 From: Bilka Date: Wed, 27 Nov 2024 21:03:57 +0100 Subject: [PATCH 08/10] AO3-6848 Use translatable word connector for warnings etc --- app/helpers/tags_helper.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/helpers/tags_helper.rb b/app/helpers/tags_helper.rb index 2669e1699ef..c39258fe10d 100644 --- a/app/helpers/tags_helper.rb +++ b/app/helpers/tags_helper.rb @@ -240,7 +240,7 @@ def show_hidden_tag_link_list_item(item, category, options = {}) def get_title_string(tags, category_name = "") if tags && tags.size > 0 - tags.collect(&:name).join(", ") + tags.collect(&:name).join(t("support.array.words_connector")) elsif tags.blank? && category_name.blank? "Choose Not To Use Archive Warnings" else From 0616bb79ea250bddca1316eac9739d6a86af80dd Mon Sep 17 00:00:00 2001 From: Bilka Date: Sat, 30 Nov 2024 15:42:51 +0100 Subject: [PATCH 09/10] AO3-6848 Fix interpolation variable name --- app/helpers/tags_helper.rb | 4 +++- .../user_mailer/challenge_assignment_notification.text.erb | 2 +- config/locales/mailers/en.yml | 2 +- 3 files changed, 5 insertions(+), 3 deletions(-) diff --git a/app/helpers/tags_helper.rb b/app/helpers/tags_helper.rb index c39258fe10d..56ac370dbb4 100644 --- a/app/helpers/tags_helper.rb +++ b/app/helpers/tags_helper.rb @@ -240,7 +240,9 @@ def show_hidden_tag_link_list_item(item, category, options = {}) def get_title_string(tags, category_name = "") if tags && tags.size > 0 - tags.collect(&:name).join(t("support.array.words_connector")) + # We don't use .to_sentence because these aren't links and we risk making any + # connector word (e.g., "and") look like part of the final tag. + tags.pluck(:name).join(t("support.array.words_connector")) elsif tags.blank? && category_name.blank? "Choose Not To Use Archive Warnings" else diff --git a/app/views/user_mailer/challenge_assignment_notification.text.erb b/app/views/user_mailer/challenge_assignment_notification.text.erb index 254d81639b2..456f33cacd0 100644 --- a/app/views/user_mailer/challenge_assignment_notification.text.erb +++ b/app/views/user_mailer/challenge_assignment_notification.text.erb @@ -38,7 +38,7 @@ <%= t(".due") %> <%= to_plain_text(time_in_zone(@collection.challenge.assignments_due_at, (@collection.challenge.time_zone || Time.zone.name), @assigned_user)).gsub(/\n\s*/, "") %>. -<%= t(".look_up.text", your_assignments_link: user_assignments_url(@assigned_user)) %> +<%= t(".look_up.text", your_assignments_url: user_assignments_url(@assigned_user)) %> <% if @collection && !@collection.assignment_notification.blank? %> diff --git a/config/locales/mailers/en.yml b/config/locales/mailers/en.yml index ea7193e07a1..28aed73fb42 100644 --- a/config/locales/mailers/en.yml +++ b/config/locales/mailers/en.yml @@ -190,7 +190,7 @@ en: text: You're receiving this email because you signed up for the %{title} challenge (%{url}). For more information about this challenge and contact information for the moderators, please visit %{challenge_profile_url}. look_up: html: You can look up this assignment from %{your_assignments_link}. - text: You can look up this assignment from your Assignments page at %{your_assignments_link}. + text: You can look up this assignment from your Assignments page at %{your_assignments_url}. your_assignments: your Assignments page optional_tags: 'Optional Tags:' prompt_url: 'Prompt URL:' From 2dac716e4f3ba270d38ee811ceaa7e86c40d46b9 Mon Sep 17 00:00:00 2001 From: Bilka Date: Thu, 12 Dec 2024 10:26:41 +0100 Subject: [PATCH 10/10] AO3-6848 Reformat ifs in erb --- ...challenge_assignment_notification.html.erb | 54 +++++++++++++++---- ...challenge_assignment_notification.text.erb | 48 ++++++++++++----- 2 files changed, 81 insertions(+), 21 deletions(-) diff --git a/app/views/user_mailer/challenge_assignment_notification.html.erb b/app/views/user_mailer/challenge_assignment_notification.html.erb index 9b8b20845cd..9237a13c180 100644 --- a/app/views/user_mailer/challenge_assignment_notification.html.erb +++ b/app/views/user_mailer/challenge_assignment_notification.html.erb @@ -28,15 +28,51 @@ <%= index + 1 %>. <%= style_bold(prompt.title) %>

- <% if fandoms %><%= style_bold(t("activerecord.models.fandom", count: prompt.any_fandom ? 1 : tag_groups["Fandom"].count) + t("mailer.general.metadata_label_indicator")) %> <%= fandoms %>
<% end %> - <% if chars %><%= style_bold(t("activerecord.models.character", count: prompt.any_character ? 1 : tag_groups["Character"].count) + t("mailer.general.metadata_label_indicator")) %> <%= chars %>
<% end %> - <% if ships %><%= style_bold(t("activerecord.models.relationship", count: prompt.any_relationship ? 1 : tag_groups["Relationship"].count) + t("mailer.general.metadata_label_indicator")) %> <%= ships %>
<% end %> - <% if ratings %><%= style_bold(t("activerecord.models.rating", count: 1) + t("mailer.general.metadata_label_indicator")) %> <%= ratings %>
<% end %> - <% if warnings %><%= style_bold(t("activerecord.models.archive_warning", count: prompt.any_archive_warning ? 1 : tag_groups["ArchiveWarning"].count) + t("mailer.general.metadata_label_indicator")) %> <%= warnings %>
<% end %> - <% if categories %><%= style_bold(t("activerecord.models.category", count: prompt.any_category ? 1 : tag_groups["Category"].count) + t("mailer.general.metadata_label_indicator")) %> <%= categories %>
<% end %> - <% if atags %><%= style_bold(t("activerecord.models.freeform", count: prompt.any_freeform ? 1 : tag_groups["Freeform"].count) + t("mailer.general.metadata_label_indicator")) %> <%= atags %>
<% end %> - <% if otags %><%= style_bold(t(".optional_tags")) %> <%= otags %>
<% end %> - <% if prompt.url && !prompt.url.blank? %><%= style_bold(t(".prompt_url")) %> <%= style_link(prompt.url, prompt.url) %>
<% end %> + <% if fandoms %> + <%= style_bold(t("activerecord.models.fandom", count: prompt.any_fandom ? 1 : tag_groups["Fandom"].count) + t("mailer.general.metadata_label_indicator")) %> + <%= fandoms %> +
+ <% end %> + <% if chars %> + <%= style_bold(t("activerecord.models.character", count: prompt.any_character ? 1 : tag_groups["Character"].count) + t("mailer.general.metadata_label_indicator")) %> + <%= chars %> +
+ <% end %> + <% if ships %> + <%= style_bold(t("activerecord.models.relationship", count: prompt.any_relationship ? 1 : tag_groups["Relationship"].count) + t("mailer.general.metadata_label_indicator")) %> + <%= ships %> +
+ <% end %> + <% if ratings %> + <%= style_bold(t("activerecord.models.rating", count: 1) + t("mailer.general.metadata_label_indicator")) %> + <%= ratings %> +
+ <% end %> + <% if warnings %> + <%= style_bold(t("activerecord.models.archive_warning", count: prompt.any_archive_warning ? 1 : tag_groups["ArchiveWarning"].count) + t("mailer.general.metadata_label_indicator")) %> + <%= warnings %> +
+ <% end %> + <% if categories %> + <%= style_bold(t("activerecord.models.category", count: prompt.any_category ? 1 : tag_groups["Category"].count) + t("mailer.general.metadata_label_indicator")) %> + <%= categories %> +
+ <% end %> + <% if atags %> + <%= style_bold(t("activerecord.models.freeform", count: prompt.any_freeform ? 1 : tag_groups["Freeform"].count) + t("mailer.general.metadata_label_indicator")) %> + <%= atags %> +
+ <% end %> + <% if otags %> + <%= style_bold(t(".optional_tags")) %> + <%= otags %> +
+ <% end %> + <% if prompt.url && !prompt.url.blank? %> + <%= style_bold(t(".prompt_url")) %> + <%= style_link(prompt.url, prompt.url) %> +
+ <% end %> <% if prompt.description && !prompt.description.blank? %> <%= style_bold(t(".description")) %> <%= style_quote(prompt.description) %> diff --git a/app/views/user_mailer/challenge_assignment_notification.text.erb b/app/views/user_mailer/challenge_assignment_notification.text.erb index 456f33cacd0..f7db169b07d 100644 --- a/app/views/user_mailer/challenge_assignment_notification.text.erb +++ b/app/views/user_mailer/challenge_assignment_notification.text.erb @@ -22,17 +22,37 @@ <%= index + 1 %>. <%= prompt.title %> -<% if fandoms %><%= t("activerecord.models.fandom", count: prompt.any_fandom ? 1 : tag_groups["Fandom"].count) + t("mailer.general.metadata_label_indicator") %> <%= fandoms %><% end %><% if chars %> -<%= t("activerecord.models.character", count: prompt.any_character ? 1 : tag_groups["Character"].count) + t("mailer.general.metadata_label_indicator") %> <%= chars %><% end %><% if ships %> -<%= t("activerecord.models.relationship", count: prompt.any_relationship ? 1 : tag_groups["Relationship"].count) + t("mailer.general.metadata_label_indicator") %> <%= ships %><% end %><% if ratings %> -<%= t("activerecord.models.rating", count: 1) + t("mailer.general.metadata_label_indicator") %> <%= ratings %><% end %><% if warnings %> -<%= t("activerecord.models.archive_warning", count: prompt.any_archive_warning ? 1 : tag_groups["ArchiveWarning"].count) + t("mailer.general.metadata_label_indicator") %> <%= warnings %><% end %><% if categories %> -<%= t("activerecord.models.category", count: prompt.any_category ? 1 : tag_groups["Category"].count) + t("mailer.general.metadata_label_indicator") %> <%= categories %><% end %><% if atags %> -<%= t("activerecord.models.freeform", count: prompt.any_freeform ? 1 : tag_groups["Freeform"].count) + t("mailer.general.metadata_label_indicator") %> <%= atags %><% end %><% if otags %> -<%= t(".optional_tags") %> <%= otags %><% end %><% if prompt.url && !prompt.url.blank? %> -<%= t(".prompt_url") %> <%= prompt.url %><% end %><% if prompt.description && !prompt.description.blank? %> +<% if fandoms %> +<%= t("activerecord.models.fandom", count: prompt.any_fandom ? 1 : tag_groups["Fandom"].count) + t("mailer.general.metadata_label_indicator") %><%= fandoms %> +<% end %> +<% if chars %> +<%= t("activerecord.models.character", count: prompt.any_character ? 1 : tag_groups["Character"].count) + t("mailer.general.metadata_label_indicator") %><%= chars %> +<% end %> +<% if ships %> +<%= t("activerecord.models.relationship", count: prompt.any_relationship ? 1 : tag_groups["Relationship"].count) + t("mailer.general.metadata_label_indicator") %><%= ships %> +<% end %> +<% if ratings %> +<%= t("activerecord.models.rating", count: 1) + t("mailer.general.metadata_label_indicator") %><%= ratings %> +<% end %> +<% if warnings %> +<%= t("activerecord.models.archive_warning", count: prompt.any_archive_warning ? 1 : tag_groups["ArchiveWarning"].count) + t("mailer.general.metadata_label_indicator") %><%= warnings %> +<% end %> +<% if categories %> +<%= t("activerecord.models.category", count: prompt.any_category ? 1 : tag_groups["Category"].count) + t("mailer.general.metadata_label_indicator") %><%= categories %> +<% end %> +<% if atags %> +<%= t("activerecord.models.freeform", count: prompt.any_freeform ? 1 : tag_groups["Freeform"].count) + t("mailer.general.metadata_label_indicator") %><%= atags %> +<% end %> +<% if otags %> +<%= t(".optional_tags") %> <%= otags %> +<% end %> +<% if prompt.url && !prompt.url.blank? %> +<%= t(".prompt_url") %> <%= prompt.url %> +<% end %> +<% if prompt.description && !prompt.description.blank? %> <%= t(".description") %> - <%= to_plain_text(prompt.description) %><% end %> + <%= to_plain_text(prompt.description) %> +<% end %> <% end %><%= text_divider %> @@ -43,5 +63,9 @@ <%= @collection.assignment_notification %><% end %><% end %> -<% content_for :footer_note do %><%= t(".footer.text", title: @collection.title, url: collection_url(@collection), challenge_profile_url: collection_profile_url(@collection)) %><% end %> -<% content_for :sent_at do %><%= l(@assignment.sent_at) %><% end %> +<% content_for :footer_note do %> +<%= t(".footer.text", title: @collection.title, url: collection_url(@collection), challenge_profile_url: collection_profile_url(@collection)) -%> +<% end %> +<% content_for :sent_at do %> +<%= l(@assignment.sent_at) -%> +<% end %>