Add better many-to-many relationshops for tracks and artists.
[demoscenemusic.git] / data / models.py
1 # encoding: utf-8
2 from django.db import models
3
4 class Group(models.Model):
5         name = models.CharField(max_length = 80)
6         shortName = models.CharField(max_length = 50, blank = True)
7         website = models.CharField(max_length = 150, blank = True)
8
9         def __unicode__(self):
10                 return self.name + (' (' + self.website + ')' if (self.website != '') else '')
11
12 class Artist(models.Model):
13         name = models.CharField(max_length = 80)
14         realName = models.CharField(max_length = 80, blank = True)
15         groups = models.ManyToManyField(Group)
16
17         def __unicode__(self):
18                 return self.name
19
20 class Party(models.Model):
21         name = models.CharField(max_length = 80)
22         website = models.CharField(max_length = 150, blank = True)
23
24         def __unicode__(self):
25                 return self.name
26
27 class Compo(models.Model):
28         name = models.CharField(max_length = 80)
29
30         def __unicode__(self):
31                 return self.name;
32
33 class Release(models.Model):
34         party = models.ForeignKey(Party)
35         year = models.IntegerField()
36         compo = models.ForeignKey(Compo)
37         place = models.IntegerField()
38         pouetId = models.IntegerField(blank = True, null = True)
39
40         def __unicode__(self):
41                 return self.compo.__unicode__() + ' @ ' + self.party.__unicode__() + ' ' + '%d' % self.year
42
43 class TrackArtist(models.Model):
44         track = models.ForeignKey('Track')
45         artist = models.ForeignKey(Artist)
46         order = models.IntegerField()
47
48 class RemixArtist(models.Model):
49         track = models.ForeignKey('Track')
50         artist = models.ForeignKey(Artist)
51         order = models.IntegerField()
52
53 class Track(models.Model):
54         name = models.CharField(max_length = 150)
55         artists = models.ManyToManyField(Artist, through = TrackArtist)
56         remix = models.CharField(max_length = 80, blank = True)
57         remixArtists = models.ManyToManyField(Artist, through = RemixArtist, related_name = 'remixTracks')
58         releases = models.ManyToManyField(Release)
59         length = models.IntegerField()
60         soundcloudLink = models.CharField(max_length = 150, blank = True)
61
62         def __unicode__(self):
63                 #return '%s – %s%s' % (' & '.join(self.artists), self.name, (('%s by %s' % (self.remix, ' & '.join(self.remixArtists) + ')')) if (self.remix != '') else ''))
64                 return u'{1} – {0}'.format(self.name, ' & '.join(a.name for a in self.artists.all()))
65
66 class File(models.Model):
67         track = models.ForeignKey(Track)
68         path = models.CharField(max_length = 150)
69         type = models.CharField(max_length = 50)
70
71         def __unicode__(self):
72                 return self.type + ' (' + self.path + ')'