liquid_feedback_frontend

annotate app/main/delegation/new.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
author Daniel Poelzleithner <poelzi@poelzi.org>
date Sat Oct 09 03:42:48 2010 +0200 (2010-10-09)
parents bf885faf3452
children 02aacb3dffe0
rev   line source
bsw/jbe@0 1 local area = Area:by_id(param.get("area_id", atom.integer))
bsw/jbe@0 2 if area then
bsw/jbe@0 3 slot.put_into("title", encode.html(_"Set delegation for Area '#{name}'":gsub("#{name}", area.name)))
bsw/jbe@4 4 util.help("delegation.new.area")
bsw/jbe@0 5 end
bsw/jbe@0 6
bsw/jbe@0 7 local issue = Issue:by_id(param.get("issue_id", atom.integer))
bsw/jbe@0 8 if issue then
bsw/jbe@0 9 slot.put_into("title", encode.html(_"Set delegation for Issue ##{number} in Area '#{area_name}'":gsub("#{number}", issue.id):gsub("#{area_name}", issue.area.name)))
bsw/jbe@4 10 util.help("delegation.new.issue")
bsw/jbe@0 11 end
bsw/jbe@0 12
poelzi@111 13 local initiative = Initiative:by_id(param.get("initiative_id", atom.integer))
poelzi@111 14
bsw/jbe@4 15 if not area and not issue then
bsw/jbe@4 16 slot.put_into("title", encode.html(_"Set global delegation"))
bsw/jbe@4 17 util.help("delegation.new.global")
bsw/jbe@4 18 end
bsw/jbe@4 19
bsw/jbe@4 20 slot.select("actions", function()
bsw/jbe@4 21 if issue then
bsw/jbe@4 22 ui.link{
bsw/jbe@4 23 module = "issue",
bsw/jbe@4 24 view = "show",
bsw/jbe@4 25 id = issue.id,
bsw/jbe@4 26 content = function()
bsw/jbe@4 27 ui.image{ static = "icons/16/cancel.png" }
bsw/jbe@4 28 slot.put(_"Cancel")
bsw/jbe@4 29 end,
bsw/jbe@4 30 }
bsw/jbe@4 31 elseif area then
bsw/jbe@4 32 ui.link{
bsw/jbe@4 33 module = "area",
bsw/jbe@4 34 view = "show",
bsw/jbe@4 35 id = area.id,
bsw/jbe@4 36 content = function()
bsw/jbe@4 37 ui.image{ static = "icons/16/cancel.png" }
bsw/jbe@4 38 slot.put(_"Cancel")
bsw/jbe@4 39 end,
bsw/jbe@4 40 }
bsw/jbe@4 41 else
bsw/jbe@4 42 ui.link{
bsw/jbe@4 43 module = "index",
bsw/jbe@4 44 view = "index",
bsw/jbe@4 45 content = function()
bsw/jbe@4 46 ui.image{ static = "icons/16/cancel.png" }
bsw/jbe@4 47 slot.put(_"Cancel")
bsw/jbe@4 48 end,
bsw/jbe@4 49 }
bsw/jbe@4 50 end
bsw/jbe@4 51 end)
bsw/jbe@4 52
bsw/jbe@4 53
bsw/jbe@0 54
bsw/jbe@0 55 local contact_members = Member:new_selector()
bsw/jbe@0 56 :add_where{ "contact.member_id = ?", app.session.member.id }
bsw/jbe@0 57 :join("contact", nil, "member.id = contact.other_member_id")
bsw/jbe@4 58 :add_order_by("member.name")
bsw/jbe@0 59 :exec()
bsw/jbe@0 60
bsw/jbe@0 61
bsw/jbe@0 62 ui.form{
bsw/jbe@0 63 attr = { class = "vertical" },
bsw/jbe@0 64 module = "delegation",
bsw/jbe@0 65 action = "update",
bsw/jbe@0 66 params = {
bsw/jbe@0 67 area_id = area and area.id or nil,
bsw/jbe@0 68 issue_id = issue and issue.id or nil,
bsw/jbe@0 69 },
bsw/jbe@0 70 routing = {
bsw/jbe@0 71 default = {
bsw/jbe@0 72 mode = "redirect",
bsw/jbe@4 73 module = area and "area" or issue and "issue" or "index",
bsw/jbe@4 74 view = (area or issue) and "show" or "index",
bsw/jbe@4 75 id = area and area.id or issue and issue.id or nil,
bsw/jbe@0 76 }
bsw/jbe@0 77 },
bsw/jbe@0 78 content = function()
bsw@10 79 local records = {
bsw/jbe@4 80 {
bsw/jbe@4 81 id = "-1",
bsw/jbe@4 82 name = _"No delegation"
bsw/jbe@4 83 }
bsw/jbe@4 84 }
poelzi@111 85
bsw/jbe@4 86 for i, record in ipairs(contact_members) do
bsw/jbe@4 87 records[#records+1] = record
bsw/jbe@4 88 end
poelzi@111 89 disabled_records = {}
poelzi@111 90 -- add initiative authors
poelzi@111 91 if initiative then
poelzi@111 92 records[#records+1] = {id="_", name=_"--- Initiators ---"}
poelzi@111 93 disabled_records["_"] = true
poelzi@111 94 for i,record in ipairs(initiative.initiators) do
poelzi@111 95 trace.debug(record)
poelzi@111 96 trace.debug(record.member.name)
poelzi@111 97 records[#records+1] = record.member
poelzi@111 98 end
poelzi@111 99 end
bsw/jbe@4 100
bsw/jbe@0 101 ui.field.select{
bsw/jbe@0 102 label = _"Trustee",
bsw/jbe@0 103 name = "trustee_id",
bsw/jbe@4 104 foreign_records = records,
bsw/jbe@0 105 foreign_id = "id",
bsw/jbe@4 106 foreign_name = "name",
poelzi@111 107 disabled_records = disabled_records
bsw/jbe@0 108 }
poelzi@111 109
bsw/jbe@0 110 ui.submit{ text = _"Save" }
bsw/jbe@0 111 end
bsw/jbe@4 112 }

Impressum / About Us