Merged pull request 97
parent
81fc032c8b
commit
01403f1b8c
|
|
@ -123,7 +123,7 @@ class SortableAdmin(SortableAdminBase, ModelAdmin):
|
||||||
|
|
||||||
# `sortable_by` defined as a SortableForeignKey
|
# `sortable_by` defined as a SortableForeignKey
|
||||||
sortable_by_fk = self.model.sortable_foreign_key
|
sortable_by_fk = self.model.sortable_foreign_key
|
||||||
|
print('sortable_by_fk: {}, {}'.format(sortable_by_fk, type(sortable_by_fk)))
|
||||||
sortable_by_class_is_sortable = check_model_is_sortable(sortable_by_fk)
|
sortable_by_class_is_sortable = check_model_is_sortable(sortable_by_fk)
|
||||||
|
|
||||||
if sortable_by_property:
|
if sortable_by_property:
|
||||||
|
|
@ -176,6 +176,7 @@ class SortableAdmin(SortableAdminBase, ModelAdmin):
|
||||||
'sortable_by_class_is_sortable': sortable_by_class_is_sortable,
|
'sortable_by_class_is_sortable': sortable_by_class_is_sortable,
|
||||||
'sortable_by_class_display_name': sortable_by_class_display_name
|
'sortable_by_class_display_name': sortable_by_class_display_name
|
||||||
}
|
}
|
||||||
|
print(context['sortable_by_class_is_sortable'])
|
||||||
return render(request, self.sortable_change_list_template, context)
|
return render(request, self.sortable_change_list_template, context)
|
||||||
|
|
||||||
def add_view(self, request, form_url='', extra_context=None):
|
def add_view(self, request, form_url='', extra_context=None):
|
||||||
|
|
|
||||||
|
|
@ -6,6 +6,7 @@
|
||||||
{% with object=regrouped_object.grouper %}
|
{% with object=regrouped_object.grouper %}
|
||||||
{% if object %}
|
{% if object %}
|
||||||
<li>
|
<li>
|
||||||
|
sortable fk is sortable: {{ sortable_by_class_is_sortable }}
|
||||||
{% if sortable_by_class_is_sortable %}
|
{% if sortable_by_class_is_sortable %}
|
||||||
{% render_object_rep object %}
|
{% render_object_rep object %}
|
||||||
{% else %}
|
{% else %}
|
||||||
|
|
|
||||||
|
|
@ -3,4 +3,4 @@
|
||||||
<form>
|
<form>
|
||||||
<input name="pk" type="hidden" value="{{ object.pk }}" />
|
<input name="pk" type="hidden" value="{{ object.pk }}" />
|
||||||
</form>
|
</form>
|
||||||
<a href="{% url 'admin:admin_do_sorting' object.model_type_id %}" class="admin_sorting_url">{{ object }}</a>
|
<a href="{# url 'admin:admin_do_sorting' object.model_type_id #}" class="admin_sorting_url">{{ object }}</a>
|
||||||
|
|
|
||||||
|
|
@ -25,6 +25,5 @@ def check_model_is_sortable(cls):
|
||||||
else:
|
else:
|
||||||
objects = cls.objects
|
objects = cls.objects
|
||||||
|
|
||||||
if objects.count() > 1:
|
return get_is_sortable(objects.all())
|
||||||
return True
|
|
||||||
return False
|
return False
|
||||||
|
|
|
||||||
|
|
@ -71,13 +71,13 @@ class ProjectAdmin(SortableAdmin):
|
||||||
CreditInline, NoteInline, GenericNoteInline,
|
CreditInline, NoteInline, GenericNoteInline,
|
||||||
NonSortableCreditInline, NonSortableNoteInline
|
NonSortableCreditInline, NonSortableNoteInline
|
||||||
]
|
]
|
||||||
list_display = ['__unicode__', 'category']
|
list_display = ['__str__', 'category']
|
||||||
|
|
||||||
admin.site.register(Project, ProjectAdmin)
|
admin.site.register(Project, ProjectAdmin)
|
||||||
|
|
||||||
|
|
||||||
class PersonAdmin(SortableAdmin):
|
class PersonAdmin(SortableAdmin):
|
||||||
list_display = ['__unicode__', 'is_board_member']
|
list_display = ['__str__', 'is_board_member']
|
||||||
|
|
||||||
admin.site.register(Person, PersonAdmin)
|
admin.site.register(Person, PersonAdmin)
|
||||||
|
|
||||||
|
|
|
||||||
|
|
@ -1,18 +1,20 @@
|
||||||
from django.contrib.contenttypes import generic
|
from django.contrib.contenttypes import generic
|
||||||
from django.contrib.contenttypes.models import ContentType
|
from django.contrib.contenttypes.models import ContentType
|
||||||
from django.db import models
|
from django.db import models
|
||||||
|
from django.utils.encoding import python_2_unicode_compatible
|
||||||
|
|
||||||
from adminsortable.fields import SortableForeignKey
|
from adminsortable.fields import SortableForeignKey
|
||||||
from adminsortable.models import Sortable
|
from adminsortable.models import Sortable
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SimpleModel(models.Model):
|
class SimpleModel(models.Model):
|
||||||
class Meta:
|
class Meta:
|
||||||
abstract = True
|
abstract = True
|
||||||
|
|
||||||
title = models.CharField(max_length=50)
|
title = models.CharField(max_length=50)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -28,11 +30,12 @@ class Category(SimpleModel, Sortable):
|
||||||
|
|
||||||
|
|
||||||
# A model with an override of its queryset for admin
|
# A model with an override of its queryset for admin
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Widget(SimpleModel, Sortable):
|
class Widget(SimpleModel, Sortable):
|
||||||
class Meta(Sortable.Meta):
|
class Meta(Sortable.Meta):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
|
|
@ -47,6 +50,7 @@ class Project(SimpleModel, Sortable):
|
||||||
|
|
||||||
|
|
||||||
# Registered as a tabular inline on `Project`
|
# Registered as a tabular inline on `Project`
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Credit(Sortable):
|
class Credit(Sortable):
|
||||||
class Meta(Sortable.Meta):
|
class Meta(Sortable.Meta):
|
||||||
pass
|
pass
|
||||||
|
|
@ -55,11 +59,12 @@ class Credit(Sortable):
|
||||||
first_name = models.CharField(max_length=30)
|
first_name = models.CharField(max_length=30)
|
||||||
last_name = models.CharField(max_length=30)
|
last_name = models.CharField(max_length=30)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '{0} {1}'.format(self.first_name, self.last_name)
|
return '{0} {1}'.format(self.first_name, self.last_name)
|
||||||
|
|
||||||
|
|
||||||
# Registered as a stacked inline on `Project`
|
# Registered as a stacked inline on `Project`
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Note(Sortable):
|
class Note(Sortable):
|
||||||
class Meta(Sortable.Meta):
|
class Meta(Sortable.Meta):
|
||||||
pass
|
pass
|
||||||
|
|
@ -67,30 +72,33 @@ class Note(Sortable):
|
||||||
project = models.ForeignKey(Project)
|
project = models.ForeignKey(Project)
|
||||||
text = models.CharField(max_length=100)
|
text = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.text
|
return self.text
|
||||||
|
|
||||||
|
|
||||||
# Registered as a tabular inline on `Project` which can't be sorted
|
# Registered as a tabular inline on `Project` which can't be sorted
|
||||||
|
@python_2_unicode_compatible
|
||||||
class NonSortableCredit(models.Model):
|
class NonSortableCredit(models.Model):
|
||||||
project = models.ForeignKey(Project)
|
project = models.ForeignKey(Project)
|
||||||
first_name = models.CharField(max_length=30)
|
first_name = models.CharField(max_length=30)
|
||||||
last_name = models.CharField(max_length=30)
|
last_name = models.CharField(max_length=30)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '{0} {1}'.format(self.first_name, self.last_name)
|
return '{0} {1}'.format(self.first_name, self.last_name)
|
||||||
|
|
||||||
|
|
||||||
# Registered as a stacked inline on `Project` which can't be sorted
|
# Registered as a stacked inline on `Project` which can't be sorted
|
||||||
|
@python_2_unicode_compatible
|
||||||
class NonSortableNote(models.Model):
|
class NonSortableNote(models.Model):
|
||||||
project = models.ForeignKey(Project)
|
project = models.ForeignKey(Project)
|
||||||
text = models.CharField(max_length=100)
|
text = models.CharField(max_length=100)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.text
|
return self.text
|
||||||
|
|
||||||
|
|
||||||
# A generic bound model
|
# A generic bound model
|
||||||
|
@python_2_unicode_compatible
|
||||||
class GenericNote(SimpleModel, Sortable):
|
class GenericNote(SimpleModel, Sortable):
|
||||||
content_type = models.ForeignKey(ContentType,
|
content_type = models.ForeignKey(ContentType,
|
||||||
verbose_name=u"Content type", related_name="generic_notes")
|
verbose_name=u"Content type", related_name="generic_notes")
|
||||||
|
|
@ -101,22 +109,23 @@ class GenericNote(SimpleModel, Sortable):
|
||||||
class Meta(Sortable.Meta):
|
class Meta(Sortable.Meta):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return u'{0}: {1}'.format(self.title, self.content_object)
|
return u'{0}: {1}'.format(self.title, self.content_object)
|
||||||
|
|
||||||
|
|
||||||
# An model registered as an inline that has a custom queryset
|
# An model registered as an inline that has a custom queryset
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Component(SimpleModel, Sortable):
|
class Component(SimpleModel, Sortable):
|
||||||
class Meta(Sortable.Meta):
|
class Meta(Sortable.Meta):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
widget = SortableForeignKey(Widget)
|
widget = SortableForeignKey(Widget)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class Person(Sortable):
|
class Person(Sortable):
|
||||||
class Meta(Sortable.Meta):
|
class Meta(Sortable.Meta):
|
||||||
verbose_name_plural = 'People'
|
verbose_name_plural = 'People'
|
||||||
|
|
@ -134,19 +143,21 @@ class Person(Sortable):
|
||||||
('Non-Board Members', {'is_board_member': False}),
|
('Non-Board Members', {'is_board_member': False}),
|
||||||
)
|
)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return '{0} {1}'.format(self.first_name, self.last_name)
|
return '{0} {1}'.format(self.first_name, self.last_name)
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class NonSortableCategory(SimpleModel):
|
class NonSortableCategory(SimpleModel):
|
||||||
class Meta(SimpleModel.Meta):
|
class Meta(SimpleModel.Meta):
|
||||||
verbose_name = 'Non-Sortable Category'
|
verbose_name = 'Non-Sortable Category'
|
||||||
verbose_name_plural = 'Non-Sortable Categories'
|
verbose_name_plural = 'Non-Sortable Categories'
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SortableCategoryWidget(SimpleModel, Sortable):
|
class SortableCategoryWidget(SimpleModel, Sortable):
|
||||||
class Meta(Sortable.Meta):
|
class Meta(Sortable.Meta):
|
||||||
verbose_name = 'Sortable Category Widget'
|
verbose_name = 'Sortable Category Widget'
|
||||||
|
|
@ -154,20 +165,21 @@ class SortableCategoryWidget(SimpleModel, Sortable):
|
||||||
|
|
||||||
non_sortable_category = SortableForeignKey(NonSortableCategory)
|
non_sortable_category = SortableForeignKey(NonSortableCategory)
|
||||||
|
|
||||||
def __unicode__(self):
|
def __str__(self):
|
||||||
return self.title
|
return self.title
|
||||||
|
|
||||||
|
|
||||||
|
@python_2_unicode_compatible
|
||||||
class SortableNonInlineCategory(SimpleModel, Sortable):
|
class SortableNonInlineCategory(SimpleModel, Sortable):
|
||||||
"""Example of a model that is sortable, but has a SortableForeignKey
|
"""Example of a model that is sortable, but has a SortableForeignKey
|
||||||
that is *not* sortable, and is also not defined as an inline of the
|
that is *not* sortable, and is also not defined as an inline of the
|
||||||
SortableForeignKey field."""
|
SortableForeignKey field."""
|
||||||
|
|
||||||
|
non_sortable_category = SortableForeignKey(NonSortableCategory)
|
||||||
|
|
||||||
class Meta(Sortable.Meta):
|
class Meta(Sortable.Meta):
|
||||||
verbose_name = 'Sortable Non-Inline Category'
|
verbose_name = 'Sortable Non-Inline Category'
|
||||||
verbose_name_plural = 'Sortable Non-Inline Categories'
|
verbose_name_plural = 'Sortable Non-Inline Categories'
|
||||||
|
|
||||||
non_sortable_category = SortableForeignKey(NonSortableCategory)
|
def __str__(self):
|
||||||
|
|
||||||
def __unicode__(self):
|
|
||||||
return self.title
|
return self.title
|
||||||
|
|
|
||||||
Binary file not shown.
|
|
@ -1,5 +1,11 @@
|
||||||
# Django settings for test_project project.
|
# Django settings for test_project project.
|
||||||
from utils import map_path
|
import os
|
||||||
|
|
||||||
|
|
||||||
|
def map_path(directory_name):
|
||||||
|
return os.path.join(os.path.dirname(__file__),
|
||||||
|
'../' + directory_name).replace('\\', '/')
|
||||||
|
|
||||||
|
|
||||||
DEBUG = True
|
DEBUG = True
|
||||||
TEMPLATE_DEBUG = DEBUG
|
TEMPLATE_DEBUG = DEBUG
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue