liquid_feedback_frontend
annotate app/main/member/show_tab.lua @ 143:a33abf457d29
add initiative_id selector in suggestion api
fixes bug #301
fixes bug #301
| author | Daniel Poelzleithner <poelzi@poelzi.org> | 
|---|---|
| date | Wed Oct 06 16:35:33 2010 +0200 (2010-10-06) | 
| parents | 43ac94c7575b | 
| children | 1652c4cd3154 | 
| rev | line source | 
|---|---|
| bsw@57 | 1 local show_as_homepage = param.get("show_as_homepage", atom.boolean) | 
| bsw@57 | 2 | 
| bsw/jbe@19 | 3 local member | 
| bsw/jbe@19 | 4 | 
| bsw/jbe@19 | 5 if request.get_json_request_slots() then | 
| bsw/jbe@19 | 6 member = Member:by_id(param.get("member_id")) | 
| bsw/jbe@19 | 7 else | 
| bsw/jbe@19 | 8 member = param.get("member", "table") | 
| bsw/jbe@19 | 9 end | 
| bsw/jbe@19 | 10 | 
| bsw@57 | 11 local tabs = { | 
| bsw@57 | 12 module = "member", | 
| bsw@57 | 13 view = "show_tab", | 
| bsw@57 | 14 static_params = { | 
| bsw@57 | 15 member_id = member.id, | 
| bsw@57 | 16 show_as_homepage = show_as_homepage | 
| bsw@57 | 17 } | 
| bsw@57 | 18 } | 
| bsw@57 | 19 | 
| bsw@57 | 20 if show_as_homepage and app.session.member_id == member.id then | 
| bsw@62 | 21 | 
| bsw@75 | 22 if app.session.member.notify_email_unconfirmed then | 
| bsw@75 | 23 tabs[#tabs+1] = { | 
| bsw@75 | 24 class = "yellow", | 
| bsw@75 | 25 name = "email_unconfirmed", | 
| bsw@75 | 26 label = _"Email unconfirmed", | 
| bsw@75 | 27 icon = { static = "icons/16/bell.png" }, | 
| bsw@75 | 28 module = "member", | 
| bsw@75 | 29 view = "_email_unconfirmed", | 
| bsw@75 | 30 params = {} | 
| bsw@75 | 31 } | 
| bsw@75 | 32 end | 
| bsw@75 | 33 | 
| bsw@69 | 34 if config.motd_intern then | 
| bsw@62 | 35 tabs[#tabs+1] = { | 
| bsw@62 | 36 class = "yellow", | 
| bsw@62 | 37 name = "motd", | 
| bsw@62 | 38 label = _"Message of the day", | 
| bsw@62 | 39 icon = { static = "icons/16/bell.png" }, | 
| bsw@62 | 40 module = "index", | 
| bsw@62 | 41 view = "_motd", | 
| bsw@62 | 42 params = {} | 
| bsw@62 | 43 } | 
| bsw@62 | 44 end | 
| bsw@57 | 45 | 
| bsw@57 | 46 local selector = Area:new_selector() | 
| bsw@57 | 47 :reset_fields() | 
| bsw@57 | 48 :add_field("area.id", nil, { "grouped" }) | 
| bsw@57 | 49 :add_field("area.name", nil, { "grouped" }) | 
| bsw@57 | 50 :add_field("membership.member_id NOTNULL", "is_member", { "grouped" }) | 
| bsw@57 | 51 :add_field("count(issue.id)", "issues_to_vote_count") | 
| bsw@57 | 52 :add_field("count(interest.member_id)", "interested_issues_to_vote_count") | 
| bsw@57 | 53 :add_field("count(interest.member_id NOTNULL OR interest.member_id NOTNULL)", "issues_to_vote_count_sum") | 
| bsw@57 | 54 :join("issue", nil, "issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed ISNULL") | 
| bsw@57 | 55 :left_join("direct_voter", nil, { "direct_voter.issue_id = issue.id AND direct_voter.member_id = ?", app.session.member.id }) | 
| bsw@57 | 56 :add_where{ "direct_voter.member_id ISNULL" } | 
| bsw@57 | 57 :left_join("interest", nil, { "interest.issue_id = issue.id AND interest.member_id = ?", app.session.member.id }) | 
| bsw@57 | 58 :left_join("membership", nil, { "membership.area_id = area.id AND membership.member_id = ? ", app.session.member.id }) | 
| bsw@57 | 59 | 
| bsw@57 | 60 local not_voted_areas = {} | 
| bsw@57 | 61 local issues_to_vote_count = 0 | 
| bsw@57 | 62 for i, area in ipairs(selector:exec()) do | 
| bsw@57 | 63 if area.is_member or area.interested_issues_to_vote_count > 0 then | 
| bsw@57 | 64 not_voted_areas[#not_voted_areas+1] = area | 
| bsw@57 | 65 end | 
| bsw@67 | 66 if area.is_member then | 
| bsw@67 | 67 issues_to_vote_count = issues_to_vote_count + area.issues_to_vote_count_sum | 
| bsw@67 | 68 end | 
| bsw@57 | 69 end | 
| bsw@57 | 70 | 
| bsw@57 | 71 if issues_to_vote_count > 0 then | 
| bsw@57 | 72 tabs[#tabs+1] = { | 
| bsw@57 | 73 class = "yellow", | 
| bsw@57 | 74 name = "not_voted_issues", | 
| bsw@57 | 75 label = _"Not voted issues" .. " (" .. tostring(issues_to_vote_count) .. ")", | 
| bsw@57 | 76 icon = { static = "icons/16/email_open.png" }, | 
| bsw@57 | 77 module = "index", | 
| bsw@57 | 78 view = "_not_voted_issues", | 
| bsw@57 | 79 params = { | 
| bsw@57 | 80 areas = not_voted_areas | 
| bsw@57 | 81 } | 
| bsw@57 | 82 } | 
| bsw@57 | 83 end | 
| bsw@57 | 84 | 
| bsw@57 | 85 local initiator_invites_selector = Initiative:new_selector() | 
| bsw@57 | 86 :join("issue", "_issue_state", "_issue_state.id = initiative.issue_id") | 
| bsw@57 | 87 :join("initiator", nil, { "initiator.initiative_id = initiative.id AND initiator.member_id = ? AND initiator.accepted ISNULL", app.session.member.id }) | 
| bsw@57 | 88 :add_where("_issue_state.closed ISNULL AND _issue_state.half_frozen ISNULL") | 
| bsw@57 | 89 | 
| bsw@57 | 90 if initiator_invites_selector:count() > 0 then | 
| bsw@57 | 91 tabs[#tabs+1] = { | 
| bsw@57 | 92 class = "yellow", | 
| bsw@57 | 93 name = "initiator_invites", | 
| bsw@57 | 94 label = _"Initiator invites" .. " (" .. tostring(initiator_invites_selector:count()) .. ")", | 
| bsw@57 | 95 icon = { static = "icons/16/user_add.png" }, | 
| bsw@57 | 96 module = "index", | 
| bsw@57 | 97 view = "_initiator_invites", | 
| bsw@57 | 98 params = { | 
| bsw@57 | 99 initiatives_selector = initiator_invites_selector | 
| bsw@57 | 100 } | 
| bsw@57 | 101 } | 
| bsw@57 | 102 end | 
| bsw@57 | 103 | 
| bsw@57 | 104 local updated_drafts_selector = Initiative:new_selector() | 
| bsw@57 | 105 :join("issue", "_issue_state", "_issue_state.id = initiative.issue_id AND _issue_state.closed ISNULL AND _issue_state.fully_frozen ISNULL") | 
| bsw@57 | 106 :join("current_draft", "_current_draft", "_current_draft.initiative_id = initiative.id") | 
| bsw@57 | 107 :join("supporter", "supporter", { "supporter.member_id = ? AND supporter.initiative_id = initiative.id AND supporter.draft_id < _current_draft.id", app.session.member_id }) | 
| bsw@75 | 108 :add_where("initiative.revoked ISNULL") | 
| bsw@57 | 109 | 
| bsw@57 | 110 if updated_drafts_selector:count() > 0 then | 
| bsw@57 | 111 tabs[#tabs+1] = { | 
| bsw@57 | 112 class = "yellow", | 
| bsw@57 | 113 name = "updated_drafts", | 
| bsw@57 | 114 label = _"Updated drafts" .. " (" .. tostring(updated_drafts_selector:count()) .. ")", | 
| bsw@57 | 115 icon = { static = "icons/16/script.png" }, | 
| bsw@57 | 116 module = "index", | 
| bsw@57 | 117 view = "_updated_drafts", | 
| bsw@57 | 118 params = { | 
| bsw@57 | 119 initiatives_selector = updated_drafts_selector | 
| bsw@57 | 120 } | 
| bsw@57 | 121 } | 
| bsw@57 | 122 end | 
| bsw@57 | 123 end | 
| bsw@57 | 124 | 
| bsw@57 | 125 tabs[#tabs+1] = { | 
| bsw@57 | 126 name = "profile", | 
| bsw@57 | 127 label = _"Profile", | 
| bsw@57 | 128 icon = { static = "icons/16/application_form.png" }, | 
| bsw@57 | 129 module = "member", | 
| bsw@57 | 130 view = "_profile", | 
| bsw@57 | 131 params = { member = member }, | 
| bsw@57 | 132 } | 
| bsw@57 | 133 | 
| bsw/jbe@19 | 134 local areas_selector = member:get_reference_selector("areas") | 
| bsw@57 | 135 tabs[#tabs+1] = { | 
| bsw@57 | 136 name = "areas", | 
| bsw@57 | 137 label = _"Areas" .. " (" .. tostring(areas_selector:count()) .. ")", | 
| bsw@57 | 138 icon = { static = "icons/16/package.png" }, | 
| bsw@57 | 139 module = "area", | 
| bsw@57 | 140 view = "_list", | 
| bsw@57 | 141 params = { areas_selector = areas_selector }, | 
| bsw@57 | 142 } | 
| bsw@57 | 143 | 
| bsw/jbe@19 | 144 local issues_selector = member:get_reference_selector("issues") | 
| bsw@57 | 145 tabs[#tabs+1] = { | 
| bsw@57 | 146 name = "issues", | 
| bsw@57 | 147 label = _"Issues" .. " (" .. tostring(issues_selector:count()) .. ")", | 
| bsw@57 | 148 icon = { static = "icons/16/folder.png" }, | 
| bsw@57 | 149 module = "issue", | 
| bsw@57 | 150 view = "_list", | 
| bsw@57 | 151 params = { issues_selector = issues_selector }, | 
| bsw@57 | 152 } | 
| bsw@57 | 153 | 
| bsw/jbe@19 | 154 local supported_initiatives_selector = member:get_reference_selector("supported_initiatives") | 
| bsw@95 | 155 | 
| bsw@57 | 156 tabs[#tabs+1] = { | 
| bsw@57 | 157 name = "supported_initiatives", | 
| bsw@57 | 158 label = _"Supported initiatives" .. " (" .. tostring(supported_initiatives_selector:count()) .. ")", | 
| bsw@57 | 159 icon = { static = "icons/16/thumb_up_green.png" }, | 
| bsw@95 | 160 module = "member", | 
| bsw@95 | 161 view = "_list_supported_initiatives", | 
| poelzi@137 | 162 params = { initiatives_selector = supported_initiatives_selector, | 
| poelzi@137 | 163 member = member }, | 
| bsw@57 | 164 } | 
| bsw@57 | 165 | 
| bsw/jbe@19 | 166 local initiated_initiatives_selector = member:get_reference_selector("initiated_initiatives"):add_where("initiator.accepted = true") | 
| bsw@57 | 167 tabs[#tabs+1] = { | 
| bsw@57 | 168 name = "initiatied_initiatives", | 
| bsw@57 | 169 label = _"Initiated initiatives" .. " (" .. tostring(initiated_initiatives_selector:count()) .. ")", | 
| bsw@57 | 170 icon = { static = "icons/16/user_edit.png" }, | 
| bsw@95 | 171 module = "member", | 
| bsw@95 | 172 view = "_list_supported_initiatives", | 
| poelzi@137 | 173 params = { initiatives_selector = initiated_initiatives_selector, | 
| poelzi@137 | 174 member = member}, | 
| bsw@57 | 175 } | 
| bsw@57 | 176 | 
| bsw/jbe@19 | 177 local incoming_delegations_selector = member:get_reference_selector("incoming_delegations") | 
| bsw/jbe@19 | 178 :left_join("issue", "_member_showtab_issue", "_member_showtab_issue.id = delegation.issue_id") | 
| bsw/jbe@19 | 179 :add_where("_member_showtab_issue.closed ISNULL") | 
| bsw@57 | 180 tabs[#tabs+1] = { | 
| bsw@57 | 181 name = "incoming_delegations", | 
| bsw@57 | 182 label = _"Incoming delegations" .. " (" .. tostring(incoming_delegations_selector:count()) .. ")", | 
| bsw@57 | 183 icon = { static = "icons/16/table_go.png" }, | 
| bsw@57 | 184 module = "delegation", | 
| bsw@57 | 185 view = "_list", | 
| bsw@57 | 186 params = { delegations_selector = incoming_delegations_selector, incoming = true }, | 
| bsw@57 | 187 } | 
| bsw@57 | 188 | 
| bsw/jbe@19 | 189 local outgoing_delegations_selector = member:get_reference_selector("outgoing_delegations") | 
| bsw/jbe@19 | 190 :left_join("issue", "_member_showtab_issue", "_member_showtab_issue.id = delegation.issue_id") | 
| bsw/jbe@19 | 191 :add_where("_member_showtab_issue.closed ISNULL") | 
| bsw@57 | 192 tabs[#tabs+1] = { | 
| bsw@57 | 193 name = "outgoing_delegations", | 
| bsw@57 | 194 label = _"Outgoing delegations" .. " (" .. tostring(outgoing_delegations_selector:count()) .. ")", | 
| bsw@57 | 195 icon = { static = "icons/16/table_go.png" }, | 
| bsw@57 | 196 module = "delegation", | 
| bsw@57 | 197 view = "_list", | 
| bsw@57 | 198 params = { delegations_selector = outgoing_delegations_selector, outgoing = true }, | 
| bsw@57 | 199 } | 
| bsw/jbe@19 | 200 | 
| bsw@57 | 201 local contacts_selector = member:get_reference_selector("saved_members"):add_where("public") | 
| bsw@57 | 202 tabs[#tabs+1] = { | 
| bsw@57 | 203 name = "contacts", | 
| bsw@57 | 204 label = _"Contacts" .. " (" .. tostring(contacts_selector:count()) .. ")", | 
| bsw@57 | 205 icon = { static = "icons/16/book_edit.png" }, | 
| bsw/jbe@19 | 206 module = "member", | 
| bsw@57 | 207 view = "_list", | 
| bsw@57 | 208 params = { members_selector = contacts_selector }, | 
| bsw/jbe@19 | 209 } | 
| bsw@57 | 210 | 
| bsw@57 | 211 ui.tabs(tabs) |