blob: abe2859f21db91bdbda8deb32fddd444182ae834 (
plain) (
blame)
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
|
import rethinkdb
from pysite.base_route import RouteView
from pysite.mixins import DBMixin
class JamsIndexView(RouteView, DBMixin):
path = "/jams"
name = "jams.index"
table_name = "code_jams"
teams_table = "code_jam_teams"
def get(self):
query = (
self.db.query(self.table_name)
.filter(rethinkdb.row["state"] != "planning")
.merge(
lambda jam_obj: {
"teams":
self.db.query(self.teams_table)
.filter(lambda team_row: jam_obj["teams"].contains(team_row["id"]))
.pluck(["id"])
.coerce_to("array")
}
)
.order_by(rethinkdb.desc("number"))
.limit(5)
)
jams = self.db.run(query, coerce=list)
return self.render("main/jams/index.html", jams=jams)
|