Django как добавить форму в DetailView с помощью FormMixin

Я пытаюсь добавить форму для комментариев в DetailView. В DetailView отображаются заметки для конкретных проектов. Поэтому комментарии имеют внешний ключ, который является конкретным примечанием, а примечание имеет внешний ключ для конкретного проекта.

Я пытаюсь использовать FormMixin с DetailView. Пока что у меня ничего не получилось. В настоящее время я могу заставить форму отображаться, но она не сохраняется, и в терминале я вижу следующую ошибку Method Not Allowed (POST): /projects/project/1/note/1/

Я могу заставить их работать отдельно, но не с формой в DetailView.

Вот мои модели:

class ProjectNotes(models.Model):
    title = models.CharField(max_length=200)
    body = tinymce_models.HTMLField()
    date = models.DateField(auto_now_add=True)
    project = models.ForeignKey(Project, default=0, blank=True, on_delete=models.CASCADE, related_name='notes')

    def __str__(self):
        return self.title
class ProjectNoteComments(models.Model):
    body = tinymce_models.HTMLField()
    date = models.DateField(auto_now_add=True)
    projectnote = models.ForeignKey(ProjectNotes, default=0, blank=True, on_delete=models.CASCADE, related_name='comments')

Вид:

class ProjectNotesDetailView(DetailView, FormMixin):
    model = ProjectNotes
    id = ProjectNotes.objects.only('id')
    template_name = 'company_accounts/project_note_detail.html'
    comments = ProjectNotes.comments
    form_class = NoteCommentForm

    def form_valid(self, form):
        projectnote = get_object_or_404(ProjectNotes, id=self.kwargs.get('pk'))
        comment = form.save(commit=False)
        comment.projectnote = projectnote
        comment.save()
        return super().form_valid(form)

    def get_success_url(self):
        return reverse('project_detail', args=[self.kwargs.get('pk')])

Форма:

class NoteCommentForm(forms.ModelForm):
    class Meta:
        model = ProjectNoteComments
        fields =['body',]

        widgets = {
            'body': forms.TextInput(attrs={'class': 'form-control'})
        }

Шаблон:

% extends 'base.html' %}
{% load crispy_forms_tags %}

{% block content %}
<div class="section-container container">
  <div class="project-entry">
    <h2>{{ projectnotes.title }}</h2>
    <p>{{ projectnotes.body | safe }}</p>
  </div>
  <div><b>Comments on {{projectnotes.title}}</b></div>
  {% if projectnotes.comments.all %}
    {% for comment in projectnotes.comments.all %}
        <div class="notecomments" style="padding: 10px;">
          
            {{ comment.body | safe }}
         
            
        </div>
      {% endfor %}
    {% else %}
    <p>No comments have been have been added yet.</p>
    {% endif %}
  
  <h2><a href="">add note</a></h2>
  
  <h1>Add Comment</h1>
  
   <form action="" method="post">
    {% csrf_token %}
    {{ form.media }}
    {{ form|crispy }}
    <input type="submit" value="save">
   </form>
  
{% endblock content %}

Попробуйте изменить порядок между DetailView и FormMixin в ProjectNotesDetailView затем реализуйте метод post (включенный `FormMixin):

class ProjectNotesDetailView(FormMixin, DetailView):
    model = ProjectNotes
    id = ProjectNotes.objects.only('id')
    template_name = 'company_accounts/project_note_detail.html'
    comments = ProjectNotes.comments
    form_class = NoteCommentForm

    def form_valid(self, form):
        projectnote = get_object_or_404(ProjectNotes, id=self.kwargs.get('pk'))
        comment = form.save(commit=False)
        comment.projectnote = projectnote
        comment.save()
        return super().form_valid(form)

    def get_success_url(self):
        return reverse('project_detail', args=[self.kwargs.get('pk')])



    def post(self, request, *args, **kwargs):
        if not request.user.is_authenticated:
            return HttpResponseForbidden()
        self.object = self.get_object()
        form = self.get_form()
        if form.is_valid():
            return self.form_valid(form)
        else:
            return self.form_invalid(form)

Проверьте, как использовать formmixin с detailview (документация).

Вернуться на верх