liquid_feedback_frontend

annotate app/main/delegation/new.lua @ 182:24b61c3fd933

Added missing encoding to suggestion text
author bsw
date Mon Nov 01 22:01:45 2010 +0100 (2010-11-01)
parents 02aacb3dffe0
children 02197b85ca3b
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@180 79 local records
bsw@180 80
bsw@180 81 if issue then
bsw@180 82 records = {
bsw@180 83 {
bsw@180 84 id = -1,
bsw@180 85 name = _"Inherit delegation from area"
bsw@180 86 },
bsw@180 87 {
bsw@180 88 id = 0,
bsw@180 89 name = _"No delegation (override area delegation)"
bsw@180 90 },
bsw@180 91
bsw/jbe@4 92 }
bsw@180 93 elseif area then
bsw@180 94 records = {
bsw@180 95 {
bsw@180 96 id = -1,
bsw@180 97 name = _"Inherit global delegation"
bsw@180 98 },
bsw@180 99 {
bsw@180 100 id = 0,
bsw@180 101 name = _"No delegation (override global delegation)"
bsw@180 102 }
bsw@180 103 }
bsw@180 104
bsw@180 105 else
bsw@180 106 records = {
bsw@180 107 {
bsw@180 108 id = -1,
bsw@180 109 name = _"No delegation"
bsw@180 110 }
bsw@180 111 }
bsw@180 112
bsw@180 113 end
poelzi@111 114
bsw/jbe@4 115 for i, record in ipairs(contact_members) do
bsw/jbe@4 116 records[#records+1] = record
bsw/jbe@4 117 end
poelzi@111 118 disabled_records = {}
poelzi@111 119 -- add initiative authors
poelzi@111 120 if initiative then
poelzi@111 121 records[#records+1] = {id="_", name=_"--- Initiators ---"}
poelzi@111 122 disabled_records["_"] = true
poelzi@111 123 for i,record in ipairs(initiative.initiators) do
poelzi@111 124 trace.debug(record)
poelzi@111 125 trace.debug(record.member.name)
poelzi@111 126 records[#records+1] = record.member
poelzi@111 127 end
poelzi@111 128 end
bsw/jbe@4 129
bsw/jbe@0 130 ui.field.select{
bsw/jbe@0 131 label = _"Trustee",
bsw/jbe@0 132 name = "trustee_id",
bsw/jbe@4 133 foreign_records = records,
bsw/jbe@0 134 foreign_id = "id",
bsw/jbe@4 135 foreign_name = "name",
poelzi@111 136 disabled_records = disabled_records
bsw/jbe@0 137 }
poelzi@111 138
bsw/jbe@0 139 ui.submit{ text = _"Save" }
bsw/jbe@0 140 end
bsw/jbe@4 141 }

Impressum / About Us