liquid_feedback_frontend

annotate app/main/area/_list.lua @ 276:f460555c9896

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

Impressum / About Us