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