groups = models.ManyToManyField(Group)
def __unicode__(self):
- return self.name
+ return "%s%s" % (self.name, (" / %s" % (" ^ ".join(g.shortName if (g.shortName != '') else g.name for g in self.groups.all()), )))
class Party(models.Model):
name = models.CharField(max_length = 80)
year = models.IntegerField()
compo = models.ForeignKey(Compo)
place = models.IntegerField()
- pouetId = models.IntegerField(blank = True)
+ pouetId = models.IntegerField(blank = True, null = True)
def __unicode__(self):
return self.compo.__unicode__() + ' @ ' + self.party.__unicode__() + ' ' + '%d' % self.year
+class TrackArtist(models.Model):
+ track = models.ForeignKey('Track')
+ artist = models.ForeignKey(Artist)
+ order = models.IntegerField()
+
+ def __unicode__(self):
+ return self.artist.__unicode__()
+
+ class Meta:
+ ordering = ['order']
+
+class RemixArtist(models.Model):
+ track = models.ForeignKey('Track')
+ artist = models.ForeignKey(Artist)
+ order = models.IntegerField()
+
+ def __unicode__(self):
+ return self.artist.__unicode__()
+
+ class Meta:
+ ordering = ['order']
+
class Track(models.Model):
name = models.CharField(max_length = 150)
- artists = models.ManyToManyField(Artist)
+ artists = models.ManyToManyField(Artist, through = TrackArtist)
remix = models.CharField(max_length = 80, blank = True)
- remixArtists = models.ManyToManyField(Artist, related_name = 'remixTracks', blank = True)
+ remixArtists = models.ManyToManyField(Artist, through = RemixArtist, related_name = 'remixTracks')
releases = models.ManyToManyField(Release)
length = models.IntegerField()
soundcloudLink = models.CharField(max_length = 150, blank = True)
def __unicode__(self):
#return '%s – %s%s' % (' & '.join(self.artists), self.name, (('%s by %s' % (self.remix, ' & '.join(self.remixArtists) + ')')) if (self.remix != '') else ''))
- return u'{1} – {0}'.format(self.name, ' & '.join(a.name for a in self.artists.all()))
+ return u'{1} – {0}'.format(self.name, ' & '.join(a.artist.__unicode__() for a in self.trackartist_set.all()))
class File(models.Model):
track = models.ForeignKey(Track)