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 module = "member",
|
bsw@75
|
28 view = "_email_unconfirmed",
|
bsw@75
|
29 params = {}
|
bsw@75
|
30 }
|
bsw@75
|
31 end
|
bsw@75
|
32
|
bsw@349
|
33 if app.session.member.notify_level == nil then
|
bsw@349
|
34 tabs[#tabs+1] = {
|
bsw@349
|
35 class = "yellow",
|
bsw@349
|
36 name = "notify_level_not_set",
|
bsw@349
|
37 label = _"Notifications",
|
bsw@349
|
38 module = "member",
|
bsw@349
|
39 view = "_notify_level_not_set"
|
bsw@349
|
40 }
|
bsw@349
|
41 end
|
bsw@438
|
42
|
bsw@438
|
43 --[[
|
bsw@69
|
44 if config.motd_intern then
|
bsw@62
|
45 tabs[#tabs+1] = {
|
bsw@62
|
46 class = "yellow",
|
bsw@62
|
47 name = "motd",
|
bsw@62
|
48 label = _"Message of the day",
|
bsw@62
|
49 module = "index",
|
bsw@62
|
50 view = "_motd",
|
bsw@62
|
51 params = {}
|
bsw@62
|
52 }
|
bsw@62
|
53 end
|
bsw@438
|
54 --]]
|
bsw@438
|
55
|
poelzi@151
|
56 local broken_delegations = Delegation:new_selector()
|
bsw@209
|
57 :join("issue", nil, "issue.id = delegation.issue_id AND issue.closed ISNULL")
|
poelzi@151
|
58 :join("member", nil, "delegation.trustee_id = member.id")
|
poelzi@152
|
59 :add_where{"delegation.truster_id = ?", member.id}
|
bsw@242
|
60 :add_where{"member.active = 'f' OR (member.last_activity IS NULL OR age(member.last_activity) > ?::interval)", config.delegation_warning_time }
|
poelzi@151
|
61
|
poelzi@155
|
62 if broken_delegations:count() > 0 then
|
poelzi@151
|
63 tabs[#tabs+1] = {
|
poelzi@151
|
64 class = "red",
|
bsw@203
|
65 name = "broken_delegations",
|
poelzi@151
|
66 label = _"Delegation problems" .. " (" .. tostring(broken_delegations:count()) .. ")",
|
poelzi@151
|
67 icon = { static = "icons/16/table_go.png" },
|
poelzi@151
|
68 module = "delegation",
|
poelzi@151
|
69 view = "_list",
|
poelzi@151
|
70 params = { delegations_selector = broken_delegations, outgoing = true },
|
poelzi@151
|
71 }
|
poelzi@151
|
72 end
|
poelzi@151
|
73
|
bsw@57
|
74 local selector = Area:new_selector()
|
bsw@57
|
75 :reset_fields()
|
bsw@281
|
76 :join("privilege", nil, { "privilege.unit_id = area.unit_id AND privilege.member_id = ? AND privilege.voting_right", app.session.member_id })
|
bsw@57
|
77 :add_field("area.id", nil, { "grouped" })
|
bsw@57
|
78 :add_field("area.name", nil, { "grouped" })
|
bsw@57
|
79 :add_field("membership.member_id NOTNULL", "is_member", { "grouped" })
|
bsw@57
|
80 :add_field("count(issue.id)", "issues_to_vote_count")
|
bsw@57
|
81 :add_field("count(interest.member_id)", "interested_issues_to_vote_count")
|
bsw@57
|
82 :add_field("count(interest.member_id NOTNULL OR interest.member_id NOTNULL)", "issues_to_vote_count_sum")
|
bsw@57
|
83 :join("issue", nil, "issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed ISNULL")
|
bsw@57
|
84 :left_join("direct_voter", nil, { "direct_voter.issue_id = issue.id AND direct_voter.member_id = ?", app.session.member.id })
|
bsw@57
|
85 :add_where{ "direct_voter.member_id ISNULL" }
|
bsw@57
|
86 :left_join("interest", nil, { "interest.issue_id = issue.id AND interest.member_id = ?", app.session.member.id })
|
bsw@57
|
87 :left_join("membership", nil, { "membership.area_id = area.id AND membership.member_id = ? ", app.session.member.id })
|
bsw@57
|
88
|
bsw@57
|
89 local not_voted_areas = {}
|
bsw@57
|
90 local issues_to_vote_count = 0
|
bsw@57
|
91 for i, area in ipairs(selector:exec()) do
|
bsw@57
|
92 if area.is_member or area.interested_issues_to_vote_count > 0 then
|
bsw@57
|
93 not_voted_areas[#not_voted_areas+1] = area
|
bsw@57
|
94 end
|
bsw@67
|
95 if area.is_member then
|
bsw@67
|
96 issues_to_vote_count = issues_to_vote_count + area.issues_to_vote_count_sum
|
bsw@67
|
97 end
|
bsw@57
|
98 end
|
bsw@57
|
99
|
bsw@57
|
100 if issues_to_vote_count > 0 then
|
bsw@57
|
101 tabs[#tabs+1] = {
|
bsw@57
|
102 class = "yellow",
|
bsw@57
|
103 name = "not_voted_issues",
|
bsw@57
|
104 label = _"Not voted issues" .. " (" .. tostring(issues_to_vote_count) .. ")",
|
bsw@57
|
105 icon = { static = "icons/16/email_open.png" },
|
bsw@57
|
106 module = "index",
|
bsw@57
|
107 view = "_not_voted_issues",
|
bsw@57
|
108 params = {
|
bsw@57
|
109 areas = not_voted_areas
|
bsw@57
|
110 }
|
bsw@57
|
111 }
|
bsw@57
|
112 end
|
bsw@57
|
113
|
bsw@57
|
114 local initiator_invites_selector = Initiative:new_selector()
|
bsw@57
|
115 :join("issue", "_issue_state", "_issue_state.id = initiative.issue_id")
|
bsw@57
|
116 :join("initiator", nil, { "initiator.initiative_id = initiative.id AND initiator.member_id = ? AND initiator.accepted ISNULL", app.session.member.id })
|
bsw@57
|
117 :add_where("_issue_state.closed ISNULL AND _issue_state.half_frozen ISNULL")
|
bsw@57
|
118
|
bsw@57
|
119 if initiator_invites_selector:count() > 0 then
|
bsw@57
|
120 tabs[#tabs+1] = {
|
bsw@57
|
121 class = "yellow",
|
bsw@57
|
122 name = "initiator_invites",
|
bsw@57
|
123 label = _"Initiator invites" .. " (" .. tostring(initiator_invites_selector:count()) .. ")",
|
bsw@57
|
124 icon = { static = "icons/16/user_add.png" },
|
bsw@57
|
125 module = "index",
|
bsw@57
|
126 view = "_initiator_invites",
|
bsw@57
|
127 params = {
|
bsw@57
|
128 initiatives_selector = initiator_invites_selector
|
bsw@57
|
129 }
|
bsw@57
|
130 }
|
bsw@57
|
131 end
|
bsw@57
|
132
|
bsw@57
|
133 local updated_drafts_selector = Initiative:new_selector()
|
bsw@57
|
134 :join("issue", "_issue_state", "_issue_state.id = initiative.issue_id AND _issue_state.closed ISNULL AND _issue_state.fully_frozen ISNULL")
|
bsw@57
|
135 :join("current_draft", "_current_draft", "_current_draft.initiative_id = initiative.id")
|
bsw@57
|
136 :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
|
137 :add_where("initiative.revoked ISNULL")
|
bsw@57
|
138
|
bsw@57
|
139 if updated_drafts_selector:count() > 0 then
|
bsw@57
|
140 tabs[#tabs+1] = {
|
bsw@57
|
141 class = "yellow",
|
bsw@57
|
142 name = "updated_drafts",
|
bsw@57
|
143 label = _"Updated drafts" .. " (" .. tostring(updated_drafts_selector:count()) .. ")",
|
bsw@57
|
144 icon = { static = "icons/16/script.png" },
|
bsw@57
|
145 module = "index",
|
bsw@57
|
146 view = "_updated_drafts",
|
bsw@57
|
147 params = {
|
bsw@57
|
148 initiatives_selector = updated_drafts_selector
|
bsw@57
|
149 }
|
bsw@57
|
150 }
|
bsw@57
|
151 end
|
bsw@57
|
152 end
|
bsw@57
|
153
|
bsw@273
|
154 if not show_as_homepage then
|
bsw@273
|
155 tabs[#tabs+1] = {
|
bsw@273
|
156 name = "profile",
|
bsw@273
|
157 label = _"Profile",
|
bsw@273
|
158 icon = { static = "icons/16/application_form.png" },
|
bsw@273
|
159 module = "member",
|
bsw@273
|
160 view = "_profile",
|
bsw@273
|
161 params = { member = member },
|
bsw@273
|
162 }
|
bsw@273
|
163 end
|
bsw@57
|
164
|
bsw@439
|
165
|
bsw@439
|
166 local areas_selector = member:get_reference_selector("areas")
|
bsw@439
|
167 tabs[#tabs+1] = {
|
bsw@439
|
168 name = "areas",
|
bsw@439
|
169 label = _"Areas",
|
bsw@439
|
170 icon = { static = "icons/16/package.png" },
|
bsw@439
|
171 module = "member",
|
bsw@439
|
172 view = "_area_list",
|
bsw@439
|
173 params = { areas_selector = areas_selector, member = member },
|
bsw@439
|
174 }
|
bsw@439
|
175
|
bsw@414
|
176 if show_as_homepage then
|
bsw@414
|
177 tabs[#tabs+1] = {
|
bsw@414
|
178 name = "timeline",
|
bsw@414
|
179 label = _"Events",
|
bsw@414
|
180 module = "member",
|
bsw@414
|
181 view = "_event_list",
|
bsw@414
|
182 params = { }
|
bsw@414
|
183 }
|
bsw@414
|
184 else
|
bsw@414
|
185 tabs[#tabs+1] = {
|
bsw@414
|
186 name = "timeline",
|
bsw@414
|
187 label = _"Events",
|
bsw@414
|
188 module = "event",
|
bsw@414
|
189 view = "_list",
|
bsw@414
|
190 params = { for_member = member }
|
bsw@414
|
191 }
|
bsw@414
|
192 end
|
bsw@414
|
193
|
bsw@57
|
194 tabs[#tabs+1] = {
|
bsw@414
|
195 name = "open",
|
bsw@414
|
196 label = _"Open issues",
|
bsw@414
|
197 module = "issue",
|
bsw@276
|
198 view = "_list",
|
bsw@460
|
199 link_params = {
|
bsw@466
|
200 filter_interest = not show_as_homepage and "issue" or nil,
|
bsw@460
|
201 },
|
bsw@414
|
202 params = {
|
bsw@414
|
203 for_state = "open",
|
bsw@465
|
204 for_member = not show_as_homepage and member or nil,
|
bsw@414
|
205 issues_selector = Issue:new_selector()
|
bsw@414
|
206 :add_where("issue.closed ISNULL")
|
bsw@414
|
207 :add_order_by("coalesce(issue.fully_frozen + issue.voting_time, issue.half_frozen + issue.verification_time, issue.accepted + issue.discussion_time, issue.created + issue.admission_time) - now()")
|
bsw@414
|
208 }
|
bsw@414
|
209 }
|
bsw@438
|
210
|
bsw@414
|
211 tabs[#tabs+1] = {
|
bsw@414
|
212 name = "closed",
|
bsw@414
|
213 label = _"Closed issues",
|
bsw@414
|
214 module = "issue",
|
bsw@414
|
215 view = "_list",
|
bsw@460
|
216 link_params = {
|
bsw@466
|
217 filter_interest = not show_as_homepage and "issue" or nil,
|
bsw@460
|
218 },
|
bsw@414
|
219 params = {
|
bsw@414
|
220 for_state = "closed",
|
bsw@465
|
221 for_member = not show_as_homepage and member or nil,
|
bsw@414
|
222 issues_selector = Issue:new_selector()
|
bsw@414
|
223 :add_where("issue.closed NOTNULL")
|
bsw@414
|
224 :add_order_by("issue.closed DESC")
|
bsw@414
|
225
|
bsw@414
|
226 }
|
bsw@57
|
227 }
|
bsw@57
|
228
|
bsw@414
|
229 if not show_as_homepage then
|
bsw@414
|
230 local outgoing_delegations_selector = member:get_reference_selector("outgoing_delegations")
|
bsw@414
|
231 :left_join("issue", "_member_showtab_issue", "_member_showtab_issue.id = delegation.issue_id")
|
bsw@414
|
232 :add_where("_member_showtab_issue.closed ISNULL")
|
bsw@414
|
233 tabs[#tabs+1] = {
|
bsw@414
|
234 name = "outgoing_delegations",
|
bsw@414
|
235 label = _"Outgoing delegations" .. " (" .. tostring(outgoing_delegations_selector:count()) .. ")",
|
bsw@414
|
236 icon = { static = "icons/16/table_go.png" },
|
bsw@414
|
237 module = "delegation",
|
bsw@414
|
238 view = "_list",
|
bsw@414
|
239 params = { delegations_selector = outgoing_delegations_selector, outgoing = true },
|
bsw@414
|
240 }
|
bsw@57
|
241
|
bsw@414
|
242 local incoming_delegations_selector = member:get_reference_selector("incoming_delegations")
|
bsw@414
|
243 :left_join("issue", "_member_showtab_issue", "_member_showtab_issue.id = delegation.issue_id")
|
bsw@414
|
244 :add_where("_member_showtab_issue.closed ISNULL")
|
bsw@414
|
245 tabs[#tabs+1] = {
|
bsw@414
|
246 name = "incoming_delegations",
|
bsw@414
|
247 label = _"Incoming delegations" .. " (" .. tostring(incoming_delegations_selector:count()) .. ")",
|
bsw@414
|
248 icon = { static = "icons/16/table_go.png" },
|
bsw@414
|
249 module = "delegation",
|
bsw@414
|
250 view = "_list",
|
bsw@414
|
251 params = { delegations_selector = incoming_delegations_selector, incoming = true },
|
bsw@414
|
252 }
|
bsw@57
|
253
|
bsw@414
|
254 local contacts_selector = member:get_reference_selector("saved_members"):add_where("public")
|
bsw@273
|
255 tabs[#tabs+1] = {
|
bsw@414
|
256 name = "contacts",
|
bsw@414
|
257 label = _"Contacts" .. " (" .. tostring(contacts_selector:count()) .. ")",
|
bsw@414
|
258 icon = { static = "icons/16/book_edit.png" },
|
bsw@273
|
259 module = "member",
|
bsw@414
|
260 view = "_list",
|
bsw@414
|
261 params = { members_selector = contacts_selector },
|
bsw@273
|
262 }
|
bsw@273
|
263 end
|
bsw@273
|
264
|
bsw@242
|
265 ui.tabs(tabs)
|