-
Notifications
You must be signed in to change notification settings - Fork 4
Expand file tree
/
Copy pathmodels.py
More file actions
125 lines (104 loc) · 3.93 KB
/
models.py
File metadata and controls
125 lines (104 loc) · 3.93 KB
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
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
"""
Artist, Venue and Show models
"""
# Imports
from flask_sqlalchemy import SQLAlchemy
db = SQLAlchemy()
# Models.
class Artist(db.Model):
""" Artist Model"""
__tablename__ = 'artists'
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String)
city = db.Column(db.String(120))
state = db.Column(db.String(120))
phone = db.Column(db.String(120))
genres = db.Column(db.String(120))
website = db.Column(db.String(120))
image_link = db.Column(db.String(500))
facebook_link = db.Column(db.String(120))
seeking_venue = db.Column(db.Boolean, nullable=False, default=False)
seeking_description = db.Column(db.String(120))
venues = db.relationship('Venue', secondary='shows')
shows = db.relationship('Show', backref=('artists'))
def to_dict(self):
""" Returns a dictinary of artists """
return {
'id': self.id,
'name': self.name,
'city': self.city,
'state': self.state,
'phone': self.phone,
'genres': self.genres.split(','), # convert string to list
'image_link': self.image_link,
'facebook_link': self.facebook_link,
'website': self.website,
'seeking_venue': self.seeking_venue,
'seeking_description': self.seeking_description,
}
def __repr__(self):
return f'<Artist {self.id} {self.name}>'
class Venue(db.Model):
""" Venue Model """
__tablename__ = 'venues'
id = db.Column(db.Integer, primary_key=True)
name = db.Column(db.String)
city = db.Column(db.String(120))
state = db.Column(db.String(120))
address = db.Column(db.String(120))
phone = db.Column(db.String(120))
genres = db.Column(db.String(120))
image_link = db.Column(db.String(500))
facebook_link = db.Column(db.String(120))
website = db.Column(db.String(120))
seeking_talent = db.Column(db.Boolean, nullable=False, default=False)
seeking_description = db.Column(db.String(120))
artists = db.relationship('Artist', secondary='shows')
shows = db.relationship('Show', backref=('venues'))
def to_dict(self):
""" Returns a dictinary of vevenuesnues """
return {
'id': self.id,
'name': self.name,
'city': self.city,
'state': self.state,
'address': self.address,
'phone': self.phone,
'genres': self.genres.split(','), # convert string to list
'image_link': self.image_link,
'facebook_link': self.facebook_link,
'website': self.website,
'seeking_talent': self.seeking_talent,
'seeking_description': self.seeking_description,
}
def __repr__(self):
return f'<Venue {self.id} {self.name}>'
class Show(db.Model):
""" Show Model """
__tablename__ = 'shows'
id = db.Column(db.Integer, primary_key=True)
artist_id = db.Column(db.Integer, db.ForeignKey(
'artists.id'), nullable=False)
venue_id = db.Column(db.Integer, db.ForeignKey(
'venues.id'), nullable=False)
start_time = db.Column(db.DateTime, nullable=False)
venue = db.relationship('Venue')
artist = db.relationship('Artist')
def show_artist(self):
""" Returns a dictinary of artists for the show """
return {
'artist_id': self.artist_id,
'artist_name': self.artist.name,
'artist_image_link': self.artist.image_link,
# convert datetime to string
'start_time': self.start_time.strftime('%Y-%m-%d %H:%M:%S')
}
def show_venue(self):
""" Returns a dictinary of venues for the show """
return {
'venue_id': self.venue_id,
'venue_name': self.venue.name,
'venue_image_link': self.venue.image_link,
# convert datetime to string
'start_time': self.start_time.strftime('%Y-%m-%d %H:%M:%S')
}