| rev | 
   line source | 
| 
bsw@57
 | 
     1 local tabs = {
 | 
| 
bsw@57
 | 
     2   module = "index",
 | 
| 
bsw@57
 | 
     3   view = "show_tab"
 | 
| 
bsw@57
 | 
     4 }
 | 
| 
bsw@57
 | 
     5 
 | 
| 
bsw@57
 | 
     6 local selector = Area:new_selector()
 | 
| 
bsw@57
 | 
     7   :reset_fields()
 | 
| 
bsw@57
 | 
     8   :add_field("area.id", nil, { "grouped" })
 | 
| 
bsw@57
 | 
     9   :add_field("area.name", nil, { "grouped" })
 | 
| 
bsw@57
 | 
    10   :add_field("membership.member_id NOTNULL", "is_member", { "grouped" })
 | 
| 
bsw@57
 | 
    11   :add_field("count(issue.id)", "issues_to_vote_count")
 | 
| 
bsw@57
 | 
    12   :add_field("count(interest.member_id)", "interested_issues_to_vote_count")
 | 
| 
bsw@57
 | 
    13   :add_field("count(interest.member_id NOTNULL OR interest.member_id NOTNULL)", "issues_to_vote_count_sum")
 | 
| 
bsw@57
 | 
    14   :join("issue", nil, "issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed ISNULL")
 | 
| 
bsw@57
 | 
    15   :left_join("direct_voter", nil, { "direct_voter.issue_id = issue.id AND direct_voter.member_id = ?", app.session.member.id })
 | 
| 
bsw@57
 | 
    16   :add_where{ "direct_voter.member_id ISNULL" }
 | 
| 
bsw@57
 | 
    17   :left_join("interest", nil, { "interest.issue_id = issue.id AND interest.member_id = ?", app.session.member.id })
 | 
| 
bsw@57
 | 
    18   :left_join("membership", nil, { "membership.area_id = area.id AND membership.member_id = ? ", app.session.member.id })
 | 
| 
bsw@57
 | 
    19 
 | 
| 
bsw@57
 | 
    20 local not_voted_areas = {}
 | 
| 
bsw@57
 | 
    21 local issues_to_vote_count = 0
 | 
| 
bsw@57
 | 
    22 for i, area in ipairs(selector:exec()) do
 | 
| 
bsw@57
 | 
    23   if area.is_member or area.interested_issues_to_vote_count > 0 then
 | 
| 
bsw@57
 | 
    24     not_voted_areas[#not_voted_areas+1] = area
 | 
| 
bsw@57
 | 
    25   end
 | 
| 
bsw@57
 | 
    26   issues_to_vote_count = issues_to_vote_count + area.issues_to_vote_count_sum
 | 
| 
bsw@57
 | 
    27 end
 | 
| 
bsw@57
 | 
    28 
 | 
| 
bsw@57
 | 
    29 tabs[#tabs+1] = {
 | 
| 
bsw@57
 | 
    30   name = "not_voted_issues",
 | 
| 
bsw@57
 | 
    31   label = _"Not voted issues" .. " (" .. tostring(issues_to_vote_count) .. ")",
 | 
| 
bsw@57
 | 
    32   icon = { static = "icons/16/email_open.png" },
 | 
| 
bsw@57
 | 
    33   module = "index",
 | 
| 
bsw@57
 | 
    34   view = "_not_voted_issues",
 | 
| 
bsw@57
 | 
    35   params = {
 | 
| 
bsw@57
 | 
    36     areas = not_voted_areas
 | 
| 
bsw@57
 | 
    37   }
 | 
| 
bsw@57
 | 
    38 }
 | 
| 
bsw@57
 | 
    39 
 | 
| 
bsw@57
 | 
    40 local initiator_invites_selector = Initiative:new_selector()
 | 
| 
bsw@57
 | 
    41   :join("issue", "_issue_state", "_issue_state.id = initiative.issue_id")
 | 
| 
bsw@57
 | 
    42   :join("initiator", nil, { "initiator.initiative_id = initiative.id AND initiator.member_id = ? AND initiator.accepted ISNULL", app.session.member.id })
 | 
| 
bsw@57
 | 
    43   :add_where("_issue_state.closed ISNULL AND _issue_state.half_frozen ISNULL")
 | 
| 
bsw@57
 | 
    44 
 | 
| 
bsw@57
 | 
    45 tabs[#tabs+1] = {
 | 
| 
bsw@57
 | 
    46   name = "initiator_invites",
 | 
| 
bsw@57
 | 
    47   label = _"Initiator invites" .. " (" .. tostring(initiator_invites_selector:count()) .. ")",
 | 
| 
bsw@57
 | 
    48   icon = { static = "icons/16/email_open.png" },
 | 
| 
bsw@57
 | 
    49   module = "index",
 | 
| 
bsw@57
 | 
    50   view = "_initiator_invites",
 | 
| 
bsw@57
 | 
    51   params = {
 | 
| 
bsw@57
 | 
    52     initiatives_selector = initiator_invites_selector
 | 
| 
bsw@57
 | 
    53   }
 | 
| 
bsw@57
 | 
    54 }
 | 
| 
bsw@57
 | 
    55 
 | 
| 
bsw@57
 | 
    56 local updated_drafts_selector = Initiative:new_selector()
 | 
| 
bsw@57
 | 
    57   :join("issue", "_issue_state", "_issue_state.id = initiative.issue_id AND _issue_state.closed ISNULL AND _issue_state.fully_frozen ISNULL")
 | 
| 
bsw@57
 | 
    58   :join("current_draft", "_current_draft", "_current_draft.initiative_id = initiative.id")
 | 
| 
bsw@57
 | 
    59   :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
 | 
    60 
 | 
| 
bsw@57
 | 
    61 tabs[#tabs+1] = {
 | 
| 
bsw@57
 | 
    62   name = "updated_drafts",
 | 
| 
bsw@57
 | 
    63   label = _"Updated drafts" .. " (" .. tostring(updated_drafts_selector:count()) .. ")",
 | 
| 
bsw@57
 | 
    64   icon = { static = "icons/16/email_open.png" },
 | 
| 
bsw@57
 | 
    65   module = "index",
 | 
| 
bsw@57
 | 
    66   view = "_updated_drafts",
 | 
| 
bsw@57
 | 
    67   params = {
 | 
| 
bsw@57
 | 
    68     initiatives_selector = updated_drafts_selector
 | 
| 
bsw@57
 | 
    69   }
 | 
| 
bsw@57
 | 
    70 }
 | 
| 
bsw@57
 | 
    71 
 | 
| 
bsw@57
 | 
    72 ui.tabs(tabs) |