bsw@57: local tabs = { bsw@57: module = "index", bsw@57: view = "show_tab" bsw@57: } bsw@57: bsw@57: local selector = Area:new_selector() bsw@57: :reset_fields() bsw@57: :add_field("area.id", nil, { "grouped" }) bsw@57: :add_field("area.name", nil, { "grouped" }) bsw@57: :add_field("membership.member_id NOTNULL", "is_member", { "grouped" }) bsw@57: :add_field("count(issue.id)", "issues_to_vote_count") bsw@57: :add_field("count(interest.member_id)", "interested_issues_to_vote_count") bsw@57: :add_field("count(interest.member_id NOTNULL OR interest.member_id NOTNULL)", "issues_to_vote_count_sum") bsw@57: :join("issue", nil, "issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed ISNULL") bsw@57: :left_join("direct_voter", nil, { "direct_voter.issue_id = issue.id AND direct_voter.member_id = ?", app.session.member.id }) bsw@57: :add_where{ "direct_voter.member_id ISNULL" } bsw@57: :left_join("interest", nil, { "interest.issue_id = issue.id AND interest.member_id = ?", app.session.member.id }) bsw@57: :left_join("membership", nil, { "membership.area_id = area.id AND membership.member_id = ? ", app.session.member.id }) bsw@57: bsw@57: local not_voted_areas = {} bsw@57: local issues_to_vote_count = 0 bsw@57: for i, area in ipairs(selector:exec()) do bsw@57: if area.is_member or area.interested_issues_to_vote_count > 0 then bsw@57: not_voted_areas[#not_voted_areas+1] = area bsw@57: end bsw@57: issues_to_vote_count = issues_to_vote_count + area.issues_to_vote_count_sum bsw@57: end bsw@57: bsw@57: tabs[#tabs+1] = { bsw@57: name = "not_voted_issues", bsw@57: label = _"Not voted issues" .. " (" .. tostring(issues_to_vote_count) .. ")", bsw@57: icon = { static = "icons/16/email_open.png" }, bsw@57: module = "index", bsw@57: view = "_not_voted_issues", bsw@57: params = { bsw@57: areas = not_voted_areas bsw@57: } bsw@57: } bsw@57: bsw@57: local initiator_invites_selector = Initiative:new_selector() bsw@57: :join("issue", "_issue_state", "_issue_state.id = initiative.issue_id") bsw@57: :join("initiator", nil, { "initiator.initiative_id = initiative.id AND initiator.member_id = ? AND initiator.accepted ISNULL", app.session.member.id }) bsw@57: :add_where("_issue_state.closed ISNULL AND _issue_state.half_frozen ISNULL") bsw@57: bsw@57: tabs[#tabs+1] = { bsw@57: name = "initiator_invites", bsw@57: label = _"Initiator invites" .. " (" .. tostring(initiator_invites_selector:count()) .. ")", bsw@57: icon = { static = "icons/16/email_open.png" }, bsw@57: module = "index", bsw@57: view = "_initiator_invites", bsw@57: params = { bsw@57: initiatives_selector = initiator_invites_selector bsw@57: } bsw@57: } bsw@57: bsw@57: local updated_drafts_selector = Initiative:new_selector() bsw@57: :join("issue", "_issue_state", "_issue_state.id = initiative.issue_id AND _issue_state.closed ISNULL AND _issue_state.fully_frozen ISNULL") bsw@57: :join("current_draft", "_current_draft", "_current_draft.initiative_id = initiative.id") bsw@57: :join("supporter", "supporter", { "supporter.member_id = ? AND supporter.initiative_id = initiative.id AND supporter.draft_id < _current_draft.id", app.session.member_id }) bsw@57: bsw@57: tabs[#tabs+1] = { bsw@57: name = "updated_drafts", bsw@57: label = _"Updated drafts" .. " (" .. tostring(updated_drafts_selector:count()) .. ")", bsw@57: icon = { static = "icons/16/email_open.png" }, bsw@57: module = "index", bsw@57: view = "_updated_drafts", bsw@57: params = { bsw@57: initiatives_selector = updated_drafts_selector bsw@57: } bsw@57: } bsw@57: bsw@57: ui.tabs(tabs)