bsw/jbe@0: local areas_selector = param.get("areas_selector", "table") bsw@375: local hide_membership = param.get("hide_membership", atom.boolean) bsw@795: local member = param.get("member", "table") bsw/jbe@0: bsw@9: areas_selector bsw@9: :reset_fields() bsw@9: :add_field("area.id", nil, { "grouped" }) bsw@622: :add_field("area.unit_id", nil, { "grouped" }) bsw@9: :add_field("area.name", nil, { "grouped" }) bsw@9: :add_field("member_weight", nil, { "grouped" }) bsw@9: :add_field("direct_member_count", nil, { "grouped" }) bsw@9: :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.accepted ISNULL AND issue.closed ISNULL)", "issues_new_count") bsw@9: :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.accepted NOTNULL AND issue.half_frozen ISNULL AND issue.closed ISNULL)", "issues_discussion_count") bsw@9: :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.half_frozen NOTNULL AND issue.fully_frozen ISNULL AND issue.closed ISNULL)", "issues_frozen_count") bsw@9: :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed ISNULL)", "issues_voting_count") bsw@10: :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed NOTNULL)", "issues_finished_count") bsw@973: :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.fully_frozen ISNULL AND issue.closed NOTNULL)", "issues_canceled_count") bsw@51: bsw@51: if app.session.member_id then bsw@51: areas_selector bsw@51: :add_field({ "(SELECT COUNT(*) FROM issue LEFT JOIN direct_voter ON direct_voter.issue_id = issue.id AND direct_voter.member_id = ? WHERE issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed ISNULL AND direct_voter.member_id ISNULL)", app.session.member.id }, "issues_to_vote_count") bsw@51: :left_join("membership", "_membership", { "_membership.area_id = area.id AND _membership.member_id = ?", app.session.member.id }) bsw@51: :add_field("_membership.member_id NOTNULL", "is_member", { "grouped" }) bsw@274: :left_join("delegation", nil, { bsw@274: "delegation.truster_id = ? AND delegation.area_id = area.id AND delegation.scope = 'area'", app.session.member_id bsw@274: }) bsw@274: :left_join("member", nil, "member.id = delegation.trustee_id") bsw@274: :add_field("member.id", "trustee_member_id", { "grouped" }) bsw@274: :add_field("member.name", "trustee_member_name", { "grouped" }) bsw@51: else bsw@51: areas_selector:add_field("0", "issues_to_vote_count") bsw@51: end bsw@9: bsw@619: ui.container{ attr = { class = "area_list" }, content = function() bsw@619: for i, area in ipairs(areas_selector:exec()) do bsw@795: execute.view { module = "area", view = "_list_entry", params = { area = area, member = member } } bsw@619: end bsw@619: end } bsw@381: