From d6e9bb724e48a6a8e4eb7a8184b352db8061533b Mon Sep 17 00:00:00 2001 From: Arnaud-D <35631001+Arnaud-D@users.noreply.github.com> Date: Sat, 19 Oct 2024 09:08:20 +0200 Subject: [PATCH] =?UTF-8?q?Rend=20g=C3=A9n=C3=A9rique=20en=20fonction=20du?= =?UTF-8?q?=20type=20la=20vue=20"WarnTypo"?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * supprime la distinction de type de publication * préfère le terme "publication" à "contenu" * renomme les vues pour adopter la convention de Django * déplace le formulaire à côté de la vue --- templates/tutorialv2/messages/warn_typo.md | 4 +- zds/tutorialv2/forms.py | 83 ---------------- zds/tutorialv2/urls/urls_contents.py | 4 +- zds/tutorialv2/views/display/container.py | 2 +- zds/tutorialv2/views/display/content.py | 2 +- zds/tutorialv2/views/misc.py | 104 +++++++++++++++++---- 6 files changed, 91 insertions(+), 108 deletions(-) diff --git a/templates/tutorialv2/messages/warn_typo.md b/templates/tutorialv2/messages/warn_typo.md index 7c1f288c83..ad16dd616b 100644 --- a/templates/tutorialv2/messages/warn_typo.md +++ b/templates/tutorialv2/messages/warn_typo.md @@ -16,10 +16,10 @@ -{% blocktrans with username=user.username|safe title=content.title|safe type=type|safe %} +{% blocktrans with username=user.username|safe title=content.title|safe %} Salut ! -Il me semble avoir déniché une erreur dans {{ type }} « [{{ title }}]({{ content_url }}) ».{% endblocktrans %} +Il me semble avoir déniché une erreur dans « [{{ title }}]({{ content_url }}) ».{% endblocktrans %} {% if target != content %} {% blocktrans with title=target.title|safe %}Fourbe, elle se situe sournoisement dans {{ feminized }} {{ level }} « [{{ title }}]({{ target_url }}) ».{% endblocktrans %} {% endif %} diff --git a/zds/tutorialv2/forms.py b/zds/tutorialv2/forms.py index a9d73013e2..c2cc469347 100644 --- a/zds/tutorialv2/forms.py +++ b/zds/tutorialv2/forms.py @@ -693,89 +693,6 @@ def __init__(self, *args, **kwargs): ) -class WarnTypoForm(forms.Form): - text = forms.CharField( - label="", - required=True, - widget=forms.Textarea(attrs={"placeholder": _("Expliquez la faute"), "rows": "3", "id": "warn_text"}), - ) - - target = forms.CharField(widget=forms.HiddenInput(), required=False) - version = forms.CharField(widget=forms.HiddenInput(), required=True) - - def __init__(self, content, targeted, public=True, *args, **kwargs): - super().__init__(*args, **kwargs) - - self.content = content - self.targeted = targeted - - # modal form, send back to previous page if any: - if public: - self.previous_page_url = targeted.get_absolute_url_online() - else: - self.previous_page_url = targeted.get_absolute_url_beta() - - # add an additional link to send PM if needed - type_ = _("l'article") - - if content.is_tutorial: - type_ = _("le tutoriel") - elif content.is_opinion: - type_ = _("le billet") - - if targeted.get_tree_depth() == 0: - pm_title = _("J'ai trouvé une faute dans {} « {} ».").format(type_, targeted.title) - else: - pm_title = _("J'ai trouvé une faute dans le chapitre « {} ».").format(targeted.title) - - usernames = "" - num_of_authors = content.authors.count() - for index, user in enumerate(content.authors.all()): - if index != 0: - usernames += "&" - usernames += "username=" + user.username - - msg = _('
Pas assez de place ? Envoyez un MP {} !').format(
- reverse("mp:create"), pm_title, usernames, _("à l'auteur") if num_of_authors == 1 else _("aux auteurs")
- )
-
- version = content.sha_beta
- if public:
- version = content.sha_public
-
- # create form
- self.helper = FormHelper()
- self.helper.form_action = reverse("content:warn-typo") + f"?pk={content.pk}"
- self.helper.form_method = "post"
- self.helper.form_class = "modal modal-flex"
- self.helper.form_id = "warn-typo-modal"
- self.helper.layout = Layout(
- Field("target"),
- Field("text"),
- HTML(msg),
- Hidden("pk", "{{ content.pk }}"),
- Hidden("version", version),
- ButtonHolder(StrictButton(_("Envoyer"), type="submit", css_class="btn-submit")),
- )
-
- def clean(self):
- cleaned_data = super().clean()
-
- text = cleaned_data.get("text")
-
- if text is None or not text.strip():
- self._errors["text"] = self.error_class([_("Vous devez indiquer la faute commise.")])
- if "text" in cleaned_data:
- del cleaned_data["text"]
-
- elif len(text) < 3:
- self._errors["text"] = self.error_class([_("Votre commentaire doit faire au moins 3 caractères.")])
- if "text" in cleaned_data:
- del cleaned_data["text"]
-
- return cleaned_data
-
-
class PublicationForm(forms.Form):
"""
The publication form (used only for content without preliminary validation).
diff --git a/zds/tutorialv2/urls/urls_contents.py b/zds/tutorialv2/urls/urls_contents.py
index 89da39e1e1..466b528482 100644
--- a/zds/tutorialv2/urls/urls_contents.py
+++ b/zds/tutorialv2/urls/urls_contents.py
@@ -51,7 +51,7 @@
from zds.tutorialv2.views.lists import TagsListView, ContentOfAuthor, ListContentReactions
from zds.tutorialv2.views.alerts import SendContentAlert, SolveContentAlert
-from zds.tutorialv2.views.misc import RequestFeaturedContent, FollowNewContent, WarnTypo
+from zds.tutorialv2.views.misc import RequestFeaturedContent, FollowNewContent, WarnTypoView
from zds.tutorialv2.views.statistics import ContentStatisticsView
from zds.tutorialv2.views.comments import (
SendNoteFormView,
@@ -167,7 +167,7 @@ def get_version_pages():
path("alerter/ Pas assez de place ? Envoyez un MP {} !').format(
+ reverse("mp:create"), pm_title, usernames, _("à l'auteur") if num_of_authors == 1 else _("aux auteurs")
+ )
+
+ version = content.sha_beta
+ if public:
+ version = content.sha_public
+
+ # create form
+ self.helper = FormHelper()
+ self.helper.form_action = reverse("content:warn-typo") + f"?pk={content.pk}"
+ self.helper.form_method = "post"
+ self.helper.form_class = "modal modal-flex"
+ self.helper.form_id = "warn-typo-modal"
+ self.helper.layout = Layout(
+ Field("target"),
+ Field("text"),
+ HTML(msg),
+ Hidden("pk", "{{ content.pk }}"),
+ Hidden("version", version),
+ ButtonHolder(StrictButton(_("Envoyer"), type="submit", css_class="btn-submit")),
+ )
+
+ def clean(self):
+ cleaned_data = super().clean()
+
+ text = cleaned_data.get("text")
+
+ if text is None or not text.strip():
+ self._errors["text"] = self.error_class([_("Vous devez indiquer la faute commise.")])
+ if "text" in cleaned_data:
+ del cleaned_data["text"]
+
+ elif len(text) < 3:
+ self._errors["text"] = self.error_class([_("Votre commentaire doit faire au moins 3 caractères.")])
+ if "text" in cleaned_data:
+ del cleaned_data["text"]
+
+ return cleaned_data
+
+
+class WarnTypoView(SingleContentFormViewMixin):
modal_form = True
form_class = WarnTypoForm
must_be_author = False
@@ -106,9 +185,8 @@ def form_valid(self, form):
authors = list(Profile.objects.contactable_members().filter(user__in=self.object.authors.all()))
authors = list(author.user for author in authors)
- # check if the warn is done on a public or beta version :
+ # Check if the warning is done on a public or beta version
is_public = False
-
if form.content.is_public:
is_public = True
elif not form.content.is_beta:
@@ -120,35 +198,23 @@ def form_valid(self, form):
else:
messages.error(self.request, _("L'auteur est malheureusement injoignable."))
- elif user in authors: # author try to PM himself
+ elif user in authors: # Author is trying to PM himself
messages.error(self.request, _("Impossible d'envoyer la proposition de correction : vous êtes auteur."))
- else: # send correction
+ else: # Send correction
text = "\n".join(["> " + line for line in form.cleaned_data["text"].split("\n")])
-
- _type = _("l'article")
- if form.content.is_tutorial:
- _type = _("le tutoriel")
- if form.content.is_opinion:
- _type = _("le billet")
-
- pm_title = _("J'ai trouvé une faute dans {} « {} ».").format(_type, form.content.title)
-
+ pm_title = _("J'ai trouvé une faute dans « {} ».").format(form.content.title)
msg = render_to_string(
"tutorialv2/messages/warn_typo.md",
{
"user": user,
"content": form.content,
"target": form.targeted,
- "type": _type,
"public": is_public,
"text": text,
},
)
-
- # send it :
send_mp(user, authors, pm_title, "", msg, leave=False)
-
messages.success(self.request, _("Merci pour votre proposition de correction."))
return redirect(form.previous_page_url)