Django - В форме ModelForm отображать данные, поступающие из модели, связанной M2M-отношением

Я создал форму для модели, включающую поле, исходящее из другой модели, связанной M2M-отношениями. Форма работает правильно, но я хотел бы добавить подробные данные из этой другой модели, и у меня ничего не получилось.
Основной моделью является Event, и она связана с Groups благодаря этой связи; в форме все группы перечислены и отображаются с флажками, но я могу отобразить только название групп, никакой другой информации.
. Похоже, что мне не хватает некоторых данных / информации: название группы отображается только потому, что я использую {{grp}}} (см. ниже), но у него нет атрибута / доступного файла, даже если он инициализирован запросом из модели группы.
Есть идеи, что я сделал неправильно, или любой совет, чтобы справиться с этим? Заранее спасибо.

Здесь представлены связанные части кода.
Модели:

class UserGroup(models.Model):
    company = models.ForeignKey(
        Company, on_delete=models.CASCADE, verbose_name="société"
    )
    users = models.ManyToManyField(UserComp, verbose_name="utilisateurs", blank=True)
    group_name = models.CharField("nom", max_length=100)
    weight = models.IntegerField("poids", default=0)
    hidden = models.BooleanField(default=False)

    def __str__(self):
        return self.group_name

class Event(models.Model):
    company = models.ForeignKey(
        Company, on_delete=models.CASCADE, verbose_name="société"
    )
    groups = models.ManyToManyField(UserGroup, verbose_name="groupes", blank=True)
    rules = [("MAJ", "Majorité"), ("PROP", "Proportionnelle")]
    event_name = models.CharField("nom", max_length=200)
    event_date = models.DateField("date de l'événement")
    slug = models.SlugField()
    current = models.BooleanField("en cours", default=False)
    quorum = models.IntegerField(default=33)
    rule = models.CharField(
        "mode de scrutin", max_length=5, choices=rules, default="MAJ"
    )

    class Meta:
        verbose_name = "Evénement"
        constraints = [
            models.UniqueConstraint(fields=["company_id", "slug"], name="unique_event_slug")
        ]

    def __str__(self):
        return self.event_name

Форма:

class EventDetail(forms.ModelForm):
    groups = forms.ModelMultipleChoiceField(
        label = "Liste des groupes",
        queryset = None,
        widget = forms.CheckboxSelectMultiple,
        required = False
        )

    class Meta:
        model = Event
        fields = ['event_name', 'event_date', 'quorum', 'rule', 'groups']


    def __init__(self, *args, **kwargs):
        super().__init__(*args, **kwargs)
        instance = kwargs.get('instance', None)
        self.fields['groups'].queryset= UserGroup.objects.\
                                                filter(company=instance.company).\
                                                order_by('group_name')

Вид:

@user_passes_test(lambda u: u.is_superuser or (u.id is not None and u.usercomp.is_admin))
def adm_event_detail(request, comp_slug, evt_id=0):
    '''
        Manage events creation and options
    '''
    company = Company.get_company(request.session['comp_slug'])
    # all_groups = list(UserGroup.objects.filter(company=company, hidden=False).order_by('group_name').values())

    if evt_id > 0:
        current_event = Event.objects.get(id=evt_id)
        event_form = EventDetail(request.POST or None, instance=current_event)

    else:
        event_form = EventDetail(request.POST or None)

    event_form.fields['groups'].queryset = UserGroup.objects.\
                                                        filter(company=company, hidden=False).\
                                                        order_by('group_name')
    
    if request.method == 'POST':
        if event_form.is_valid():
            if evt_id == 0:
                # Create new event
                event_data = {
                    "company": company,
                    "groups": event_form.cleaned_data["groups"],
                    "event_name": event_form.cleaned_data["event_name"],
                    "event_date": event_form.cleaned_data["event_date"],
                    "quorum": event_form.cleaned_data["quorum"],
                    "rule":event_form.cleaned_data["rule"]
                }
                new_event = Event.create_event(event_data)
            else:
                new_event = event_form.save()

        else:
            print("****** FORMULAIRE NON VALIDE *******")
            print(event_form.errors)

    return render(request, "polls/adm_event_detail.html", locals())

HTML (я не поместил все части виджета 'accordion', я не думаю, что они имеют отношение к проблеме):

{% if evt_id %}
<form action="{% url 'polls:adm_event_detail' company.comp_slug evt_id %}" method="post">
{% else %}
<form action="{% url 'polls:adm_create_event' company.comp_slug %}" method="post">
{% endif %}
    {% csrf_token %}

    <!-- Hidden field where the referer is identified to go back to the related page after validation -->
    <input type="hidden" name="url_dest" value="{{ url_dest }}" />

    <br>

    <!-- Accordion -->
    <div id="eventDetails" class="accordion shadow">

        <div class="card">
            <div class="card-header bg-white shadow-sm border-0">
                <h6 class="mb-0 font-weight-bold">
                    Evénement
                </h6>
            </div>
            <div class="card-body p-5">
                <p>Nom : {{event_form.event_name}} </p>
                <p>Date : {{event_form.event_date}} </p>
            </div>
        </div>

        <!-- Accordion item 2 - Event's groups -->
        <div class="card">
        <div id="headingTwo" class="card-header bg-white shadow-sm border-0">
            <h6 class="mb-0 font-weight-bold">
                <a href="#" data-toggle="collapse" data-target="#collapseTwo" aria-expanded="false" aria-controls="collapseTwo" class="d-block position-relative collapsed text-dark collapsible-link py-2">
                    Groupes d'utilisateurs
                </a>
            </h6>
        </div>
        <div id="collapseTwo" aria-labelledby="headingTwo" data-parent="#eventDetails" class="collapse show">
            <div class="card-body p-5">
                <p>Sélectionnez le(s) groupe(s) d'utilisateurs participants à l'événement :</p>
                <ul>
                {% for grp in event_form.groups %}
                    <li>{{ grp }}
                        {{ grp.weight }}
                        {{ grp.hidden }}
                        {{ grp.nb_users }}
                    </li>
                {% endfor %}
                </ul>

                <p></p>
            </div>
        </div>
        </div>

    </div> <!-- Accordion end -->


    <button class="btn btn-success mt-5" type="submit">{% if evt_id %}Mettre à jour{% else %}Créer{% endif %}</button>
    &nbsp &nbsp &nbsp
    <a class="btn btn-secondary back_btn mt-5" href="*">Annuler</a>
    <div class="row">
        <div hidden>
            <!-- List of groups in event -->
            {{ event_form.group_list }}
        </div>
    </div>
</form>

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

Также обратите внимание, что при запросе связанных моделей вы получаете объект менеджера отношений. Следовательно, используйте .all для запроса всех групп.

Попробовать

     <ul>
         {% for grp in event_form.instance.groups.all %}
             <li>{{ grp }}
                 {{ grp.weight }}
                 {{ grp.hidden }}
                 {{ grp.nb_users }}
                </li>
         {% endfor %}
     </ul>
Вернуться на верх