liquid_feedback_frontend
annotate app/main/member/show_tab.lua @ 151:1652c4cd3154
add broken delegations tab on homepage
if a user has delegations to an inactive account, a new red tab will apear on the homepage of the user listing his broken delegations
if a user has delegations to an inactive account, a new red tab will apear on the homepage of the user listing his broken delegations
| author | Daniel Poelzleithner <poelzi@poelzi.org> |
|---|---|
| date | Fri Oct 08 05:24:14 2010 +0200 (2010-10-08) |
| parents | 43ac94c7575b |
| children | ccdf197b3f9b |
| 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 |
| poelzi@151 | 46 local broken_delegations = Delegation:new_selector() |
| poelzi@151 | 47 :join("member", nil, "delegation.trustee_id = member.id") |
| poelzi@151 | 48 :add_where{"member.active = 'f' AND delegation.truster_id = ?", member.id} |
| poelzi@151 | 49 |
| poelzi@151 | 50 if broken_delegations:count() then |
| poelzi@151 | 51 tabs[#tabs+1] = { |
| poelzi@151 | 52 class = "red", |
| poelzi@151 | 53 name = "problem_delegations", |
| poelzi@151 | 54 label = _"Delegation problems" .. " (" .. tostring(broken_delegations:count()) .. ")", |
| poelzi@151 | 55 icon = { static = "icons/16/table_go.png" }, |
| poelzi@151 | 56 module = "delegation", |
| poelzi@151 | 57 view = "_list", |
| poelzi@151 | 58 params = { delegations_selector = broken_delegations, outgoing = true }, |
| poelzi@151 | 59 } |
| poelzi@151 | 60 end |
| poelzi@151 | 61 |
| bsw@57 | 62 local selector = Area:new_selector() |
| bsw@57 | 63 :reset_fields() |
| bsw@57 | 64 :add_field("area.id", nil, { "grouped" }) |
| bsw@57 | 65 :add_field("area.name", nil, { "grouped" }) |
| bsw@57 | 66 :add_field("membership.member_id NOTNULL", "is_member", { "grouped" }) |
| bsw@57 | 67 :add_field("count(issue.id)", "issues_to_vote_count") |
| bsw@57 | 68 :add_field("count(interest.member_id)", "interested_issues_to_vote_count") |
| bsw@57 | 69 :add_field("count(interest.member_id NOTNULL OR interest.member_id NOTNULL)", "issues_to_vote_count_sum") |
| bsw@57 | 70 :join("issue", nil, "issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed ISNULL") |
| bsw@57 | 71 :left_join("direct_voter", nil, { "direct_voter.issue_id = issue.id AND direct_voter.member_id = ?", app.session.member.id }) |
| bsw@57 | 72 :add_where{ "direct_voter.member_id ISNULL" } |
| bsw@57 | 73 :left_join("interest", nil, { "interest.issue_id = issue.id AND interest.member_id = ?", app.session.member.id }) |
| bsw@57 | 74 :left_join("membership", nil, { "membership.area_id = area.id AND membership.member_id = ? ", app.session.member.id }) |
| bsw@57 | 75 |
| bsw@57 | 76 local not_voted_areas = {} |
| bsw@57 | 77 local issues_to_vote_count = 0 |
| bsw@57 | 78 for i, area in ipairs(selector:exec()) do |
| bsw@57 | 79 if area.is_member or area.interested_issues_to_vote_count > 0 then |
| bsw@57 | 80 not_voted_areas[#not_voted_areas+1] = area |
| bsw@57 | 81 end |
| bsw@67 | 82 if area.is_member then |
| bsw@67 | 83 issues_to_vote_count = issues_to_vote_count + area.issues_to_vote_count_sum |
| bsw@67 | 84 end |
| bsw@57 | 85 end |
| bsw@57 | 86 |
| bsw@57 | 87 if issues_to_vote_count > 0 then |
| bsw@57 | 88 tabs[#tabs+1] = { |
| bsw@57 | 89 class = "yellow", |
| bsw@57 | 90 name = "not_voted_issues", |
| bsw@57 | 91 label = _"Not voted issues" .. " (" .. tostring(issues_to_vote_count) .. ")", |
| bsw@57 | 92 icon = { static = "icons/16/email_open.png" }, |
| bsw@57 | 93 module = "index", |
| bsw@57 | 94 view = "_not_voted_issues", |
| bsw@57 | 95 params = { |
| bsw@57 | 96 areas = not_voted_areas |
| bsw@57 | 97 } |
| bsw@57 | 98 } |
| bsw@57 | 99 end |
| bsw@57 | 100 |
| bsw@57 | 101 local initiator_invites_selector = Initiative:new_selector() |
| bsw@57 | 102 :join("issue", "_issue_state", "_issue_state.id = initiative.issue_id") |
| bsw@57 | 103 :join("initiator", nil, { "initiator.initiative_id = initiative.id AND initiator.member_id = ? AND initiator.accepted ISNULL", app.session.member.id }) |
| bsw@57 | 104 :add_where("_issue_state.closed ISNULL AND _issue_state.half_frozen ISNULL") |
| bsw@57 | 105 |
| bsw@57 | 106 if initiator_invites_selector:count() > 0 then |
| bsw@57 | 107 tabs[#tabs+1] = { |
| bsw@57 | 108 class = "yellow", |
| bsw@57 | 109 name = "initiator_invites", |
| bsw@57 | 110 label = _"Initiator invites" .. " (" .. tostring(initiator_invites_selector:count()) .. ")", |
| bsw@57 | 111 icon = { static = "icons/16/user_add.png" }, |
| bsw@57 | 112 module = "index", |
| bsw@57 | 113 view = "_initiator_invites", |
| bsw@57 | 114 params = { |
| bsw@57 | 115 initiatives_selector = initiator_invites_selector |
| bsw@57 | 116 } |
| bsw@57 | 117 } |
| bsw@57 | 118 end |
| bsw@57 | 119 |
| bsw@57 | 120 local updated_drafts_selector = Initiative:new_selector() |
| bsw@57 | 121 :join("issue", "_issue_state", "_issue_state.id = initiative.issue_id AND _issue_state.closed ISNULL AND _issue_state.fully_frozen ISNULL") |
| bsw@57 | 122 :join("current_draft", "_current_draft", "_current_draft.initiative_id = initiative.id") |
| bsw@57 | 123 :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 | 124 :add_where("initiative.revoked ISNULL") |
| bsw@57 | 125 |
| bsw@57 | 126 if updated_drafts_selector:count() > 0 then |
| bsw@57 | 127 tabs[#tabs+1] = { |
| bsw@57 | 128 class = "yellow", |
| bsw@57 | 129 name = "updated_drafts", |
| bsw@57 | 130 label = _"Updated drafts" .. " (" .. tostring(updated_drafts_selector:count()) .. ")", |
| bsw@57 | 131 icon = { static = "icons/16/script.png" }, |
| bsw@57 | 132 module = "index", |
| bsw@57 | 133 view = "_updated_drafts", |
| bsw@57 | 134 params = { |
| bsw@57 | 135 initiatives_selector = updated_drafts_selector |
| bsw@57 | 136 } |
| bsw@57 | 137 } |
| bsw@57 | 138 end |
| bsw@57 | 139 end |
| bsw@57 | 140 |
| bsw@57 | 141 tabs[#tabs+1] = { |
| bsw@57 | 142 name = "profile", |
| bsw@57 | 143 label = _"Profile", |
| bsw@57 | 144 icon = { static = "icons/16/application_form.png" }, |
| bsw@57 | 145 module = "member", |
| bsw@57 | 146 view = "_profile", |
| bsw@57 | 147 params = { member = member }, |
| bsw@57 | 148 } |
| bsw@57 | 149 |
| bsw/jbe@19 | 150 local areas_selector = member:get_reference_selector("areas") |
| bsw@57 | 151 tabs[#tabs+1] = { |
| bsw@57 | 152 name = "areas", |
| bsw@57 | 153 label = _"Areas" .. " (" .. tostring(areas_selector:count()) .. ")", |
| bsw@57 | 154 icon = { static = "icons/16/package.png" }, |
| bsw@57 | 155 module = "area", |
| bsw@57 | 156 view = "_list", |
| bsw@57 | 157 params = { areas_selector = areas_selector }, |
| bsw@57 | 158 } |
| bsw@57 | 159 |
| bsw/jbe@19 | 160 local issues_selector = member:get_reference_selector("issues") |
| bsw@57 | 161 tabs[#tabs+1] = { |
| bsw@57 | 162 name = "issues", |
| bsw@57 | 163 label = _"Issues" .. " (" .. tostring(issues_selector:count()) .. ")", |
| bsw@57 | 164 icon = { static = "icons/16/folder.png" }, |
| bsw@57 | 165 module = "issue", |
| bsw@57 | 166 view = "_list", |
| bsw@57 | 167 params = { issues_selector = issues_selector }, |
| bsw@57 | 168 } |
| bsw@57 | 169 |
| bsw/jbe@19 | 170 local supported_initiatives_selector = member:get_reference_selector("supported_initiatives") |
| bsw@95 | 171 |
| bsw@57 | 172 tabs[#tabs+1] = { |
| bsw@57 | 173 name = "supported_initiatives", |
| bsw@57 | 174 label = _"Supported initiatives" .. " (" .. tostring(supported_initiatives_selector:count()) .. ")", |
| bsw@57 | 175 icon = { static = "icons/16/thumb_up_green.png" }, |
| bsw@95 | 176 module = "member", |
| bsw@95 | 177 view = "_list_supported_initiatives", |
| poelzi@137 | 178 params = { initiatives_selector = supported_initiatives_selector, |
| poelzi@137 | 179 member = member }, |
| bsw@57 | 180 } |
| bsw@57 | 181 |
| bsw/jbe@19 | 182 local initiated_initiatives_selector = member:get_reference_selector("initiated_initiatives"):add_where("initiator.accepted = true") |
| bsw@57 | 183 tabs[#tabs+1] = { |
| bsw@57 | 184 name = "initiatied_initiatives", |
| bsw@57 | 185 label = _"Initiated initiatives" .. " (" .. tostring(initiated_initiatives_selector:count()) .. ")", |
| bsw@57 | 186 icon = { static = "icons/16/user_edit.png" }, |
| bsw@95 | 187 module = "member", |
| bsw@95 | 188 view = "_list_supported_initiatives", |
| poelzi@137 | 189 params = { initiatives_selector = initiated_initiatives_selector, |
| poelzi@137 | 190 member = member}, |
| bsw@57 | 191 } |
| bsw@57 | 192 |
| bsw/jbe@19 | 193 local incoming_delegations_selector = member:get_reference_selector("incoming_delegations") |
| bsw/jbe@19 | 194 :left_join("issue", "_member_showtab_issue", "_member_showtab_issue.id = delegation.issue_id") |
| bsw/jbe@19 | 195 :add_where("_member_showtab_issue.closed ISNULL") |
| bsw@57 | 196 tabs[#tabs+1] = { |
| bsw@57 | 197 name = "incoming_delegations", |
| bsw@57 | 198 label = _"Incoming delegations" .. " (" .. tostring(incoming_delegations_selector:count()) .. ")", |
| bsw@57 | 199 icon = { static = "icons/16/table_go.png" }, |
| bsw@57 | 200 module = "delegation", |
| bsw@57 | 201 view = "_list", |
| bsw@57 | 202 params = { delegations_selector = incoming_delegations_selector, incoming = true }, |
| bsw@57 | 203 } |
| bsw@57 | 204 |
| bsw/jbe@19 | 205 local outgoing_delegations_selector = member:get_reference_selector("outgoing_delegations") |
| bsw/jbe@19 | 206 :left_join("issue", "_member_showtab_issue", "_member_showtab_issue.id = delegation.issue_id") |
| bsw/jbe@19 | 207 :add_where("_member_showtab_issue.closed ISNULL") |
| bsw@57 | 208 tabs[#tabs+1] = { |
| bsw@57 | 209 name = "outgoing_delegations", |
| bsw@57 | 210 label = _"Outgoing delegations" .. " (" .. tostring(outgoing_delegations_selector:count()) .. ")", |
| bsw@57 | 211 icon = { static = "icons/16/table_go.png" }, |
| bsw@57 | 212 module = "delegation", |
| bsw@57 | 213 view = "_list", |
| bsw@57 | 214 params = { delegations_selector = outgoing_delegations_selector, outgoing = true }, |
| bsw@57 | 215 } |
| bsw/jbe@19 | 216 |
| bsw@57 | 217 local contacts_selector = member:get_reference_selector("saved_members"):add_where("public") |
| bsw@57 | 218 tabs[#tabs+1] = { |
| bsw@57 | 219 name = "contacts", |
| bsw@57 | 220 label = _"Contacts" .. " (" .. tostring(contacts_selector:count()) .. ")", |
| bsw@57 | 221 icon = { static = "icons/16/book_edit.png" }, |
| bsw/jbe@19 | 222 module = "member", |
| bsw@57 | 223 view = "_list", |
| bsw@57 | 224 params = { members_selector = contacts_selector }, |
| bsw/jbe@19 | 225 } |
| bsw@57 | 226 |
| bsw@57 | 227 ui.tabs(tabs) |