Merged pull request 97

master
Brandon Taylor 2014-12-22 10:25:35 -05:00
parent 81fc032c8b
commit 01403f1b8c
8 changed files with 41 additions and 22 deletions

View File

@ -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):

View File

@ -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 %}

View File

@ -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>

View File

@ -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

View File

@ -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)

View File

@ -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

View File

@ -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