feat: Move report e-mail to html
This commit is contained in:
		@@ -1,5 +1,7 @@
 | 
				
			|||||||
from django.db.models.signals import post_save
 | 
					from django.db.models.signals import post_save
 | 
				
			||||||
from django.dispatch import receiver
 | 
					from django.dispatch import receiver
 | 
				
			||||||
 | 
					from django.template.loader import render_to_string
 | 
				
			||||||
 | 
					from django.utils.html import strip_tags
 | 
				
			||||||
 | 
					
 | 
				
			||||||
from django.utils.translation import gettext_lazy as _
 | 
					from django.utils.translation import gettext_lazy as _
 | 
				
			||||||
from django.conf import settings
 | 
					from django.conf import settings
 | 
				
			||||||
@@ -11,25 +13,23 @@ NEWLINE = "\r\n"
 | 
				
			|||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def mail_admins_new_report(report):
 | 
					def mail_admins_new_report(report):
 | 
				
			||||||
    subject = _("Neue Meldung")
 | 
					    """
 | 
				
			||||||
 | 
					    Sends an e-mail to all users that should handle the report.
 | 
				
			||||||
 | 
					    """
 | 
				
			||||||
    for moderator in User.objects.filter(trust_level__gt=TrustLevel.MODERATOR):
 | 
					    for moderator in User.objects.filter(trust_level__gt=TrustLevel.MODERATOR):
 | 
				
			||||||
        greeting = _("Moin,") + "{NEWLINE}"
 | 
					 | 
				
			||||||
        new_report_text = _("es wurde ein Regelverstoß gemeldet.") + "{NEWLINE}"
 | 
					 | 
				
			||||||
        if len(report.reported_broken_rules.all()) > 0:
 | 
					 | 
				
			||||||
            reported_rules_text = (f"Ein Verstoß gegen die folgenden Regeln wurde gemeldet:{NEWLINE}"
 | 
					 | 
				
			||||||
                                   f"- {f'{NEWLINE} - '.join([str(r) for r in report.reported_broken_rules.all()])}{NEWLINE}")
 | 
					 | 
				
			||||||
        else:
 | 
					 | 
				
			||||||
            reported_rules_text = f"Es wurden keine Regeln angegeben gegen die Verstoßen wurde.{NEWLINE}"
 | 
					 | 
				
			||||||
        if report.user_comment:
 | 
					 | 
				
			||||||
            comment_text = f'Kommentar zum Report: "{report.user_comment}"{NEWLINE}'
 | 
					 | 
				
			||||||
        else:
 | 
					 | 
				
			||||||
            comment_text = f"Es wurde kein Kommentar hinzugefügt.{NEWLINE}"
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
        report_url = "https://" + host + report.get_absolute_url()
 | 
					        report_url = "https://" + host + report.get_absolute_url()
 | 
				
			||||||
        link_text = f"Um alle Details zu sehen, geh bitte auf: {report_url}"
 | 
					        context = {"report_url": report_url,
 | 
				
			||||||
        body_text = greeting + new_report_text + reported_rules_text + comment_text + link_text
 | 
					                   "user_comment": report.user_comment,}
 | 
				
			||||||
        message = mail.EmailMessage(subject, body_text, settings.DEFAULT_FROM_EMAIL, [moderator.email])
 | 
					
 | 
				
			||||||
        message.send()
 | 
					        subject = _("Neue Meldung")
 | 
				
			||||||
 | 
					        html_message = render_to_string('fellchensammlung/mail/report.html', context)
 | 
				
			||||||
 | 
					        plain_message = strip_tags(html_message)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        mail.send_mail(subject,
 | 
				
			||||||
 | 
					                       plain_message,
 | 
				
			||||||
 | 
					                       from_email="info@notfellchen.org",
 | 
				
			||||||
 | 
					                       recipient_list=[moderator.email],
 | 
				
			||||||
 | 
					                       html_message=html_message)
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
def send_notification_email(notification_pk):
 | 
					def send_notification_email(notification_pk):
 | 
				
			||||||
 
 | 
				
			|||||||
@@ -0,0 +1,25 @@
 | 
				
			|||||||
 | 
					{% extends "fellchensammlung/mail/base.html" %}
 | 
				
			||||||
 | 
					{% load i18n %}
 | 
				
			||||||
 | 
					{% block title %}
 | 
				
			||||||
 | 
					    {% translate 'Neue Meldung' %}
 | 
				
			||||||
 | 
					{% endblock %}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					{% block content %}
 | 
				
			||||||
 | 
					    <p>Moin,</p>
 | 
				
			||||||
 | 
					    <p>
 | 
				
			||||||
 | 
					        es gibt eine neue Meldung. Folgende Nachricht wurde zur Meldung hinzugefügt.
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					    </p>
 | 
				
			||||||
 | 
					    <p>
 | 
				
			||||||
 | 
					        <i>
 | 
				
			||||||
 | 
					            {{ user_comment }}
 | 
				
			||||||
 | 
					        </i>
 | 
				
			||||||
 | 
					    </p>
 | 
				
			||||||
 | 
					    <p>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					        Bitte bearbeite die Meldung möglichst bald
 | 
				
			||||||
 | 
					    </p>
 | 
				
			||||||
 | 
					    <p>
 | 
				
			||||||
 | 
					        <a href="{{ report_url }}" class="cta-button">{% translate 'Report bearbeiten' %}</a>
 | 
				
			||||||
 | 
					    </p>
 | 
				
			||||||
 | 
					{% endblock %}
 | 
				
			||||||
@@ -476,6 +476,7 @@ def report_adoption(request, adoption_notice_id):
 | 
				
			|||||||
            report_instance.save()
 | 
					            report_instance.save()
 | 
				
			||||||
            form.save_m2m()
 | 
					            form.save_m2m()
 | 
				
			||||||
            mail_admins_new_report(report_instance)
 | 
					            mail_admins_new_report(report_instance)
 | 
				
			||||||
 | 
					            print("dada")
 | 
				
			||||||
            return redirect(reverse("report-detail-success", args=[report_instance.pk], ))
 | 
					            return redirect(reverse("report-detail-success", args=[report_instance.pk], ))
 | 
				
			||||||
    else:
 | 
					    else:
 | 
				
			||||||
        form = ReportAdoptionNoticeForm()
 | 
					        form = ReportAdoptionNoticeForm()
 | 
				
			||||||
 
 | 
				
			|||||||
		Reference in New Issue
	
	Block a user