liquid_feedback_frontend
annotate app/main/initiative/_battles.lua @ 118:93f4e465b50d
add initiator support in delegation
if a delegation is issued from the initiative view, the initiators
from that one are added to the delegation target list. this makes it easier to delegate to the author without the need to add him to the contact list.
if a delegation is issued from the initiative view, the initiators
from that one are added to the delegation target list. this makes it easier to delegate to the author without the need to add him to the contact list.
author | Daniel Poelzleithner <poelzi@poelzi.org> |
---|---|
date | Mon Sep 20 20:32:04 2010 +0200 (2010-09-20) |
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 |