Author: floguy
Date: Sun Sep 21 02:13:55 2008
New Revision: 919

Modified:
    trunk/local_apps/projects/thing.py
    trunk/local_apps/tribes/thing.py

Log:
Fixed support for ordering tribes and projects by number of members.

Modified: trunk/local_apps/projects/thing.py
==============================================================================
--- trunk/local_apps/projects/thing.py  (original)
+++ trunk/local_apps/projects/thing.py  Sun Sep 21 02:13:55 2008
@@ -1,13 +1,28 @@
  import things
+from django.db import connection

  class ProjectThing(things.ModelThing):
      created = things.OrderField(verbose_name_asc='Oldest',
          verbose_name_desc='Newest', url_asc='oldest', url_desc='newest',
          field_url='date')
      name = things.OrderField()
-    member_users = things.OrderField(verbose_name_asc='Largest',
-        verbose_name_desc='Smallest', url_asc='largest',  
url_desc='smallest',
+    member_count = things.OrderField(verbose_name_asc='Smallest',
+        verbose_name_desc='Largest', url_asc='smallest',  
url_desc='largest',
          field_url='size')
      search = ('name', 'description')
      template_dir = 'projects'
-    list_template_name = 'projects.html'
\ No newline at end of file
+    list_template_name = 'projects.html'
+
+    def get_query_set(self, m2m_name='member_users'):
+        m2m_field = self.model._meta.get_field(m2m_name)
+        qn = connection.ops.quote_name
+        SQL = """
+        SELECT COUNT(*)
+        FROM %(m2m_table)s
+        WHERE %(m2m_table)s.%(column_name)s = %(self_table)s.id
+        """ % {
+            'm2m_table': qn(m2m_field.m2m_db_table()),
+            'column_name': qn(m2m_field.m2m_column_name()),
+            'self_table': qn(self.model._meta.db_table),
+        }
+        return self.model._default_manager.extra(select={'member_count':  
SQL})
\ No newline at end of file

Modified: trunk/local_apps/tribes/thing.py
==============================================================================
--- trunk/local_apps/tribes/thing.py    (original)
+++ trunk/local_apps/tribes/thing.py    Sun Sep 21 02:13:55 2008
@@ -1,13 +1,29 @@
  import things
+from django.db import connection

  class TribeThing(things.ModelThing):
      created = things.OrderField(verbose_name_asc='Oldest',
          verbose_name_desc='Newest', url_asc='oldest', url_desc='newest',
          field_url='date')
      name = things.OrderField()
-    members = things.OrderField(verbose_name_asc='Largest',
-        verbose_name_desc='Smallest', url_asc='largest',  
url_desc='smallest',
+    member_count = things.OrderField(verbose_name_asc='Smallest',
+        verbose_name_desc='Largest', url_asc='smallest',  
url_desc='largest',
          field_url='size')
      search = ('name', 'description')
      template_dir = 'tribes'
-    list_template_name = 'tribes.html'
\ No newline at end of file
+    list_template_name = 'tribes.html'
+
+    def get_query_set(self, m2m_name='members'):
+        m2m_field = self.model._meta.get_field(m2m_name)
+        qn = connection.ops.quote_name
+        SQL = """
+        SELECT COUNT(*)
+        FROM %(m2m_table)s
+        WHERE %(m2m_table)s.%(column_name)s = %(self_table)s.id
+        """ % {
+            'm2m_table': qn(m2m_field.m2m_db_table()),
+            'column_name': qn(m2m_field.m2m_column_name()),
+            'self_table': qn(self.model._meta.db_table),
+        }
+        print SQL
+        return self.model._default_manager.extra(select={'member_count':  
SQL})
\ No newline at end of file

--~--~---------~--~----~------------~-------~--~----~
You received this message because you are subscribed to the Google Groups 
"pinax-updates" group.
To post to this group, send email to [email protected]
To unsubscribe from this group, send email to [EMAIL PROTECTED]
For more options, visit this group at 
http://groups.google.com/group/pinax-updates?hl=en
-~----------~----~----~----~------~----~------~--~---

Reply via email to