Mercurial > public > sg101
view banners/models.py @ 1037:7e0c3cbd3cda
Fix bad select_related call.
In Django 1.8, select_related now throws an error if you give it an invalid
field. This was happening. Fix that query.
Also noticed an extra query generated in the display_post template. Fixed.
author | Brian Neal <bgneal@gmail.com> |
---|---|
date | Tue, 29 Dec 2015 22:21:42 -0600 |
parents | ee87ea74d46b |
children |
line wrap: on
line source
""" Models for the banners application. """ import datetime from django.db import models class Campaign(models.Model): """ A model to represent an ad or banner campaign. """ name = models.CharField(max_length=128) slug = models.SlugField() creation_date = models.DateTimeField(blank=True) def __unicode__(self): return self.name class Meta: ordering = ['name'] def save(self, *args, **kwargs): if not self.pk and not self.creation_date: self.creation_date = datetime.datetime.now() super(Campaign, self).save(*args, **kwargs) def banner_upload_to(instance, filename): """ An "upload_to" function for the Banner model. """ return "banners/%s/%s" % (instance.campaign.slug, filename) class Banner(models.Model): """ A model to represent a banner. """ campaign = models.ForeignKey(Campaign) image = models.ImageField(upload_to=banner_upload_to) description = models.CharField(max_length=128) creation_date = models.DateTimeField(blank=True) def __unicode__(self): return self.description class Meta: ordering = ['-creation_date'] def save(self, *args, **kwargs): if not self.pk and not self.creation_date: self.creation_date = datetime.datetime.now() super(Banner, self).save(*args, **kwargs)