-
Notifications
You must be signed in to change notification settings - Fork 180
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Bug in v2.2.4 ? #414
Comments
Didn't we just change the save_new method? It's not supposed to be invoked with updates I think |
Btw, now that I'm looking again it seems that the test @jedie is running is a false negative: in the form data, they are uploading "Chapter One" with position 1 and "Chapter Two" with position 0. Thus, the result containing "Chapter Two" first and "Chapter One" second should be considered correct. |
This is exactly what the browser also send. Or exists the bug in the JavaScript part that adds the field?!? Think the playwright tests should cover this, isn't it? |
It's not a bug, it's how the library works. Even if you change the order of an item in the admin page, "Chapter One" will always have index 0 written in the form field labels, while its position field will change value according to its position. This means that it's the position field to be responsible for determining the position of Chapter One, even if the index is of the item inside the form fields is still 0. |
From an HTML perspective, PS: I've tested the latest version myself and to me it's working as intended |
Changes in 2.2.4 causes "unexpected" ordering from user's perspective, in my opinion.
The newly added row appears at the top. models.py class Child(models.Model):
name = models.CharField(max_length=200)
class Parent(models.Model):
children = models.ManyToManyField(Child, through='Through')
class Through(models.Model):
child = models.ForeignKey(Child, on_delete=models.CASCADE)
parent = models.ForeignKey(Parent, on_delete=models.CASCADE)
order = models.PositiveIntegerField(default=0)
class Meta:
ordering = ['order'] admin.py class ThroughInline(SortableStackedInline):
model = Through
readonly_fields = ['_order']
def _order(self, obj):
return obj.order
@admin.register(Parent)
class ParentAdmin(SortableAdminBase, admin.ModelAdmin):
inlines = [ThroughInline]
@admin.register(Child)
class ChildAdmin(admin.ModelAdmin):
pass |
@tmsi10 I never intended admin-sortable to be able to sort many-to-many fields. Maybe for this we need another widget anyway. In one of my other projects I created such a widget: https://django-formset.fly.dev/dual-selector/#sortable-dual-selector-widget Would this help? If so, I might port it to django-admin-sortable2 since it also is based on the Sortable.js library. |
@jrief the mentioned case is similar to the example described in https://django-admin-sortable2.readthedocs.io/en/latest/usage.html#sortable-many-to-many-relations-with-sortable-inlines Using inlines allows user to fill extra data when associating the records so I guess it cannot be replaced by the widget |
@tmsi10 to me your issue seems to be related to how the javascript sets the value of the ordering field when a new inline form gets added, which should equal one more the number of inlines present. Is that right? In other words, I think that 2.2.4 fixed a bug that worked as a feature by hiding a javascript side bug |
JavaScript side issue, yes, if there is no intention to have (some) magic values, either 0, nullish or negative number, implicitly representing "let the python side append those records at the end (in sequence)". It seems that it is pre-populated as 0 (field's default) if there is no dragging (the JavaScript sorting logic). 2.2.4 does fix a bug for the "save as new" scenario. |
I seems to me, that v2.2.3 -> v2.2.4 introduces a bug: Adding a new entry to a existing object will add it not always as a new last entry... Sometimes it will be added as the second one.
I found this bug, because a integration tests failed. It looks like:
With v2.2.3 it's correct:
['Chapter One', 'Chapter Two']
With v2.2.4 it's:
['Chapter Two', 'Chapter One']
The text was updated successfully, but these errors were encountered: