liquid_feedback_frontend

annotate app/main/area/_list.lua @ 376:e957acdc4ba2

Work on help texts
author jbe
date Sun Mar 04 16:20:56 2012 +0100 (2012-03-04)
parents 89d32158bfd5
children 2dae61588cee
rev   line source
bsw/jbe@0 1 local areas_selector = param.get("areas_selector", "table")
bsw@375 2 local hide_membership = param.get("hide_membership", atom.boolean)
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@373 32
bsw@373 33 ui.container{ attr = { class = "area_list" }, content = function()
bsw@373 34
bsw@373 35 for i, area in ipairs(areas_selector:exec()) do
bsw@373 36
bsw@373 37 ui.container{ attr = { class = "area" }, content = function()
bsw@373 38
bsw@375 39 ui.container{ attr = { class = "bar" }, content = function()
bsw@375 40 if area.member_weight and area.direct_member_count then
bsw@375 41 local max_value = MemberCount:get()
bsw@375 42 ui.bargraph{
bsw@375 43 max_value = max_value,
bsw@375 44 width = 100,
bsw@375 45 bars = {
bsw@375 46 { color = "#444", value = area.direct_member_count },
bsw@375 47 { color = "#777", value = area.member_weight - area.direct_member_count },
bsw@375 48 { color = "#ddd", value = max_value - area.member_weight },
bsw@269 49 }
bsw@375 50 }
bsw@375 51 end
bsw@375 52 end }
bsw@373 53
bsw@375 54 if not hide_membership then
bsw@373 55 ui.container{ attr = { class = "membership" }, content = function()
bsw@373 56 if area.is_member then
bsw@373 57 local text = _"Member of area"
bsw@373 58 ui.image{
bsw@373 59 attr = { title = text, alt = text },
bsw@373 60 static = "icons/16/user_gray.png",
bsw@373 61 }
bsw@373 62 else
bsw@373 63 slot.put('<img src="null.png" width="16" height="1" />')
bsw@373 64 end
bsw@373 65 end }
bsw@375 66 end
bsw@375 67
bsw@375 68 ui.container{ attr = { class = "delegatee" }, content = function()
bsw@375 69 if area.trustee_member_id then
bsw@375 70 local trustee_member = Member:by_id(area.trustee_member_id)
bsw@375 71 local text = _("Area delegated to '#{name}'", { name = area.trustee_member_name })
bsw@375 72 ui.image{
bsw@375 73 attr = { class = "delegation_arrow", alt = text, title = text },
bsw@375 74 static = "delegation_arrow_24_horizontal.png"
bsw@375 75 }
bsw@375 76 execute.view{
bsw@375 77 module = "member_image",
bsw@375 78 view = "_show",
bsw@375 79 params = {
bsw@375 80 member = trustee_member,
bsw@375 81 image_type = "avatar",
bsw@375 82 show_dummy = true,
bsw@375 83 class = "micro_avatar",
bsw@375 84 popup_text = text
bsw@373 85 }
bsw@375 86 }
bsw@375 87 else
bsw@375 88 slot.put('<img src="null.png" width="41" height="1" />')
bsw@375 89 end
bsw@375 90 end }
bsw@375 91
bsw@375 92 ui.container{ attr = { class = "name" }, content = function()
bsw@375 93 ui.link{
bsw@375 94 text = area.name,
bsw@375 95 module = "area",
bsw@375 96 view = "show",
bsw@375 97 id = area.id
bsw@375 98 }
bsw@375 99 slot.put(" ")
bsw@375 100 ui.tag{ content = "" }
bsw@373 101 end }
bsw/jbe@4 102
bsw@373 103 ui.container{ attr = { class = "phases" }, content = function()
bsw@373 104
bsw@373 105 ui.container{ attr = { class = "admission" }, content = function()
bsw@373 106 ui.link{
bsw@373 107 text = tostring(area.issues_new_count),
bsw@373 108 module = "area",
bsw@373 109 view = "show",
bsw@373 110 id = area.id,
bsw@373 111 params = { filter = "new", tab = "issues" }
bsw@373 112 }
bsw@373 113 end }
bsw/jbe@19 114
bsw@373 115 ui.container{ attr = { class = "discussion" }, content = function()
bsw@373 116 ui.link{
bsw@373 117 text = tostring(area.issues_discussion_count),
bsw@373 118 module = "area",
bsw@373 119 view = "show",
bsw@373 120 id = area.id,
bsw@373 121 params = { filter = "accepted", tab = "issues" }
bsw@373 122 }
bsw@373 123 end }
mail@240 124
bsw@373 125 ui.container{ attr = { class = "verification" }, content = function()
bsw@373 126 ui.link{
bsw@373 127 text = tostring(area.issues_frozen_count),
bsw@373 128 module = "area",
bsw@373 129 view = "show",
bsw@373 130 id = area.id,
bsw@373 131 params = { filter = "half_frozen", tab = "issues" }
bsw@373 132 }
bsw@373 133 end }
bsw/jbe@19 134
bsw@373 135 ui.container{ attr = { class = "voting" }, content = function()
bsw@373 136 ui.link{
bsw@373 137 text = tostring(area.issues_voting_count),
bsw@373 138 module = "area",
bsw@373 139 view = "show",
bsw@373 140 id = area.id,
bsw@373 141 params = { filter = "frozen", tab = "issues" }
bsw@373 142 }
bsw@373 143 end }
bsw/jbe@19 144
bsw@373 145 ui.container{ attr = { class = "finished" }, content = function()
bsw@373 146 ui.link{
bsw@373 147 text = tostring(area.issues_finished_count),
bsw@373 148 module = "area",
bsw@373 149 view = "show",
bsw@373 150 id = area.id,
bsw@373 151 params = { filter = "finished", issue_list = "newest", tab = "issues" }
bsw@373 152 }
bsw@373 153 end }
bsw/jbe@19 154
bsw@373 155 ui.container{ attr = { class = "cancelled" }, content = function()
bsw@373 156 ui.link{
bsw@373 157 text = tostring(area.issues_cancelled_count),
bsw@373 158 module = "area",
bsw@373 159 view = "show",
bsw@373 160 id = area.id,
bsw@373 161 params = { filter = "cancelled", issue_list = "newest", tab = "issues" }
bsw@373 162 }
bsw@373 163 end }
bsw/jbe@19 164
bsw@373 165 end }
bsw@373 166
bsw@375 167 slot.put("<br />")
bsw@373 168 end }
bsw@373 169
bsw@373 170 end
bsw@373 171
bsw@373 172 end }

Impressum / About Us