bsw@718: bsw@718: local initiative = param.get("initiative", "table") bsw@718: local suggestions_selector = param.get("suggestions_selector", "table") bsw@718: bsw@718: suggestions_selector:add_order_by("plus2_unfulfilled_count + plus1_unfulfilled_count DESC, id") bsw@718: bsw@718: local tab_id = param.get("tab_id") bsw@718: local show_name = param.get("show_name", atom.boolean) bsw@718: if show_name == nil then bsw@718: show_name = true bsw@718: end bsw@718: local show_filter = param.get("show_filter", atom.boolean) bsw@718: if show_filter == nil then bsw@718: show_filter = true bsw@718: end bsw@718: bsw@718: local partial = { bsw@718: routing = { bsw@718: default = { bsw@718: mode = "redirect", bsw@718: module = "initiative", bsw@718: view = "show_tab", bsw@718: params = { bsw@718: initiative_id = initiative.id, bsw@718: tab = "suggestions", bsw@718: tab_id = tab_id bsw@718: }, bsw@718: } bsw@718: } bsw@718: } bsw@718: bsw@718: local ui_filters = ui.filters bsw@718: if true or not show_filter then bsw@718: ui_filters = function(args) args.content() end bsw@718: end bsw@718: bsw@718: ui.container{ attr = { class = "box" }, bsw@718: content = function() bsw@718: ui.paginate{ bsw@718: selector = suggestions_selector, bsw@718: content = function() bsw@718: ui.list{ bsw@718: attr = { style = "table-layout: fixed;" }, bsw@718: records = suggestions_selector:exec(), bsw@718: columns = { bsw@718: { bsw@718: label = show_name and _"Suggestion" or nil, bsw@718: content = function(record) bsw@718: if show_name then bsw@718: ui.link{ bsw@718: text = record.name, bsw@718: module = "suggestion", bsw@718: view = "show", bsw@718: id = record.id bsw@718: } bsw@718: end bsw@718: end bsw@718: }, bsw@718: { bsw@718: label = _"Collective opinion of supporters", bsw@718: label_attr = { style = "width: 101px;" }, bsw@718: content = function(record) bsw@718: if record.minus2_unfulfilled_count then bsw@718: local max_value = record.initiative.supporter_count bsw@718: ui.bargraph{ bsw@718: max_value = max_value, bsw@718: width = 100, bsw@718: bars = { bsw@718: { color = "#0a0", value = record.plus2_unfulfilled_count + record.plus2_fulfilled_count }, bsw@718: { color = "#8f8", value = record.plus1_unfulfilled_count + record.plus1_fulfilled_count }, bsw@718: { color = "#eee", value = max_value - record.minus2_unfulfilled_count - record.minus1_unfulfilled_count - record.minus2_fulfilled_count - record.minus1_fulfilled_count - record.plus1_unfulfilled_count - record.plus2_unfulfilled_count - record.plus1_fulfilled_count - record.plus2_fulfilled_count}, bsw@718: { color = "#f88", value = record.minus1_unfulfilled_count + record.minus1_fulfilled_count }, bsw@718: { color = "#a00", value = record.minus2_unfulfilled_count + record.minus2_fulfilled_count }, bsw@718: } bsw@718: } bsw@718: end bsw@718: end bsw@718: }, bsw@718: { bsw@718: label = _"My opinion", bsw@718: label_attr = { style = "width: 130px; font-style: italic;" }, bsw@718: content = function(record) bsw@718: local degree bsw@718: local opinion bsw@718: if app.session.member_id then bsw@718: opinion = Opinion:by_pk(app.session.member.id, record.id) bsw@718: end bsw@718: if opinion then bsw@718: degree = opinion.degree bsw@718: end bsw@718: ui.container{ bsw@718: attr = { class = "suggestion_my_opinion" }, bsw@718: content = function() bsw@718: local has_voting_right = app.session.member and app.session.member:has_voting_right_for_unit_id(initiative.issue.area.unit_id) bsw@718: if app.session.member_id and has_voting_right then bsw@718: if initiative.issue.state == "voting" or initiative.issue.state == "closed" then bsw@718: if degree == -2 then bsw@718: ui.tag{ bsw@718: tag = "span", bsw@718: attr = { bsw@718: class = "action" .. (degree == -2 and " active_red2" or "") bsw@718: }, bsw@718: content = _"must not" bsw@718: } bsw@718: end bsw@718: if degree == -1 then bsw@718: ui.tag{ bsw@718: tag = "span", bsw@718: attr = { class = "action" .. (degree == -1 and " active_red1" or "") }, bsw@718: content = _"should not" bsw@718: } bsw@718: end bsw@718: if degree == nil then bsw@718: ui.tag{ bsw@718: tag = "span", bsw@718: attr = { class = "action" .. (degree == nil and " active" or "") }, bsw@718: content = _"neutral" bsw@718: } bsw@718: end bsw@718: if degree == 1 then bsw@718: ui.tag{ bsw@718: tag = "span", bsw@718: attr = { class = "action" .. (degree == 1 and " active_green1" or "") }, bsw@718: content = _"should" bsw@718: } bsw@718: end bsw@718: if degree == 2 then bsw@718: ui.tag{ bsw@718: tag = "span", bsw@718: attr = { class = "action" .. (degree == 2 and " active_green2" or "") }, bsw@718: content = _"must" bsw@718: } bsw@718: end bsw@718: else bsw@718: -- we need to put initiative_id into the parameters to have a redirect target in case the suggestion is gone after the action bsw@718: params = param.get_all_cgi() bsw@718: params['initiative_id'] = initiative.id bsw@718: bsw@718: ui.link{ bsw@718: attr = { class = "action" .. (degree == 2 and " active_green2" or "") }, bsw@718: text = _"must", bsw@718: module = "opinion", bsw@718: action = "update", bsw@718: routing = { default = { mode = "redirect", module = request.get_module(), view = request.get_view(), id = param.get_id_cgi(), params = params } }, bsw@718: params = { bsw@718: suggestion_id = record.id, bsw@718: degree = 2 bsw@718: }, bsw@718: partial = partial bsw@718: } bsw@718: slot.put(" ") bsw@718: ui.link{ bsw@718: attr = { class = "action" .. (degree == 1 and " active_green1" or "") }, bsw@718: text = _"should", bsw@718: module = "opinion", bsw@718: action = "update", bsw@718: routing = { default = { mode = "redirect", module = request.get_module(), view = request.get_view(), id = param.get_id_cgi(), params = params} }, bsw@718: params = { bsw@718: suggestion_id = record.id, bsw@718: degree = 1 bsw@718: }, bsw@718: partial = partial bsw@718: } bsw@718: slot.put(" ") bsw@718: ui.link{ bsw@718: attr = { class = "action" .. (degree == nil and " active" or "") }, bsw@718: text = _"neutral", bsw@718: module = "opinion", bsw@718: action = "update", bsw@718: routing = { default = { mode = "redirect", module = request.get_module(), view = request.get_view(), id = param.get_id_cgi(), params = params } }, bsw@718: params = { bsw@718: suggestion_id = record.id, bsw@718: delete = true bsw@718: }, bsw@718: partial = partial bsw@718: } bsw@718: slot.put(" ") bsw@718: ui.link{ bsw@718: attr = { class = "action" .. (degree == -1 and " active_red1" or "") }, bsw@718: text = _"should not", bsw@718: module = "opinion", bsw@718: action = "update", bsw@718: routing = { default = { mode = "redirect", module = request.get_module(), view = request.get_view(), id = param.get_id_cgi(), params = params } }, bsw@718: params = { bsw@718: suggestion_id = record.id, bsw@718: degree = -1 bsw@718: }, bsw@718: partial = partial bsw@718: } bsw@718: slot.put(" ") bsw@718: ui.link{ bsw@718: attr = { class = "action" .. (degree == -2 and " active_red2" or "") }, bsw@718: text = _"must not", bsw@718: module = "opinion", bsw@718: action = "update", bsw@718: routing = { default = { mode = "redirect", module = request.get_module(), view = request.get_view(), id = param.get_id_cgi(), params = params } }, bsw@718: params = { bsw@718: suggestion_id = record.id, bsw@718: degree = -2 bsw@718: }, bsw@718: partial = partial bsw@718: } bsw@718: end bsw@718: elseif app.session.member_id then bsw@718: ui.field.text{ value = _"[No voting privilege]" } bsw@718: else bsw@718: ui.field.text{ value = _"[Registered members only]" } bsw@718: end bsw@718: end bsw@718: } bsw@718: end bsw@718: }, bsw@718: { bsw@718: label = _"Suggestion currently not implemented", bsw@718: label_attr = { style = "width: 101px;" }, bsw@718: content = function(record) bsw@718: if record.minus2_unfulfilled_count then bsw@718: local max_value = record.initiative.supporter_count bsw@718: ui.bargraph{ bsw@718: max_value = max_value, bsw@718: width = 100, bsw@718: bars = { bsw@718: { color = "#0a0", value = record.plus2_unfulfilled_count }, bsw@718: { color = "#8f8", value = record.plus1_unfulfilled_count }, bsw@718: { color = "#eee", value = max_value - record.minus2_unfulfilled_count - record.minus1_unfulfilled_count - record.plus1_unfulfilled_count - record.plus2_unfulfilled_count }, bsw@718: { color = "#f88", value = record.minus1_unfulfilled_count }, bsw@718: { color = "#a00", value = record.minus2_unfulfilled_count }, bsw@718: } bsw@718: } bsw@718: end bsw@718: end bsw@718: }, bsw@718: { bsw@718: label = _"Suggestion currently implemented", bsw@718: label_attr = { style = "width: 101px;" }, bsw@718: content = function(record) bsw@718: if record.minus2_fulfilled_count then bsw@718: local max_value = record.initiative.supporter_count bsw@718: ui.bargraph{ bsw@718: max_value = max_value, bsw@718: width = 100, bsw@718: bars = { bsw@718: { color = "#0a0", value = record.plus2_fulfilled_count }, bsw@718: { color = "#8f8", value = record.plus1_fulfilled_count }, bsw@718: { color = "#eee", value = max_value - record.minus2_fulfilled_count - record.minus1_fulfilled_count - record.plus1_fulfilled_count - record.plus2_fulfilled_count}, bsw@718: { color = "#f88", value = record.minus1_fulfilled_count }, bsw@718: { color = "#a00", value = record.minus2_fulfilled_count }, bsw@718: } bsw@718: } bsw@718: end bsw@718: end bsw@718: }, bsw@718: { bsw@718: label = app.session.member_id and _"I consider suggestion as" or nil, bsw@718: label_attr = { style = "width: 100px; font-style: italic;" }, bsw@718: content = function(record) bsw@718: local degree bsw@718: local opinion bsw@718: if app.session.member_id then bsw@718: opinion = Opinion:by_pk(app.session.member.id, record.id) bsw@718: end bsw@718: if opinion then bsw@718: degree = opinion.degree bsw@718: end bsw@718: if opinion then bsw@718: bsw@718: ui.link{ bsw@718: attr = { class = opinion.fulfilled and "action active" or "action" }, bsw@718: text = _"implemented", bsw@718: module = "opinion", bsw@718: action = "update", bsw@718: routing = { default = { mode = "redirect", module = request.get_module(), view = request.get_view(), id = param.get_id_cgi(), params = param.get_all_cgi() } }, bsw@718: params = { bsw@718: suggestion_id = record.id, bsw@718: fulfilled = true bsw@718: }, bsw@718: partial = partial bsw@718: } bsw@718: slot.put("
") bsw@718: ui.link{ bsw@718: attr = { class = not opinion.fulfilled and "action active" or "action" }, bsw@718: text = _"not implemented", bsw@718: module = "opinion", bsw@718: action = "update", bsw@718: routing = { default = { mode = "redirect", module = request.get_module(), view = request.get_view(), id = param.get_id_cgi(), params = param.get_all_cgi() } }, bsw@718: params = { bsw@718: suggestion_id = record.id, bsw@718: fulfilled = false bsw@718: }, bsw@718: partial = partial bsw@718: } bsw@718: bsw@718: end bsw@718: end bsw@718: }, bsw@718: { bsw@718: label = app.session.member_id and _"So I'm" or nil, bsw@718: content = function(record) bsw@718: local opinion bsw@718: if app.session.member_id then bsw@718: opinion = Opinion:by_pk(app.session.member.id, record.id) bsw@718: end bsw@718: if opinion then bsw@718: if (opinion.fulfilled and opinion.degree > 0) or (not opinion.fulfilled and opinion.degree < 0) then bsw@718: local title = _"satisfied" bsw@718: ui.image{ attr = { alt = title, title = title }, static = "icons/emoticon_happy.png" } bsw@718: elseif opinion.degree == 1 or opinion.degree == -1 then bsw@718: local title = _"a bit unsatisfied" bsw@718: ui.image{ attr = { alt = title, title = title }, static = "icons/emoticon_unhappy.png" } bsw@718: else bsw@718: local title = _"more unsatisfied" bsw@718: ui.image{ attr = { alt = title, title = title }, static = "icons/emoticon_unhappy_red.png" } bsw@718: end bsw@718: end bsw@718: end bsw@718: }, bsw@718: } bsw@718: } bsw@718: end bsw@718: } bsw@718: end bsw@718: }