liquid_feedback_frontend

annotate app/main/initiative/_list_element.lua @ 1666:f582e3d6434c

Fixed display of pie chart
author bsw
date Mon Feb 15 15:31:12 2021 +0100 (2021-02-15)
parents 97dfef4eb2d7
children 8d36c14128d4
rev   line source
bsw/jbe@19 1 local initiative = param.get("initiative", "table")
bsw@1045 2 local for_event = param.get("for_event", atom.boolean)
bsw/jbe@1309 3 local for_member = param.get("for_member", "table")
bsw@1045 4
bsw@1045 5 local issue = initiative.issue
bsw/jbe@19 6
bsw@1666 7 local position = param.get("position", atom.number)
bsw@1666 8
bsw/jbe@1309 9 if initiative.vote_grade ~= nil then
bsw/jbe@1309 10 if initiative.vote_grade > 0 then
bsw/jbe@1309 11 local text = _"voted yes"
bsw/jbe@1309 12 ui.container{ attr = { class = "mdl-list__item-avatar positive" }, content = function()
bsw/jbe@1309 13 ui.tag{ tag = "i", attr = { class = "material-icons", title = text }, content = "thumb_up" }
bsw/jbe@1309 14 end }
bsw/jbe@1309 15 elseif initiative.vote_grade == 0 then
bsw/jbe@1309 16 elseif initiative.vote_grade < 0 then
bsw/jbe@1309 17 local text = _"voted no"
bsw/jbe@1309 18 ui.container{ attr = { class = "mdl-list__item-avatar negative" }, content = function()
bsw/jbe@1309 19 ui.tag{ tag = "i", attr = { class = "material-icons", title = text }, content = "thumb_down" }
bsw/jbe@1309 20 end }
bsw/jbe@1309 21 end
bsw/jbe@1309 22 end
bsw/jbe@19 23
bsw@1665 24 local class = "initiative mdl-list__item-primary-content"
bsw@1045 25 if initiative.rank == 1 then
bsw@1045 26 class = class .. " rank1"
bsw@715 27 end
bsw@1045 28 if initiative.revoked then
bsw@1045 29 class = class .. " revoked"
bsw@898 30 end
bsw@898 31
bsw@1045 32 ui.container{
bsw@1045 33 attr = { class = class },
bsw@1045 34 content = function ()
bsw@1666 35 if position == 1 and not for_member and (
bsw@1666 36 initiative.issue.state == "finished_with_winner"
bsw@1666 37 or initiative.issue.state == "finished_without_winner"
bsw@1666 38 ) then
bsw@1666 39 util.initiative_pie(initiative)
bsw@1666 40 end
bsw/jbe@1309 41 ui.container {
bsw@1045 42 attr = { class = "initiative_name" },
bsw@1045 43 content = function()
bsw/jbe@1309 44 if not for_member and app.session.member then
bsw/jbe@1309 45 if initiative.member_info.supported then
bsw/jbe@1309 46 if initiative.member_info.satisfied then
bsw/jbe@1309 47 ui.tag{ tag = "i", attr = { id = "lf-initiative__support-" .. initiative.id, class = "material-icons material-icons-small" }, content = "thumb_up" }
bsw/jbe@1309 48 --ui.container { attr = { class = "mdl-tooltip", ["for"] = "lf-initiative__support-" .. initiative.id }, content = _"You are supporter of this initiative" }
bsw/jbe@1309 49 else
bsw/jbe@1309 50 ui.tag{ tag = "i", attr = { id = "lf-initiative__support-" .. initiative.id, class = "material-icons material-icons-small mdl-color-text--orange-500" }, content = "thumb_up" }
bsw/jbe@1309 51 --ui.container { attr = { class = "mdl-tooltip", ["for"] = "lf-initiative__support-" .. initiative.id }, content = _"supporter with restricting suggestions" }
bsw/jbe@1309 52 end
bsw/jbe@1309 53 slot.put(" ")
bsw/jbe@1309 54 end
bsw/jbe@1309 55 end
bsw@1045 56 ui.link {
bsw@1045 57 text = initiative.display_name,
bsw@1045 58 module = "initiative", view = "show", id = initiative.id
bsw@551 59 }
bsw/jbe@1309 60 end
bsw/jbe@1309 61 }
bsw/jbe@1309 62 ui.container{ attr = { class = "mdl-list__item-text-body" }, content = function()
bsw/jbe@1309 63 local draft_content = initiative.current_draft.content
bsw/jbe@1309 64 if config.initiative_abstract then
bsw/jbe@1309 65 local abstract = string.match(draft_content, "(.+)<!%--END_OF_ABSTRACT%-->")
bsw/jbe@1309 66 if abstract then
bsw/jbe@1309 67 slot.put(abstract)
bsw/jbe@1309 68 end
bsw/jbe@1309 69 end
bsw/jbe@1309 70 if not config.voting_only then
bsw/jbe@1309 71 if app.session:has_access("authors_pseudonymous") then
bsw/jbe@1309 72 local initiator_members = initiative:get_reference_selector("initiating_members")
bsw/jbe@1309 73 :add_field("initiator.accepted", "accepted")
bsw/jbe@1309 74 :add_order_by("member.name")
bsw/jbe@1309 75 :add_where("initiator.accepted")
bsw/jbe@1309 76 :exec()
bsw/jbe@1309 77
bsw/jbe@1309 78 local initiators = {}
bsw/jbe@1309 79 for i, member in ipairs(initiator_members) do
bsw/jbe@1309 80 if member.accepted then
bsw/jbe@1309 81 initiators[#initiators+1] = member.name
bsw/jbe@1309 82 end
bsw@862 83 end
bsw/jbe@1309 84 ui.tag{ content = _"by" }
bsw/jbe@1309 85 slot.put(" ")
bsw/jbe@1309 86 ui.tag{ content = table.concat(initiators, ", ") }
bsw/jbe@1309 87 slot.put("<br />")
bsw@556 88 end
bsw@551 89 end
bsw/jbe@1309 90 if initiative.rank ~= 1 and (issue.voter_count == nil or issue.voter_count > 0) and not for_event then
bsw/jbe@1309 91 if not config.voting_only or issue.closed then
bsw/jbe@1309 92 execute.view {
bsw/jbe@1309 93 module = "initiative", view = "_bargraph", params = {
bsw/jbe@1309 94 initiative = initiative,
bsw/jbe@1309 95 battled_initiative = issue.initiatives[1]
bsw/jbe@1309 96 }
bsw/jbe@1309 97 }
bsw/jbe@1309 98
bsw/jbe@1309 99 slot.put(" &nbsp; ")
bsw/jbe@1309 100
bsw/jbe@1309 101 ui.supporter_count(initiative)
bsw/jbe@1309 102 end
bsw/jbe@1309 103 end
bsw/jbe@1309 104
bsw/jbe@1309 105 if initiative.positive_votes ~= nil then
bsw/jbe@1309 106
bsw/jbe@1309 107 local result_text
bsw/jbe@1309 108
bsw/jbe@1309 109 if issue.voter_count == 0 then
bsw/jbe@1309 110 result_text = _("No votes (0)", { result = result })
bsw/jbe@1309 111
bsw/jbe@1309 112 elseif initiative.rank == 1 and not for_event then
bsw/jbe@1309 113 local result = ""
bsw/jbe@1309 114 if initiative.eligible then
bsw/jbe@1309 115 result = _("Reached #{sign}#{num}/#{den}", {
bsw/jbe@1309 116 sign = issue.policy.direct_majority_strict and ">" or "≥",
bsw/jbe@1309 117 num = issue.policy.direct_majority_num,
bsw/jbe@1309 118 den = issue.policy.direct_majority_den
bsw/jbe@1309 119 })
bsw/jbe@1309 120 else
bsw/jbe@1309 121 result = _("Failed #{sign}#{num}/#{den}", {
bsw/jbe@1309 122 sign = issue.policy.direct_majority_strict and ">" or "≥",
bsw/jbe@1309 123 num = issue.policy.direct_majority_num,
bsw/jbe@1309 124 den = issue.policy.direct_majority_den
bsw/jbe@1309 125 })
bsw/jbe@1309 126 end
bsw/jbe@1309 127 local neutral_count = issue.voter_count - initiative.positive_votes - initiative.negative_votes
bsw/jbe@1309 128
bsw/jbe@1309 129 result_text = _("#{result}: #{yes_count} Yes (#{yes_percent}), #{no_count} No (#{no_percent}), #{neutral_count} Abstention (#{neutral_percent})", {
bsw/jbe@1309 130 result = result,
bsw/jbe@1309 131 yes_count = initiative.positive_votes,
bsw/jbe@1309 132 yes_percent = format.percent_floor(initiative.positive_votes, issue.voter_count),
bsw/jbe@1309 133 neutral_count = neutral_count,
bsw/jbe@1309 134 neutral_percent = format.percent_floor(neutral_count, issue.voter_count),
bsw/jbe@1309 135 no_count = initiative.negative_votes,
bsw/jbe@1309 136 no_percent = format.percent_floor(initiative.negative_votes, issue.voter_count)
bsw/jbe@1309 137 })
bsw/jbe@1309 138
bsw/jbe@1309 139 end
bsw/jbe@1309 140
bsw/jbe@1309 141 ui.container { attr = { class = "result" }, content = result_text }
bsw/jbe@1309 142
bsw/jbe@1309 143 end
bsw/jbe@1309 144
bsw/jbe@1309 145 end }
bsw@556 146 end
bsw@1045 147 }
bsw@1045 148
bsw@1665 149 if config.attachments and config.attachments.preview_in_listing then
bsw@1665 150
bsw@1665 151 local file = File:new_selector()
bsw@1665 152 :left_join("draft_attachment", nil, "draft_attachment.file_id = file.id")
bsw@1665 153 :add_where{ "draft_attachment.draft_id = ?", initiative.current_draft.id }
bsw@1665 154 :reset_fields()
bsw@1665 155 :add_field("file.id")
bsw@1665 156 :add_field("draft_attachment.title")
bsw@1665 157 :add_field("draft_attachment.description")
bsw@1665 158 :add_order_by("draft_attachment.id")
bsw@1665 159 :limit(1)
bsw@1665 160 :optional_object_mode()
bsw@1665 161 :exec()
bsw@1665 162
bsw@1665 163 if file then
bsw@1665 164 ui.image{ attr = { class = "attachment" }, module = "file", view = "show.jpg", id = file.id, params = { preview = true } }
bsw@1665 165 end
bsw@1665 166 end
bsw@1665 167
bsw@1665 168

Impressum / About Us