liquid_feedback_frontend

diff app/main/index/index.lua @ 10:72c5e0ee7c98

Version beta6

Bugfixes:
- Security fix: Every user was able to change the discussion URL of an initiative
- Creation of new issues in areas without default policies is now possible
- Members can now be sorted in different ways
- No error when trying to compare a draft with itself
- Added missing local statement to variable initialization in app/main/delegation/new.lua
- CSS flaw in initiative action bar fixed

New features:
- Possiblity to invite other users to become initiator
- Revokation of initiatives implemented
- Number of suggestions, supporters, etc. is shown on corresponding tabs of initiative view
- Members can now be sorted by account creation (default sorting is "newest first")
- Configuration option to create an automatic discussion link for all issues
- First draft of global timeline feature (not accessible via link yet)
- Custom stylesheet URL for users marked as developers

In area listing the number of closed issues is shown too

Renamed "author" field of initiative to "last author"

Removed wrongly included file app/main/member/_show_thumb.lua.orig in the distribution

Help texts updated
author bsw
date Sun Jan 10 12:00:00 2010 +0100 (2010-01-10)
parents 0ee1e0c42d4c
children a3ac899559de
line diff
     1.1 --- a/app/main/index/index.lua	Mon Jan 04 12:00:00 2010 +0100
     1.2 +++ b/app/main/index/index.lua	Sun Jan 10 12:00:00 2010 +0100
     1.3 @@ -1,12 +1,14 @@
     1.4  slot.select("title", function()
     1.5 -  execute.view{
     1.6 -    module = "member_image",
     1.7 -    view = "_show",
     1.8 -    params = {
     1.9 -      member = app.session.member, 
    1.10 -      image_type = "avatar"
    1.11 +  if app.session.member then
    1.12 +    execute.view{
    1.13 +      module = "member_image",
    1.14 +      view = "_show",
    1.15 +      params = {
    1.16 +        member = app.session.member,
    1.17 +        image_type = "avatar"
    1.18 +      }
    1.19      }
    1.20 -  }
    1.21 +  end
    1.22  end)
    1.23  
    1.24  slot.select("title", function()
    1.25 @@ -43,48 +45,50 @@
    1.26  
    1.27  slot.select("actions", function()
    1.28  
    1.29 -  ui.link{
    1.30 -    content = function()
    1.31 -        ui.image{ static = "icons/16/application_form.png" }
    1.32 -        slot.put(_"Edit my profile")
    1.33 -    end,
    1.34 -    module = "member",
    1.35 -    view = "edit"
    1.36 -  }
    1.37 -
    1.38 -  ui.link{
    1.39 -    content = function()
    1.40 -        ui.image{ static = "icons/16/user_gray.png" }
    1.41 -        slot.put(_"Upload images")
    1.42 -    end,
    1.43 -    module = "member",
    1.44 -    view = "edit_images"
    1.45 -  }
    1.46 -
    1.47 -  execute.view{
    1.48 -    module = "delegation",
    1.49 -    view = "_show_box"
    1.50 -  }
    1.51 -
    1.52 -  ui.link{
    1.53 -    content = function()
    1.54 -        ui.image{ static = "icons/16/wrench.png" }
    1.55 -        slot.put(_"Settings")
    1.56 -    end,
    1.57 -    module = "member",
    1.58 -    view = "settings"
    1.59 -  }
    1.60 -
    1.61 -  if config.download_dir then
    1.62 +  if app.session.member then
    1.63 +    ui.link{
    1.64 +      content = function()
    1.65 +          ui.image{ static = "icons/16/application_form.png" }
    1.66 +          slot.put(_"Edit my profile")
    1.67 +      end,
    1.68 +      module = "member",
    1.69 +      view = "edit"
    1.70 +    }
    1.71 +  
    1.72      ui.link{
    1.73        content = function()
    1.74 -          ui.image{ static = "icons/16/database_save.png" }
    1.75 -          slot.put(_"Download")
    1.76 +          ui.image{ static = "icons/16/user_gray.png" }
    1.77 +          slot.put(_"Upload images")
    1.78        end,
    1.79 -      module = "index",
    1.80 -      view = "download"
    1.81 +      module = "member",
    1.82 +      view = "edit_images"
    1.83 +    }
    1.84 +  
    1.85 +    execute.view{
    1.86 +      module = "delegation",
    1.87 +      view = "_show_box"
    1.88      }
    1.89 -  end 
    1.90 +  
    1.91 +    ui.link{
    1.92 +      content = function()
    1.93 +          ui.image{ static = "icons/16/wrench.png" }
    1.94 +          slot.put(_"Settings")
    1.95 +      end,
    1.96 +      module = "member",
    1.97 +      view = "settings"
    1.98 +    }
    1.99 +  
   1.100 +    if config.download_dir then
   1.101 +      ui.link{
   1.102 +        content = function()
   1.103 +            ui.image{ static = "icons/16/database_save.png" }
   1.104 +            slot.put(_"Download")
   1.105 +        end,
   1.106 +        module = "index",
   1.107 +        view = "download"
   1.108 +      }
   1.109 +    end 
   1.110 +  end
   1.111  end)
   1.112  
   1.113  local lang = locale.get("lang")
   1.114 @@ -106,24 +110,25 @@
   1.115  
   1.116  util.help("index.index", _"Home")
   1.117  
   1.118 -
   1.119 -local selector = Area:new_selector()
   1.120 -  :reset_fields()
   1.121 -  :add_field("area.id", nil, { "grouped" })
   1.122 -  :add_field("area.name", nil, { "grouped" })
   1.123 -  :add_field("membership.member_id NOTNULL", "is_member", { "grouped" })
   1.124 -  :add_field("count(issue.id)", "issues_to_vote_count")
   1.125 -  :add_field("count(interest.member_id)", "interested_issues_to_vote_count")
   1.126 -  :join("issue", nil, "issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed ISNULL")
   1.127 -  :left_join("direct_voter", nil, { "direct_voter.issue_id = issue.id AND direct_voter.member_id = ?", app.session.member.id })
   1.128 -  :add_where{ "direct_voter.member_id ISNULL" }
   1.129 -  :left_join("interest", nil, { "interest.issue_id = issue.id AND interest.member_id = ?", app.session.member.id })
   1.130 -  :left_join("membership", nil, { "membership.area_id = area.id AND membership.member_id = ? ", app.session.member.id })
   1.131 -
   1.132  local areas = {}
   1.133 -for i, area in ipairs(selector:exec()) do
   1.134 -  if area.is_member or area.interested_issues_to_vote_count > 0 then
   1.135 -    areas[#areas+1] = area
   1.136 +if app.session.member then
   1.137 +  local selector = Area:new_selector()
   1.138 +    :reset_fields()
   1.139 +    :add_field("area.id", nil, { "grouped" })
   1.140 +    :add_field("area.name", nil, { "grouped" })
   1.141 +    :add_field("membership.member_id NOTNULL", "is_member", { "grouped" })
   1.142 +    :add_field("count(issue.id)", "issues_to_vote_count")
   1.143 +    :add_field("count(interest.member_id)", "interested_issues_to_vote_count")
   1.144 +    :join("issue", nil, "issue.area_id = area.id AND issue.fully_frozen NOTNULL AND issue.closed ISNULL")
   1.145 +    :left_join("direct_voter", nil, { "direct_voter.issue_id = issue.id AND direct_voter.member_id = ?", app.session.member.id })
   1.146 +    :add_where{ "direct_voter.member_id ISNULL" }
   1.147 +    :left_join("interest", nil, { "interest.issue_id = issue.id AND interest.member_id = ?", app.session.member.id })
   1.148 +    :left_join("membership", nil, { "membership.area_id = area.id AND membership.member_id = ? ", app.session.member.id })
   1.149 +  
   1.150 +  for i, area in ipairs(selector:exec()) do
   1.151 +    if area.is_member or area.interested_issues_to_vote_count > 0 then
   1.152 +      areas[#areas+1] = area
   1.153 +    end
   1.154    end
   1.155  end
   1.156  
   1.157 @@ -190,9 +195,27 @@
   1.158    }
   1.159  end
   1.160  
   1.161 -execute.view{
   1.162 -  module = "member",
   1.163 -  view = "_show",
   1.164 -  params = { member = app.session.member }
   1.165 -}
   1.166 +local initiatives_selector = Initiative:new_selector()
   1.167 +  :join("initiator", nil, { "initiator.initiative_id = initiative.id AND initiator.member_id = ? AND initiator.accepted ISNULL", app.session.member.id })
   1.168 +
   1.169 +if initiatives_selector:count() > 0 then
   1.170 +  ui.container{
   1.171 +    attr = { style = "font-weight: bold;" },
   1.172 +    content = _"Initiatives that invited you to become initiator:"
   1.173 +  }
   1.174  
   1.175 +  execute.view{
   1.176 +    module = "initiative",
   1.177 +    view = "_list",
   1.178 +    params = { initiatives_selector = initiatives_selector }
   1.179 +  }
   1.180 +end
   1.181 +
   1.182 +
   1.183 +if app.session.member then
   1.184 +  execute.view{
   1.185 +    module = "member",
   1.186 +    view = "_show",
   1.187 +    params = { member = app.session.member }
   1.188 +  }
   1.189 +end

Impressum / About Us