aboutsummaryrefslogtreecommitdiff
path: root/models.py
diff options
context:
space:
mode:
authorAlban Gruin2017-02-11 13:45:14 +0100
committerAlban Gruin2017-02-11 13:45:14 +0100
commit26a132d5d1fdb7fc9da827bbc9d5e409834fb954 (patch)
tree94c7c7dc55efd419e757008714891eb3fb47bc66 /models.py
parent64f7dedf227a88bac522cb34c6a99982b3d65321 (diff)
Suppression du GroupedManager et de toutes ses sous-classes
Diffstat (limited to 'models.py')
-rw-r--r--models.py19
1 files changed, 10 insertions, 9 deletions
diff --git a/models.py b/models.py
index 1723536..68e1e84 100644
--- a/models.py
+++ b/models.py
@@ -15,17 +15,19 @@
# 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
from django.db import connection, models
-from django.db.models import Q
+from django.db.models import Count, Manager, Q
from django.db.models.expressions import RawSQL
-from django.db.models.functions import ExtractYear
+from django.db.models.functions import Extract, ExtractYear
from django.utils.text import slugify
-from .db import ExtractWeek, GroupedManager
-
import hashlib
import os
+class ExtractWeek(Extract):
+ lookup_name = "week"
+
+
class Timetable(models.Model):
name = models.CharField(max_length=64, unique=True, verbose_name="nom")
url = models.URLField(max_length=255, unique=True, verbose_name="URL")
@@ -141,15 +143,14 @@ class Room(models.Model):
verbose_name_plural = "salles"
-class CourseManager(GroupedManager):
+class CourseManager(Manager):
def __get_weeks(self, qs):
- extractYear = ExtractYear("begin")
- qs = qs.group_by("groups", "year", "week", "groups__timetable", "groups__mention", "groups__subgroup", "groups__td", "groups__tp", "begin", "groups__name").order_by("groups__name", "year", "week")
+ qs = qs.order_by("groups__name", "year", "week").annotate(_=Count(("groups", "year", "week", "begin")), year=ExtractYear("begin"))
if connection.vendor == "postgresql":
- return qs.annotate(week=ExtractWeek("begin"), year=extractYear)
+ return qs.annotate(week=ExtractWeek("begin"))
else:
- return qs.annotate(week=RawSQL("""cast(strftime("%%W", "begin") as integer)""", []), year=extractYear)
+ return qs.annotate(week=RawSQL("""cast(strftime("%%W", "begin") as integer)""", []))
def get_courses_for_group(self, group, **filters):
return self.get_queryset().filter(Q(groups__td__isnull=True) | Q(groups__td=group.td), Q(groups__tp__isnull=True) | Q(groups__tp=group.tp), groups__mention=group.mention, groups__subgroup=group.subgroup, timetable=group.timetable, **filters).order_by("begin")