Active / Inactive model manager

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
class ActiveInactiveManager(models.Manager):
    """
    Used for models with active_date and inactive_date. Adds an "active" 
    filter to get only active items
    """
    def active(self):
        return self.filter(
            Q(active_date=None)   | Q(active_date__lte=now),
            Q(inactive_date=None) | Q(inactive_date__gt=now)
        )


# Usage in model:
class MyModel(models.Model):
    #...
    active_date = models.DateField()
    inactive_date = models.DateField()

    objects = ActiveInactiveManager()

"""
# usage example
>>> MyModel.objects.active()
>>> MyModel.objects.active().filter(category='whatever')
"""

More like this

  1. ActiveManager: filter objects depending on publication and/or expiration dates by haplo 4 years, 10 months ago
  2. Easier chainability with custom QuerySets by bendavis78 1 year, 2 months ago
  3. RandomObjectManager by jjdelc 2 years, 2 months ago
  4. Timestamps in Model by lindsayrgwatt 4 years, 8 months ago
  5. CustomQueryManager by zvoase 4 years, 10 months ago

Comments

(Forgotten your password?)