| rev |
line source |
|
bsw/jbe@0
|
1 local areas_selector = param.get("areas_selector", "table")
|
|
bsw@278
|
2 local title = param.get("title", "function")
|
|
bsw/jbe@0
|
3
|
|
bsw@9
|
4 areas_selector
|
|
bsw@9
|
5 :reset_fields()
|
|
bsw@9
|
6 :add_field("area.id", nil, { "grouped" })
|
|
bsw@9
|
7 :add_field("area.name", nil, { "grouped" })
|
|
bsw@9
|
8 :add_field("member_weight", nil, { "grouped" })
|
|
bsw@9
|
9 :add_field("direct_member_count", nil, { "grouped" })
|
|
bsw@9
|
10 :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.accepted ISNULL AND issue.closed ISNULL)", "issues_new_count")
|
|
bsw@9
|
11 :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.accepted NOTNULL AND issue.half_frozen ISNULL AND issue.closed ISNULL)", "issues_discussion_count")
|
|
bsw@9
|
12 :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.half_frozen NOTNULL AND issue.fully_frozen ISNULL AND issue.closed ISNULL)", "issues_frozen_count")
|
|
bsw@9
|
13 :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed ISNULL)", "issues_voting_count")
|
|
bsw@10
|
14 :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed NOTNULL)", "issues_finished_count")
|
|
bsw@10
|
15 :add_field("(SELECT COUNT(*) FROM issue WHERE issue.area_id = area.id AND issue.fully_frozen ISNULL AND issue.closed NOTNULL)", "issues_cancelled_count")
|
|
bsw@51
|
16
|
|
bsw@51
|
17 if app.session.member_id then
|
|
bsw@51
|
18 areas_selector
|
|
bsw@51
|
19 :add_field({ "(SELECT COUNT(*) FROM issue LEFT JOIN direct_voter ON direct_voter.issue_id = issue.id AND direct_voter.member_id = ? WHERE issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed ISNULL AND direct_voter.member_id ISNULL)", app.session.member.id }, "issues_to_vote_count")
|
|
bsw@51
|
20 :left_join("membership", "_membership", { "_membership.area_id = area.id AND _membership.member_id = ?", app.session.member.id })
|
|
bsw@51
|
21 :add_field("_membership.member_id NOTNULL", "is_member", { "grouped" })
|
|
bsw@274
|
22 :left_join("delegation", nil, {
|
|
bsw@274
|
23 "delegation.truster_id = ? AND delegation.area_id = area.id AND delegation.scope = 'area'", app.session.member_id
|
|
bsw@274
|
24 })
|
|
bsw@274
|
25 :left_join("member", nil, "member.id = delegation.trustee_id")
|
|
bsw@274
|
26 :add_field("member.id", "trustee_member_id", { "grouped" })
|
|
bsw@274
|
27 :add_field("member.name", "trustee_member_name", { "grouped" })
|
|
bsw@51
|
28 else
|
|
bsw@51
|
29 areas_selector:add_field("0", "issues_to_vote_count")
|
|
bsw@51
|
30 end
|
|
bsw@9
|
31
|
|
bsw/jbe@19
|
32 local label_attr = { style = "text-align: right; width: 4em;" }
|
|
bsw/jbe@19
|
33 local field_attr = { style = "text-align: right; width: 4em;" }
|
|
bsw/jbe@19
|
34
|
|
bsw@269
|
35 ui.list{
|
|
bsw@269
|
36 attr = { class = "area_list" },
|
|
bsw@269
|
37 records = areas_selector:exec(),
|
|
bsw@269
|
38 columns = {
|
|
bsw@269
|
39 {
|
|
bsw@278
|
40 label = title,
|
|
bsw@269
|
41 content = function(record)
|
|
bsw@269
|
42 if record.is_member then
|
|
bsw@269
|
43 local text = _"Member of area"
|
|
bsw@269
|
44 ui.image{
|
|
bsw@269
|
45 attr = { title = text, alt = text, style = "vertical-align: middle;" },
|
|
bsw@269
|
46 static = "icons/16/user_gray.png",
|
|
bsw@269
|
47 }
|
|
bsw@269
|
48 end
|
|
bsw@269
|
49 end
|
|
bsw@269
|
50 },
|
|
bsw/jbe@0
|
51 {
|
|
bsw@269
|
52 content = function(record)
|
|
bsw@274
|
53 if record.trustee_member_id then
|
|
bsw@274
|
54 local trustee_member = Member:by_id(record.trustee_member_id)
|
|
bsw@274
|
55 local text = _("Area delegated to '#{name}'", { name = record.trustee_member_name })
|
|
bsw@274
|
56 execute.view{
|
|
bsw@274
|
57 module = "member_image",
|
|
bsw@274
|
58 view = "_show",
|
|
bsw@274
|
59 params = {
|
|
bsw@274
|
60 member = trustee_member,
|
|
bsw@274
|
61 image_type = "avatar",
|
|
bsw@274
|
62 show_dummy = true,
|
|
bsw@274
|
63 class = "micro_avatar",
|
|
bsw@274
|
64 popup_text = text
|
|
bsw@274
|
65 }
|
|
bsw@269
|
66 }
|
|
bsw@269
|
67 end
|
|
bsw@269
|
68 end
|
|
bsw@269
|
69 },
|
|
bsw@269
|
70 {
|
|
bsw@269
|
71 content = function(record)
|
|
bsw@269
|
72 if record.member_weight and record.direct_member_count then
|
|
bsw@269
|
73 local max_value = MemberCount:get()
|
|
bsw@269
|
74 ui.bargraph{
|
|
bsw@269
|
75 max_value = max_value,
|
|
bsw@269
|
76 width = 100,
|
|
bsw@269
|
77 bars = {
|
|
bsw@269
|
78 { color = "#444", value = record.direct_member_count },
|
|
bsw@269
|
79 { color = "#777", value = record.member_weight - record.direct_member_count },
|
|
bsw@269
|
80 { color = "#ddd", value = max_value - record.member_weight },
|
|
bsw@269
|
81 }
|
|
bsw@269
|
82 }
|
|
bsw@269
|
83 end
|
|
bsw@269
|
84 end
|
|
bsw/jbe@0
|
85 },
|
|
bsw/jbe@0
|
86 {
|
|
bsw@269
|
87 content = function(record)
|
|
bsw@269
|
88 ui.link{
|
|
bsw@269
|
89 text = record.name,
|
|
bsw@269
|
90 module = "area",
|
|
bsw@269
|
91 view = "show",
|
|
bsw@269
|
92 id = record.id
|
|
bsw@269
|
93 }
|
|
bsw@269
|
94 end
|
|
bsw/jbe@0
|
95 },
|
|
bsw/jbe@0
|
96 {
|
|
bsw@269
|
97 label = function()
|
|
bsw@269
|
98 local title = _"New"
|
|
bsw@269
|
99 ui.image{
|
|
bsw@269
|
100 attr = { title = title, alt = title },
|
|
bsw@269
|
101 static = "icons/16/new.png"
|
|
bsw@269
|
102 }
|
|
bsw@269
|
103 end,
|
|
bsw@269
|
104 field_attr = field_attr,
|
|
bsw@269
|
105 label_attr = label_attr,
|
|
bsw@269
|
106 content = function(record)
|
|
bsw@269
|
107 ui.link{
|
|
bsw@269
|
108 text = tostring(record.issues_new_count),
|
|
bsw@269
|
109 module = "area",
|
|
bsw@269
|
110 view = "show",
|
|
bsw@269
|
111 id = record.id,
|
|
bsw@269
|
112 params = { filter = "new", tab = "issues" }
|
|
bsw@269
|
113 }
|
|
bsw@269
|
114 end
|
|
bsw@269
|
115 },
|
|
bsw@269
|
116 {
|
|
bsw@269
|
117 label = function()
|
|
bsw@269
|
118 local title = _"Discussion"
|
|
bsw@269
|
119 ui.image{
|
|
bsw@269
|
120 attr = { title = title, alt = title },
|
|
bsw@269
|
121 static = "icons/16/comments.png"
|
|
bsw@269
|
122 }
|
|
bsw@269
|
123 end,
|
|
bsw@269
|
124 field_attr = field_attr,
|
|
bsw@269
|
125 label_attr = label_attr,
|
|
bsw@269
|
126 content = function(record)
|
|
bsw@269
|
127 ui.link{
|
|
bsw@269
|
128 text = tostring(record.issues_discussion_count),
|
|
bsw@269
|
129 module = "area",
|
|
bsw@269
|
130 view = "show",
|
|
bsw@269
|
131 id = record.id,
|
|
bsw@269
|
132 params = { filter = "accepted", tab = "issues" }
|
|
bsw@269
|
133 }
|
|
bsw@269
|
134 end
|
|
bsw/jbe@0
|
135 },
|
|
bsw/jbe@0
|
136 {
|
|
bsw@269
|
137 label = function()
|
|
bsw@269
|
138 local title = _"Frozen"
|
|
bsw@269
|
139 ui.image{
|
|
bsw@269
|
140 attr = { title = title, alt = title },
|
|
bsw@269
|
141 static = "icons/16/lock.png"
|
|
bsw@269
|
142 }
|
|
bsw@269
|
143 end,
|
|
bsw@269
|
144 field_attr = field_attr,
|
|
bsw@269
|
145 label_attr = label_attr,
|
|
bsw@269
|
146 content = function(record)
|
|
bsw@269
|
147 ui.link{
|
|
bsw@269
|
148 text = tostring(record.issues_frozen_count),
|
|
bsw@269
|
149 module = "area",
|
|
bsw@269
|
150 view = "show",
|
|
bsw@269
|
151 id = record.id,
|
|
bsw@269
|
152 params = { filter = "half_frozen", tab = "issues" }
|
|
bsw@269
|
153 }
|
|
bsw@269
|
154 end
|
|
bsw@269
|
155 },
|
|
bsw@269
|
156 {
|
|
bsw@269
|
157 label = function()
|
|
bsw@269
|
158 local title = _"Voting"
|
|
bsw@269
|
159 ui.image{
|
|
bsw@269
|
160 attr = { title = title, alt = title },
|
|
bsw@269
|
161 static = "icons/16/email_open.png"
|
|
bsw@269
|
162 }
|
|
bsw@269
|
163 end,
|
|
bsw@269
|
164 field_attr = field_attr,
|
|
bsw@269
|
165 label_attr = label_attr,
|
|
bsw@269
|
166 content = function(record)
|
|
bsw@269
|
167 ui.link{
|
|
bsw@269
|
168 text = tostring(record.issues_voting_count),
|
|
bsw@269
|
169 module = "area",
|
|
bsw@269
|
170 view = "show",
|
|
bsw@269
|
171 id = record.id,
|
|
bsw@269
|
172 params = { filter = "frozen", tab = "issues" }
|
|
bsw@269
|
173 }
|
|
bsw@269
|
174 end
|
|
bsw@269
|
175 },
|
|
bsw@269
|
176 {
|
|
bsw@269
|
177 label = function()
|
|
bsw@269
|
178 local title = _"Finished"
|
|
bsw@269
|
179 ui.image{
|
|
bsw@269
|
180 attr = { title = title, alt = title },
|
|
bsw@269
|
181 static = "icons/16/tick.png"
|
|
bsw@269
|
182 }
|
|
bsw@269
|
183 end,
|
|
bsw@269
|
184 field_attr = field_attr,
|
|
bsw@269
|
185 label_attr = label_attr,
|
|
bsw@269
|
186 content = function(record)
|
|
bsw@269
|
187 ui.link{
|
|
bsw@269
|
188 text = tostring(record.issues_finished_count),
|
|
bsw@269
|
189 module = "area",
|
|
bsw@269
|
190 view = "show",
|
|
bsw@269
|
191 id = record.id,
|
|
bsw@269
|
192 params = { filter = "finished", issue_list = "newest", tab = "issues" }
|
|
bsw@269
|
193 }
|
|
bsw@269
|
194 end
|
|
bsw@269
|
195 },
|
|
bsw@269
|
196 {
|
|
bsw@269
|
197 label = function()
|
|
bsw@269
|
198 local title = _"Cancelled"
|
|
bsw@269
|
199 ui.image{
|
|
bsw@269
|
200 attr = { title = title, alt = title },
|
|
bsw@269
|
201 static = "icons/16/cross.png"
|
|
bsw@269
|
202 }
|
|
bsw@269
|
203 end,
|
|
bsw@269
|
204 field_attr = field_attr,
|
|
bsw@269
|
205 label_attr = label_attr,
|
|
bsw@269
|
206 content = function(record)
|
|
bsw@269
|
207 ui.link{
|
|
bsw@269
|
208 text = tostring(record.issues_cancelled_count),
|
|
bsw@269
|
209 module = "area",
|
|
bsw@269
|
210 view = "show",
|
|
bsw@269
|
211 id = record.id,
|
|
bsw@269
|
212 params = { filter = "cancelled", issue_list = "newest", tab = "issues" }
|
|
bsw@269
|
213 }
|
|
bsw@269
|
214 end
|
|
bsw@269
|
215 },
|
|
bsw@269
|
216 {
|
|
bsw@269
|
217 content = function(record)
|
|
bsw@269
|
218 if record.issues_to_vote_count > 0 then
|
|
bsw@269
|
219 ui.link{
|
|
bsw@269
|
220 attr = { class = "not_voted" },
|
|
bsw@269
|
221 text = _"Not yet voted" .. ": " .. tostring(record.issues_to_vote_count),
|
|
bsw@269
|
222 module = "area",
|
|
bsw@269
|
223 view = "show",
|
|
bsw@269
|
224 id = record.id,
|
|
bsw@269
|
225 params = {
|
|
bsw@269
|
226 filter = "frozen",
|
|
bsw@269
|
227 filter_voting = "not_voted",
|
|
bsw@269
|
228 tab = "issues"
|
|
bsw@9
|
229 }
|
|
bsw@269
|
230 }
|
|
bsw@269
|
231 end
|
|
bsw@269
|
232 end
|
|
bsw@269
|
233 },
|
|
bsw@269
|
234 }
|
|
bsw/jbe@4
|
235 }
|
|
bsw@274
|
236 --[[
|
|
bsw/jbe@4
|
237 ui.bargraph_legend{
|
|
bsw/jbe@4
|
238 width = 25,
|
|
bsw/jbe@4
|
239 bars = {
|
|
bsw/jbe@4
|
240 { color = "#444", label = _"Direct membership" },
|
|
bsw/jbe@4
|
241 { color = "#777", label = _"Membership by delegation" },
|
|
bsw/jbe@4
|
242 { color = "#ddd", label = _"No membership at all" },
|
|
bsw/jbe@4
|
243 }
|
|
bsw/jbe@4
|
244 }
|
|
bsw/jbe@4
|
245
|
|
bsw/jbe@19
|
246 slot.put("<br /> ")
|
|
bsw/jbe@19
|
247
|
|
bsw/jbe@19
|
248
|
|
bsw@51
|
249 if app.session.member_id then
|
|
bsw@51
|
250 ui.image{
|
|
bsw@51
|
251 attr = { title = title, alt = title },
|
|
bsw@51
|
252 static = "icons/16/user_gray.png"
|
|
bsw@51
|
253 }
|
|
bsw@51
|
254 slot.put(" ")
|
|
bsw@51
|
255 slot.put(_"Member of area")
|
|
bsw@51
|
256 slot.put(" ")
|
|
mail@240
|
257
|
|
mail@240
|
258 ui.image{
|
|
mail@240
|
259 attr = { title = title, alt = title },
|
|
mail@240
|
260 static = "icons/16/link.png"
|
|
mail@240
|
261 }
|
|
mail@240
|
262 slot.put(" ")
|
|
mail@240
|
263 slot.put(_"Area delegated")
|
|
mail@240
|
264 slot.put(" ")
|
|
bsw@51
|
265 end
|
|
bsw/jbe@19
|
266
|
|
bsw/jbe@19
|
267 ui.image{
|
|
bsw/jbe@19
|
268 attr = { title = title, alt = title },
|
|
bsw/jbe@19
|
269 static = "icons/16/new.png"
|
|
bsw/jbe@19
|
270 }
|
|
bsw/jbe@19
|
271 slot.put(" ")
|
|
bsw/jbe@19
|
272 slot.put(_"New")
|
|
bsw/jbe@19
|
273 slot.put(" ")
|
|
bsw/jbe@19
|
274
|
|
bsw/jbe@19
|
275 ui.image{
|
|
bsw/jbe@19
|
276 attr = { title = title, alt = title },
|
|
bsw/jbe@19
|
277 static = "icons/16/comments.png"
|
|
bsw/jbe@19
|
278 }
|
|
bsw/jbe@19
|
279 slot.put(" ")
|
|
bsw/jbe@19
|
280 slot.put(_"Discussion")
|
|
bsw/jbe@19
|
281 slot.put(" ")
|
|
bsw/jbe@19
|
282
|
|
bsw/jbe@19
|
283 ui.image{
|
|
bsw/jbe@19
|
284 attr = { title = title, alt = title },
|
|
bsw/jbe@19
|
285 static = "icons/16/lock.png"
|
|
bsw/jbe@19
|
286 }
|
|
bsw/jbe@19
|
287 slot.put(" ")
|
|
bsw/jbe@19
|
288 slot.put(_"Frozen")
|
|
bsw/jbe@19
|
289 slot.put(" ")
|
|
bsw/jbe@19
|
290
|
|
bsw/jbe@19
|
291 ui.image{
|
|
bsw/jbe@19
|
292 attr = { title = title, alt = title },
|
|
bsw/jbe@19
|
293 static = "icons/16/email_open.png"
|
|
bsw/jbe@19
|
294 }
|
|
bsw/jbe@19
|
295 slot.put(" ")
|
|
bsw/jbe@19
|
296 slot.put(_"Voting")
|
|
bsw/jbe@19
|
297 slot.put(" ")
|
|
bsw/jbe@19
|
298
|
|
bsw/jbe@19
|
299 ui.image{
|
|
bsw/jbe@19
|
300 attr = { title = title, alt = title },
|
|
bsw/jbe@19
|
301 static = "icons/16/tick.png"
|
|
bsw/jbe@19
|
302 }
|
|
bsw/jbe@19
|
303 slot.put(" ")
|
|
bsw/jbe@19
|
304 slot.put(_"Finished")
|
|
bsw/jbe@19
|
305 slot.put(" ")
|
|
bsw/jbe@19
|
306
|
|
bsw/jbe@19
|
307 ui.image{
|
|
bsw/jbe@19
|
308 attr = { title = title, alt = title },
|
|
bsw/jbe@19
|
309 static = "icons/16/cross.png"
|
|
bsw/jbe@19
|
310 }
|
|
bsw/jbe@19
|
311 slot.put(" ")
|
|
bsw/jbe@19
|
312 slot.put(_"Cancelled")
|
|
bsw/jbe@19
|
313
|
|
bsw@274
|
314 --]] |