Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
*.py[co]
*.egg-info/
31 changes: 25 additions & 6 deletions treeadmin/admin.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,9 +3,13 @@
from django.contrib.admin.views import main
from django.db.models import Q
from django.http import HttpResponse, HttpResponseBadRequest, HttpResponseForbidden, HttpResponseNotFound, HttpResponseServerError
from django.utils import simplejson
try:
import django.utils.simplejson
except:
import json as simplejson
from django.utils.safestring import mark_safe
from django.utils.translation import ugettext_lazy as _, ugettext
from django import VERSION as django_version

from mptt.exceptions import InvalidMove

Expand Down Expand Up @@ -48,7 +52,9 @@ def _build_tree_structure(cls):
else:
mptt_opts = cls._meta

for p_id, parent_id in cls.objects.order_by(mptt_opts.tree_id_attr, mptt_opts.left_attr).values_list("pk", "%s_id" % mptt_opts.parent_attr):
values_list = [tuple(dct.values()) for dct in cls.objects.order_by(mptt_opts.tree_id_attr, mptt_opts.left_attr).values("pk", "%s_id" % mptt_opts.parent_attr)]

for p_id, parent_id in values_list:
all_nodes[p_id] = []

if parent_id:
Expand Down Expand Up @@ -127,9 +133,22 @@ def __init__(self, request, *args, **kwargs):
self.user = request.user
super(ChangeList, self).__init__(request, *args, **kwargs)

def get_query_set(self, *args, **kwargs):
def get_queryset(self, *args, **kwargs):
mptt_opts = self.model._mptt_meta
return super(ChangeList, self).get_query_set(*args, **kwargs).order_by(mptt_opts.tree_id_attr, mptt_opts.left_attr)
get_qs = getattr(super(ChangeList, self), 'get_queryset', super(ChangeList, self).get_query_set)
return get_qs(*args, **kwargs).order_by(mptt_opts.tree_id_attr, mptt_opts.left_attr)

if django_version < (1, 6):
get_query_set = get_queryset

@property
def query_set(self):
return self.queryset

@query_set.setter
def query_set(self, qs):
self.queryset = qs


def get_results(self, request):
mptt_opts = self.model._mptt_meta
Expand All @@ -139,9 +158,9 @@ def get_results(self, request):
mptt_opts.left_attr + '__lte': lft,
mptt_opts.right_attr + '__gte': rght,
}) for lft, rght, tree_id in \
self.query_set.values_list(mptt_opts.left_attr, mptt_opts.right_attr, mptt_opts.tree_id_attr)]
self.queryset.values_list(mptt_opts.left_attr, mptt_opts.right_attr, mptt_opts.tree_id_attr)]
if clauses:
self.query_set = self.model._default_manager.filter(reduce(lambda p, q: p|q, clauses))
self.queryset = self.model._default_manager.filter(reduce(lambda p, q: p|q, clauses))

super(ChangeList, self).get_results(request)

Expand Down