liquid_feedback_frontend
annotate app/main/initiative/_battles.lua @ 159:5d797c6706d5
implement quorum display
show the initiative quorum as a small 1px line in bargraph
allow to update your support on the diff page
better linked title in diff page
show absolute quorum numbers in detail pages of issue and initiative
show the initiative quorum as a small 1px line in bargraph
allow to update your support on the diff page
better linked title in diff page
show absolute quorum numbers in detail pages of issue and initiative
| author | Daniel Poelzleithner <poelzi@poelzi.org> |
|---|---|
| date | Sat Oct 09 03:42:48 2010 +0200 (2010-10-09) |
| parents | a6caaff47205 |
| children | cc64a4fc6ab6 |
| rev | line source |
|---|---|
| bsw@31 | 1 local initiative = param.get("initiative", "table") |
| bsw@31 | 2 |
| bsw@31 | 3 if not initiative.issue.closed then |
| bsw@31 | 4 return |
| bsw@31 | 5 end |
| bsw@31 | 6 |
| bsw@31 | 7 local battled_initiatives = Initiative:new_selector() |
| bsw@31 | 8 :add_field("winning_battle.count", "winning_count") |
| bsw@31 | 9 :add_field("losing_battle.count", "losing_count") |
| bsw@31 | 10 :join("battle", "winning_battle", { "winning_battle.winning_initiative_id = ? AND winning_battle.losing_initiative_id = initiative.id", initiative.id }) |
| bsw@31 | 11 :join("battle", "losing_battle", { "losing_battle.losing_initiative_id = ? AND losing_battle.winning_initiative_id = initiative.id", initiative.id }) |
| bsw@31 | 12 :add_order_by("rank") |
| bsw@31 | 13 :exec() |
| bsw@31 | 14 |
| bsw@31 | 15 |
| bsw@31 | 16 local number_of_initiatives = Initiative:new_selector() |
| bsw@31 | 17 :add_where{ "issue_id = ?", initiative.issue_id } |
| bsw@31 | 18 :add_where("admitted") |
| bsw@31 | 19 :count() |
| bsw@31 | 20 |
| bsw@31 | 21 if number_of_initiatives > 1 then |
| bsw@31 | 22 ui.container{ |
| bsw@31 | 23 attr = { class = "heading first" }, |
| bsw@31 | 24 content = _"This initiative compared to alternative initiatives" |
| bsw@31 | 25 } |
| bsw@31 | 26 |
| bsw@31 | 27 ui.list{ |
| bsw@31 | 28 records = battled_initiatives, |
| bsw@31 | 29 columns = { |
| bsw@31 | 30 { |
| bsw@31 | 31 content = function() |
| bsw@31 | 32 slot.put(_"This initiative") |
| bsw@31 | 33 end |
| bsw@31 | 34 }, |
| bsw@31 | 35 { |
| bsw@31 | 36 content = function(record) |
| bsw@31 | 37 local population = initiative.issue.voter_count |
| bsw@31 | 38 local value = record.winning_count |
| bsw@31 | 39 ui.bargraph{ |
| bsw@31 | 40 class = "bargraph bargraph50", |
| bsw@31 | 41 max_value = population, |
| bsw@31 | 42 width = 50, |
| bsw@31 | 43 bars = { |
| bsw@31 | 44 { color = "#aaa", value = population - value }, |
| bsw@31 | 45 { color = "#444", value = value }, |
| bsw@31 | 46 } |
| bsw@31 | 47 } |
| bsw@31 | 48 end |
| bsw@31 | 49 }, |
| bsw@31 | 50 { |
| bsw@31 | 51 content = function(record) |
| bsw@31 | 52 slot.put(record.winning_count) |
| bsw@31 | 53 end |
| bsw@31 | 54 }, |
| bsw@31 | 55 { |
| bsw@31 | 56 content = function(record) |
| bsw@31 | 57 if record.winning_count == record.losing_count then |
| bsw@31 | 58 ui.image{ static = "icons/16/bullet_blue.png" } |
| bsw@31 | 59 elseif record.winning_count > record.losing_count then |
| bsw@31 | 60 ui.image{ static = "icons/16/resultset_previous.png" } |
| bsw@31 | 61 else |
| bsw@31 | 62 ui.image{ static = "icons/16/resultset_next.png" } |
| bsw@31 | 63 end |
| bsw@31 | 64 end |
| bsw@31 | 65 }, |
| bsw@31 | 66 { |
| bsw@31 | 67 field_attr = { style = "text-align: right;" }, |
| bsw@31 | 68 content = function(record) |
| bsw@31 | 69 slot.put(record.losing_count) |
| bsw@31 | 70 end |
| bsw@31 | 71 }, |
| bsw@31 | 72 { |
| bsw@31 | 73 content = function(record) |
| bsw@31 | 74 local population = initiative.issue.voter_count |
| bsw@31 | 75 local value = record.losing_count |
| bsw@31 | 76 ui.bargraph{ |
| bsw@31 | 77 class = "bargraph bargraph50", |
| bsw@31 | 78 max_value = population, |
| bsw@31 | 79 width = 50, |
| bsw@31 | 80 bars = { |
| bsw@31 | 81 { color = "#444", value = value }, |
| bsw@31 | 82 { color = "#aaa", value = population - value }, |
| bsw@31 | 83 } |
| bsw@31 | 84 } |
| bsw@31 | 85 end |
| bsw@31 | 86 }, |
| bsw@31 | 87 { |
| bsw@31 | 88 content = function(record) |
| bsw@31 | 89 ui.link{ |
| bsw@31 | 90 module = "initiative", |
| bsw@31 | 91 view = "show", |
| bsw@31 | 92 id = record.id, |
| bsw@31 | 93 text = record.name |
| bsw@31 | 94 } |
| bsw@31 | 95 end |
| bsw@31 | 96 } |
| bsw@31 | 97 } |
| bsw@31 | 98 } |
| bsw@31 | 99 end |