liquid_feedback_frontend

view app/main/issue/_list.lua @ 275:fc14e76afe31

Made filter better useable
author bsw
date Sun Feb 12 13:42:08 2012 +0100 (2012-02-12)
parents 7196685f9dd7
children 808269b7f41c
line source
1 local issues_selector = param.get("issues_selector", "table")
3 if app.session.member_id then
4 issues_selector
5 :left_join("interest", "_interest", { "_interest.issue_id = issue.id AND _interest.member_id = ?", app.session.member.id} )
6 :add_field("(_interest.member_id NOTNULL)", "is_interested")
7 end
9 ui.add_partial_param_names{
10 "filter",
11 "filter_open",
12 "filter_voting",
13 "filter_interest",
14 "issue_list"
15 }
17 local filters = execute.load_chunk{module="issue", chunk="_filters.lua"}
19 filters.content = function()
20 ui.paginate{
21 per_page = tonumber(param.get("per_page")),
22 selector = issues_selector,
23 content = function()
24 local highlight_string = param.get("highlight_string", "string")
25 local issues = issues or issues_selector:exec()
26 -- issues:load(initiatives)
27 ui.container{ attr = { class = "issues" }, content = function()
29 for i, issue in ipairs(issues) do
31 local class = "issue"
32 if issue.is_interested then
33 class = class .. " interested"
34 end
35 ui.container{ attr = { class = class }, content = function()
37 ui.container{ attr = { class = "issue_info" }, content = function()
39 ui.tag{
40 tag = "div",
41 content = function()
42 ui.link{
43 attr = { class = "issue_id" },
44 text = _("Issue ##{id}", { id = tostring(issue.id) }),
45 module = "issue",
46 view = "show",
47 id = issue.id
48 }
50 -- if not param.get("for_area_list", atom.boolean) then
51 slot.put(" · ")
52 ui.tag{ content = issue.area.unit.name }
53 slot.put(" · ")
54 ui.tag{ content = issue.area.name }
55 -- end
56 end
57 }
58 ui.tag{
59 tag = "div",
60 content = function()
62 ui.tag{ content = issue.policy.name }
64 slot.put(" · ")
65 ui.tag{ content = issue.state_name }
67 if issue.state_time_left then
68 slot.put(" · ")
69 ui.tag{ content = _("#{time_left} left", { time_left = issue.state_time_left }) }
70 end
72 end
73 }
76 if issue.old_state then
77 ui.field.text{ value = format.time(issue.sort) }
78 ui.field.text{ value = Issue:get_state_name_for_state(issue.old_state) .. " > " .. Issue:get_state_name_for_state(issue.new_state) }
79 else
80 end
81 end }
83 ui.container{ attr = { class = "initiative_list" }, content = function()
85 local initiatives_selector = issue:get_reference_selector("initiatives")
86 local highlight_string = param.get("highlight_string")
87 if highlight_string then
88 initiatives_selector:add_field( {'"highlight"("initiative"."name", ?)', highlight_string }, "name_highlighted")
89 end
90 execute.view{
91 module = "initiative",
92 view = "_list",
93 params = {
94 issue = issue,
95 initiatives_selector = initiatives_selector,
96 highlight_string = highlight_string,
97 per_page = app.session.member_id and tonumber(app.session.member:get_setting_value("initiatives_preview_limit") or 3) or 3,
98 no_sort = true,
99 limit = app.session.member_id and tonumber(app.session.member:get_setting_value("initiatives_preview_limit") or 3) or 3
100 }
101 }
102 end }
103 end }
104 end
105 end }
106 end
107 }
108 end
110 filters.opened = true
111 filters.selector = issues_selector
113 if param.get("no_filter", atom.boolean) then
114 filters.content()
115 else
116 ui.filters(filters)
117 end
119 if param.get("legend", atom.boolean) ~= false then
120 local filter = param.get_all_cgi().filter
121 if not filter or filter == "any" or filter ~= "finished" then
122 ui.bargraph_legend{
123 width = 25,
124 bars = {
125 { color = "#0a0", label = _"Supporter" },
126 { color = "#777", label = _"Potential supporter" },
127 { color = "#ddd", label = _"No support at all" },
128 }
129 }
130 end
131 if not filter or filter == "any" or filter == "finished" then
132 ui.bargraph_legend{
133 width = 25,
134 bars = {
135 { color = "#0a0", label = _"Yes" },
136 { color = "#aaa", label = _"Abstention" },
137 { color = "#a00", label = _"No" },
138 }
139 }
140 end
141 end

Impressum / About Us