Add style to tracks.
[demoscenemusic.git] / data / models.py
index 33cae30..da15ab5 100644 (file)
@@ -12,10 +12,10 @@ class Group(models.Model):
 class Artist(models.Model):
        name = models.CharField(max_length = 80)
        realName = models.CharField(max_length = 80, blank = True)
-       groups = models.ManyToManyField(Group)
+       groups = models.ManyToManyField(Group, blank = True)
 
        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()), )) if (self.groups.all()) else '')
 
 class Party(models.Model):
        name = models.CharField(max_length = 80)
@@ -35,23 +35,52 @@ class Release(models.Model):
        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 Style(models.Model):
+       name = models.CharField(max_length = 80)
+
+       def __unicode__(self):
+               return self.name
+
 class Track(models.Model):
        name = models.CharField(max_length = 150)
-       artists = models.ManyToManyField(Artist)
+       artists = models.ManyToManyField(Artist, through = TrackArtist)
+       styles = models.ManyToManyField(Style, blank = True)
        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)