You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
When a Page features more than one EditTable, the Save feature breaks sometimes if the order of the EditTables differs from the order of the Models in the models.py file.
#588
Open
leethobbit opened this issue
Oct 15, 2024
· 2 comments
Issue: When using multiple EditTables on a page, and when the order of the EditTables is different from the order that the models appear in the models.py file, the Save feature of the 2nd table seems to break and no longer submit new rows.
In my example, I have models for Role and Person at a business. The Role model appears before the Person model in the models.py.
Code in use:
models.py
fromdjango.dbimportmodelsclassRole(models.Model):
name=models.CharField(max_length=80, unique=True)
description=models.TextField(blank=True, null=False, default="")
def__str__(self):
""" Required method to see the name field when a form is created with this model """returnself.namedefget_absolute_url(self):
returnf"/people/roles/{self.id}/"# class Person# TODO Sort out how to link donations to a person, and sum themclassPerson(models.Model):
first_name=models.CharField(max_length=80, null=False, default="")
last_name=models.CharField(max_length=80, null=False, default="")
email=models.EmailField(null=False, default="[email protected]")
phone_number=models.CharField(max_length=20, default="555-5555")
roles=models.ManyToManyField(Role)
address=models.CharField(max_length=250, default="")
zip_code=models.IntegerField(default=44121)
notes=models.TextField(blank=True, null=False, default="")
def__str__(self):
""" Required method to see the name field when a form is created with this model """returnself.first_name+" "+self.last_namedefget_absolute_url(self):
returnf"/people/{self.id}/"
fromdjango.shortcutsimportget_object_or_404fromdjango.urlsimportpathfromiommiimportFormfromiommiimportPagefromiommiimporthtmlimportoar.people.viewsaspeople_viewsfrom .modelsimportPersonfrom .modelsimportRoleapp_name="people"# Menu# Tables# PagesclassPeopleIndex(Page):
people_title=html.h1("People")
hr1=html.hr("")
people=people_views.people_tablebr2=html.br("")
roles_title=html.h1("Roles")
hr2=html.hr("")
roles=people_views.roles_table# The order here causes a problem
If I place them on a Page with the Role EditTable first, things work as expected. If I flip them, the Role EditTable (which now appears second) will no longer save new rows. I was able to replicate this with multiple other models from different apps in my project so it seems consistent across the board.
Hope I have provided enough details to narrow down the issue. If I discover more I'll add to this post.
The text was updated successfully, but these errors were encountered:
Interesting. I tested with both 7.5.1 and 7.6.0 and encounter the situation in both versions. I've been using classes to define my index Pages, which is where the trouble shows up.
Additionally, it seems there are more inconsistencies here than I noticed previously. One of my apps in this project is behaving as expected. So, I need to investigate further on my end.
Issue: When using multiple EditTables on a page, and when the order of the EditTables is different from the order that the models appear in the models.py file, the Save feature of the 2nd table seems to break and no longer submit new rows.
In my example, I have models for Role and Person at a business. The Role model appears before the Person model in the models.py.
Code in use:
models.py
views.py
urls.py
If I place them on a Page with the Role EditTable first, things work as expected. If I flip them, the Role EditTable (which now appears second) will no longer save new rows. I was able to replicate this with multiple other models from different apps in my project so it seems consistent across the board.
Hope I have provided enough details to narrow down the issue. If I discover more I'll add to this post.
The text was updated successfully, but these errors were encountered: