aboutsummaryrefslogtreecommitdiffstats
path: root/pysite/views/main/jams/index.py
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)