Fix conflics after rebase
This commit is contained in:
@@ -96,7 +96,7 @@ class Admin::BudgetInvestmentsController < Admin::BaseController
|
|||||||
def budget_investment_params
|
def budget_investment_params
|
||||||
params.require(:budget_investment)
|
params.require(:budget_investment)
|
||||||
.permit(:title, :description, :external_url, :heading_id, :administrator_id, :tag_list,
|
.permit(:title, :description, :external_url, :heading_id, :administrator_id, :tag_list,
|
||||||
:valuation_tag_list, :incompatible, :selected, valuator_ids: [],
|
:valuation_tag_list, :incompatible, :visible_to_valuators, :selected, valuator_ids: [],
|
||||||
valuator_group_ids: [])
|
valuator_group_ids: [])
|
||||||
end
|
end
|
||||||
|
|
||||||
|
|||||||
@@ -17,7 +17,7 @@ class Valuation::BudgetInvestmentsController < Valuation::BaseController
|
|||||||
def index
|
def index
|
||||||
@heading_filters = heading_filters
|
@heading_filters = heading_filters
|
||||||
@investments = if current_user.valuator? && @budget.present?
|
@investments = if current_user.valuator? && @budget.present?
|
||||||
@budget.investments.scoped_filter(params_for_current_valuator, @current_filter)
|
@budget.investments.visible_to_valuators.scoped_filter(params_for_current_valuator, @current_filter)
|
||||||
.order(cached_votes_up: :desc)
|
.order(cached_votes_up: :desc)
|
||||||
.page(params[:page])
|
.page(params[:page])
|
||||||
else
|
else
|
||||||
|
|||||||
@@ -65,6 +65,7 @@ class Budget
|
|||||||
scope :under_valuation, -> { valuation_open.valuating.where("administrator_id IS NOT ?", nil) }
|
scope :under_valuation, -> { valuation_open.valuating.where("administrator_id IS NOT ?", nil) }
|
||||||
scope :managed, -> { valuation_open.where(valuator_assignments_count: 0).where("administrator_id IS NOT ?", nil) }
|
scope :managed, -> { valuation_open.where(valuator_assignments_count: 0).where("administrator_id IS NOT ?", nil) }
|
||||||
scope :valuating, -> { valuation_open.where("valuator_assignments_count > 0 OR valuator_group_assignments_count > 0" ) }
|
scope :valuating, -> { valuation_open.where("valuator_assignments_count > 0 OR valuator_group_assignments_count > 0" ) }
|
||||||
|
scope :visible_to_valuators, -> { where(visible_to_valuators: true) }
|
||||||
scope :valuation_finished, -> { where(valuation_finished: true) }
|
scope :valuation_finished, -> { where(valuation_finished: true) }
|
||||||
scope :valuation_finished_feasible, -> { where(valuation_finished: true, feasibility: "feasible") }
|
scope :valuation_finished_feasible, -> { where(valuation_finished: true, feasibility: "feasible") }
|
||||||
scope :feasible, -> { where(feasibility: "feasible") }
|
scope :feasible, -> { where(feasibility: "feasible") }
|
||||||
|
|||||||
@@ -27,8 +27,13 @@
|
|||||||
<th><%= t("admin.budget_investments.index.table_geozone") %></th>
|
<th><%= t("admin.budget_investments.index.table_geozone") %></th>
|
||||||
<th><%= t("admin.budget_investments.index.table_feasibility") %></th>
|
<th><%= t("admin.budget_investments.index.table_feasibility") %></th>
|
||||||
<th class="text-center"><%= t("admin.budget_investments.index.table_valuation_finished") %></th>
|
<th class="text-center"><%= t("admin.budget_investments.index.table_valuation_finished") %></th>
|
||||||
<th class="text-center"><%= t("admin.budget_investments.index.table_selection") %></th>
|
<th class="text-center">
|
||||||
<% if params[:filter] == "selected" %>
|
<% if params[:filter] == "valuating" %>
|
||||||
|
<%= t("admin.budget_investments.index.table_evaluation") %>
|
||||||
|
<% else %>
|
||||||
|
<%= t("admin.budget_investments.index.table_selection") %>
|
||||||
|
<% end %>
|
||||||
|
</th>
|
||||||
<th class="text-center"><%= t("admin.budget_investments.index.table_incompatible") %></th>
|
<th class="text-center"><%= t("admin.budget_investments.index.table_incompatible") %></th>
|
||||||
<% end %>
|
<% end %>
|
||||||
</tr>
|
</tr>
|
||||||
@@ -76,7 +81,15 @@
|
|||||||
<td class="small text-center">
|
<td class="small text-center">
|
||||||
<%= investment.valuation_finished? ? t("shared.yes"): t("shared.no") %>
|
<%= investment.valuation_finished? ? t("shared.yes"): t("shared.no") %>
|
||||||
</td>
|
</td>
|
||||||
<td class="small">
|
<td class="small text-center">
|
||||||
|
<% if params[:filter] == "valuating" %>
|
||||||
|
<%= form_for [:admin, investment.budget, investment], remote: true do |f| %>
|
||||||
|
<%= f.check_box :visible_to_valuators,
|
||||||
|
label: false,
|
||||||
|
class: "js-submit-on-change",
|
||||||
|
id: "budget_investment_visible_to_valuators" %>
|
||||||
|
<% end %>
|
||||||
|
<% else %>
|
||||||
<% if investment.selected? %>
|
<% if investment.selected? %>
|
||||||
<%= link_to_unless investment.budget.finished?,
|
<%= link_to_unless investment.budget.finished?,
|
||||||
t("admin.budget_investments.index.selected"),
|
t("admin.budget_investments.index.selected"),
|
||||||
@@ -104,6 +117,7 @@
|
|||||||
remote: true,
|
remote: true,
|
||||||
class: "button small hollow expanded" %>
|
class: "button small hollow expanded" %>
|
||||||
<% end %>
|
<% end %>
|
||||||
|
<% end %>
|
||||||
</td>
|
</td>
|
||||||
<% if params[:filter] == "selected" %>
|
<% if params[:filter] == "selected" %>
|
||||||
<td class="small text-center">
|
<td class="small text-center">
|
||||||
|
|||||||
@@ -31,7 +31,7 @@
|
|||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
<% @investments.each do |investment| %>
|
<% @investments.each do |investment| %>
|
||||||
<tr id="<%= dom_id(investment) %>">
|
<tr id="<%= dom_id(investment) %>" class="budget_investment">
|
||||||
<td>
|
<td>
|
||||||
<strong><%= investment.id %></strong>
|
<strong><%= investment.id %></strong>
|
||||||
</td>
|
</td>
|
||||||
|
|||||||
@@ -186,6 +186,7 @@ en:
|
|||||||
table_feasibility: "Feasibility"
|
table_feasibility: "Feasibility"
|
||||||
table_valuation_finished: "Val. Fin."
|
table_valuation_finished: "Val. Fin."
|
||||||
table_selection: "Selected"
|
table_selection: "Selected"
|
||||||
|
table_evaluation: "Show to valuators"
|
||||||
table_incompatible: "Incompatible"
|
table_incompatible: "Incompatible"
|
||||||
show:
|
show:
|
||||||
assigned_admin: Assigned administrator
|
assigned_admin: Assigned administrator
|
||||||
|
|||||||
@@ -186,6 +186,7 @@ es:
|
|||||||
table_feasibility: "Viabilidad"
|
table_feasibility: "Viabilidad"
|
||||||
table_valuation_finished: "Ev. Fin."
|
table_valuation_finished: "Ev. Fin."
|
||||||
table_selection: "Seleccionado"
|
table_selection: "Seleccionado"
|
||||||
|
table_evaluation: "Mostrar a evaluadores"
|
||||||
table_incompatible: "Incompatible"
|
table_incompatible: "Incompatible"
|
||||||
show:
|
show:
|
||||||
assigned_admin: Administrador asignado
|
assigned_admin: Administrador asignado
|
||||||
|
|||||||
@@ -31,5 +31,11 @@ require_relative 'dev_seeds/communities'
|
|||||||
require_relative 'dev_seeds/legislation_processes'
|
require_relative 'dev_seeds/legislation_processes'
|
||||||
require_relative 'dev_seeds/newsletters'
|
require_relative 'dev_seeds/newsletters'
|
||||||
require_relative 'dev_seeds/notifications'
|
require_relative 'dev_seeds/notifications'
|
||||||
|
section "Marking investments as visible to valuators" do
|
||||||
|
(1..50).to_a.sample.times do
|
||||||
|
Budget::Investment.reorder("RANDOM()").first.update(visible_to_valuators: true)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
log "All dev seeds created successfuly 👍"
|
log "All dev seeds created successfuly 👍"
|
||||||
|
|||||||
@@ -0,0 +1,5 @@
|
|||||||
|
class AddVisibleToValuatorsToBudgetInvestment < ActiveRecord::Migration
|
||||||
|
def change
|
||||||
|
add_column :budget_investments, :visible_to_valuators, :boolean, default: false
|
||||||
|
end
|
||||||
|
end
|
||||||
@@ -163,6 +163,7 @@ ActiveRecord::Schema.define(version: 20180320104823) do
|
|||||||
t.boolean "incompatible", default: false
|
t.boolean "incompatible", default: false
|
||||||
t.integer "community_id"
|
t.integer "community_id"
|
||||||
t.integer "valuator_group_assignments_count", default: 0
|
t.integer "valuator_group_assignments_count", default: 0
|
||||||
|
t.boolean "visible_to_valuators", default: false
|
||||||
end
|
end
|
||||||
|
|
||||||
add_index "budget_investments", ["administrator_id"], name: "index_budget_investments_on_administrator_id", using: :btree
|
add_index "budget_investments", ["administrator_id"], name: "index_budget_investments_on_administrator_id", using: :btree
|
||||||
|
|||||||
@@ -342,6 +342,10 @@ FactoryBot.define do
|
|||||||
winner true
|
winner true
|
||||||
end
|
end
|
||||||
|
|
||||||
|
trait :visible_to_valuators do
|
||||||
|
visible_to_valuators true
|
||||||
|
end
|
||||||
|
|
||||||
trait :incompatible do
|
trait :incompatible do
|
||||||
selected
|
selected
|
||||||
incompatible true
|
incompatible true
|
||||||
|
|||||||
@@ -946,6 +946,94 @@ feature 'Admin budget investments' do
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
context "Mark as visible to valuators" do
|
||||||
|
let(:group) { create(:budget_group, budget: @budget) }
|
||||||
|
let(:heading) { create(:budget_heading, group: group) }
|
||||||
|
|
||||||
|
scenario "Mark as visible to valuator", :js do
|
||||||
|
valuator = create(:valuator)
|
||||||
|
|
||||||
|
investment1 = create(:budget_investment, heading: heading)
|
||||||
|
investment2 = create(:budget_investment, heading: heading)
|
||||||
|
|
||||||
|
investment1.valuators << valuator
|
||||||
|
investment2.valuators << valuator
|
||||||
|
|
||||||
|
visit admin_budget_budget_investments_path(@budget)
|
||||||
|
within('#filter-subnav') { click_link 'Under valuation' }
|
||||||
|
|
||||||
|
within("#budget_investment_#{investment1.id}") do
|
||||||
|
check "budget_investment_visible_to_valuators"
|
||||||
|
end
|
||||||
|
|
||||||
|
wait_for_ajax
|
||||||
|
|
||||||
|
login_as(valuator.user)
|
||||||
|
visit valuation_root_path
|
||||||
|
|
||||||
|
within "#budget_#{@budget.id}" do
|
||||||
|
click_link "Evaluate"
|
||||||
|
end
|
||||||
|
expect(page).to have_content investment1.title
|
||||||
|
expect(page).not_to have_content investment2.title
|
||||||
|
end
|
||||||
|
|
||||||
|
scenario "Unmark as visible to valuator", :js do
|
||||||
|
valuator = create(:valuator)
|
||||||
|
|
||||||
|
investment1 = create(:budget_investment, heading: heading, visible_to_valuators: true)
|
||||||
|
investment2 = create(:budget_investment, heading: heading, visible_to_valuators: true)
|
||||||
|
|
||||||
|
investment1.valuators << valuator
|
||||||
|
investment2.valuators << valuator
|
||||||
|
|
||||||
|
visit admin_budget_budget_investments_path(@budget)
|
||||||
|
within('#filter-subnav') { click_link 'Under valuation' }
|
||||||
|
|
||||||
|
within("#budget_investment_#{investment1.id}") do
|
||||||
|
uncheck "budget_investment_visible_to_valuators"
|
||||||
|
end
|
||||||
|
|
||||||
|
wait_for_ajax
|
||||||
|
|
||||||
|
login_as(valuator.user)
|
||||||
|
visit valuation_root_path
|
||||||
|
|
||||||
|
within "#budget_#{@budget.id}" do
|
||||||
|
click_link "Evaluate"
|
||||||
|
end
|
||||||
|
|
||||||
|
expect(page).not_to have_content investment1.title
|
||||||
|
expect(page).to have_content investment2.title
|
||||||
|
end
|
||||||
|
|
||||||
|
scenario "Showing the valuating checkbox" do
|
||||||
|
investment1 = create(:budget_investment, heading: heading, visible_to_valuators: true)
|
||||||
|
investment2 = create(:budget_investment, heading: heading, visible_to_valuators: false)
|
||||||
|
|
||||||
|
investment1.valuators << create(:valuator)
|
||||||
|
investment2.valuators << create(:valuator)
|
||||||
|
|
||||||
|
visit admin_budget_budget_investments_path(@budget)
|
||||||
|
within('#filter-subnav') { click_link 'All' }
|
||||||
|
|
||||||
|
expect(page).not_to have_css("#budget_investment_visible_to_valuators")
|
||||||
|
expect(page).not_to have_css("#budget_investment_visible_to_valuators")
|
||||||
|
|
||||||
|
within('#filter-subnav') { click_link 'Under valuation' }
|
||||||
|
|
||||||
|
within("#budget_investment_#{investment1.id}") do
|
||||||
|
valuating_checkbox = find("#budget_investment_visible_to_valuators")
|
||||||
|
expect(valuating_checkbox).to be_checked
|
||||||
|
end
|
||||||
|
|
||||||
|
within("#budget_investment_#{investment2.id}") do
|
||||||
|
valuating_checkbox = find("#budget_investment_visible_to_valuators")
|
||||||
|
expect(valuating_checkbox).not_to be_checked
|
||||||
|
end
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
context "Selecting csv" do
|
context "Selecting csv" do
|
||||||
|
|
||||||
scenario "Downloading CSV file" do
|
scenario "Downloading CSV file" do
|
||||||
|
|||||||
@@ -26,8 +26,8 @@ feature 'Valuation budget investments' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
scenario 'Index shows budget investments assigned to current valuator' do
|
scenario 'Index shows budget investments assigned to current valuator' do
|
||||||
investment1 = create(:budget_investment, budget: budget)
|
investment1 = create(:budget_investment, :visible_to_valuators, budget: budget)
|
||||||
investment2 = create(:budget_investment, budget: budget)
|
investment2 = create(:budget_investment, :visible_to_valuators, budget: budget)
|
||||||
|
|
||||||
investment1.valuators << valuator
|
investment1.valuators << valuator
|
||||||
|
|
||||||
@@ -38,8 +38,8 @@ feature 'Valuation budget investments' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
scenario 'Index shows no budget investment to admins no valuators' do
|
scenario 'Index shows no budget investment to admins no valuators' do
|
||||||
investment1 = create(:budget_investment, budget: budget)
|
investment1 = create(:budget_investment, :visible_to_valuators, budget: budget)
|
||||||
investment2 = create(:budget_investment, budget: budget)
|
investment2 = create(:budget_investment, :visible_to_valuators, budget: budget)
|
||||||
|
|
||||||
investment1.valuators << valuator
|
investment1.valuators << valuator
|
||||||
|
|
||||||
@@ -52,9 +52,9 @@ feature 'Valuation budget investments' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
scenario 'Index orders budget investments by votes' do
|
scenario 'Index orders budget investments by votes' do
|
||||||
investment10 = create(:budget_investment, budget: budget, cached_votes_up: 10)
|
investment10 = create(:budget_investment, :visible_to_valuators, budget: budget, cached_votes_up: 10)
|
||||||
investment100 = create(:budget_investment, budget: budget, cached_votes_up: 100)
|
investment100 = create(:budget_investment, :visible_to_valuators, budget: budget, cached_votes_up: 100)
|
||||||
investment1 = create(:budget_investment, budget: budget, cached_votes_up: 1)
|
investment1 = create(:budget_investment, :visible_to_valuators, budget: budget, cached_votes_up: 1)
|
||||||
|
|
||||||
investment1.valuators << valuator
|
investment1.valuators << valuator
|
||||||
investment10.valuators << valuator
|
investment10.valuators << valuator
|
||||||
@@ -66,6 +66,27 @@ feature 'Valuation budget investments' do
|
|||||||
expect(investment10.title).to appear_before(investment1.title)
|
expect(investment10.title).to appear_before(investment1.title)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
scenario 'Index displays investments paginated' do
|
||||||
|
per_page = Kaminari.config.default_per_page
|
||||||
|
(per_page + 2).times do
|
||||||
|
investment = create(:budget_investment, :visible_to_valuators, budget: @budget)
|
||||||
|
investment.valuators << @valuator
|
||||||
|
end
|
||||||
|
|
||||||
|
visit valuation_budget_budget_investments_path(@budget)
|
||||||
|
|
||||||
|
expect(page).to have_css('.budget_investment', count: per_page)
|
||||||
|
|
||||||
|
within("ul.pagination") do
|
||||||
|
expect(page).to have_content("1")
|
||||||
|
expect(page).to have_content("2")
|
||||||
|
expect(page).not_to have_content("3")
|
||||||
|
click_link "Next", exact: false
|
||||||
|
end
|
||||||
|
|
||||||
|
expect(page).to have_css('.budget_investment', count: 2)
|
||||||
|
end
|
||||||
|
|
||||||
scenario "Index filtering by heading", :js do
|
scenario "Index filtering by heading", :js do
|
||||||
group = create(:budget_group, budget: budget)
|
group = create(:budget_group, budget: budget)
|
||||||
valuating_heading = create(:budget_heading, name: "Only Valuating", group: group)
|
valuating_heading = create(:budget_heading, name: "Only Valuating", group: group)
|
||||||
@@ -91,6 +112,14 @@ feature 'Valuation budget investments' do
|
|||||||
group: group,
|
group: group,
|
||||||
budget: budget,
|
budget: budget,
|
||||||
valuators: [valuator])
|
valuators: [valuator])
|
||||||
|
# heading1 = create(:budget_heading, name: "District 9", group: group)
|
||||||
|
# heading2 = create(:budget_heading, name: "Down to the river", group: group)
|
||||||
|
# investment1 = create(:budget_investment, :visible_to_valuators, title: "Realocate visitors",
|
||||||
|
# heading: heading1, group: group, budget: budget)
|
||||||
|
# investment2 = create(:budget_investment, :visible_to_valuators, title: "Destroy the city",
|
||||||
|
# heading: heading2, group: group, budget: budget)
|
||||||
|
investment1.valuators << valuator
|
||||||
|
investment2.valuators << valuator
|
||||||
|
|
||||||
visit valuation_budget_budget_investments_path(budget)
|
visit valuation_budget_budget_investments_path(budget)
|
||||||
|
|
||||||
@@ -162,9 +191,10 @@ feature 'Valuation budget investments' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
scenario "Index filtering by valuation status" do
|
scenario "Index filtering by valuation status" do
|
||||||
valuating = create(:budget_investment, budget: budget, title: "Ongoing valuation")
|
valuating = create(:budget_investment, :visible_to_valuators,
|
||||||
valuated = create(:budget_investment, budget: budget, title: "Old idea",
|
budget: budget, title: "Ongoing valuation")
|
||||||
valuation_finished: true)
|
valuated = create(:budget_investment, :visible_to_valuators,
|
||||||
|
budget: budget, title: "Old idea", valuation_finished: true)
|
||||||
valuating.valuators << valuator
|
valuating.valuators << valuator
|
||||||
valuated.valuators << valuator
|
valuated.valuators << valuator
|
||||||
|
|
||||||
@@ -194,7 +224,7 @@ feature 'Valuation budget investments' do
|
|||||||
let(:investment) do
|
let(:investment) do
|
||||||
create(:budget_investment, budget: budget, price: 1234, feasibility: 'unfeasible',
|
create(:budget_investment, budget: budget, price: 1234, feasibility: 'unfeasible',
|
||||||
unfeasibility_explanation: 'It is impossible',
|
unfeasibility_explanation: 'It is impossible',
|
||||||
administrator: administrator)
|
administrator: administrator,)
|
||||||
end
|
end
|
||||||
|
|
||||||
background do
|
background do
|
||||||
@@ -202,8 +232,10 @@ feature 'Valuation budget investments' do
|
|||||||
end
|
end
|
||||||
|
|
||||||
scenario 'visible for assigned valuators' do
|
scenario 'visible for assigned valuators' do
|
||||||
|
investment.update(visible_to_valuators: true)
|
||||||
visit valuation_budget_budget_investments_path(budget)
|
visit valuation_budget_budget_investments_path(budget)
|
||||||
|
|
||||||
|
|
||||||
click_link investment.title
|
click_link investment.title
|
||||||
|
|
||||||
expect(page).to have_content(investment.title)
|
expect(page).to have_content(investment.title)
|
||||||
|
|||||||
@@ -362,6 +362,12 @@ module CommonActions
|
|||||||
fill_in "newsletter_from", with: (options[:from] || "no-reply@consul.dev")
|
fill_in "newsletter_from", with: (options[:from] || "no-reply@consul.dev")
|
||||||
fill_in "newsletter_body", with: (options[:body] || "This is a different body")
|
fill_in "newsletter_body", with: (options[:body] || "This is a different body")
|
||||||
end
|
end
|
||||||
|
def wait_for_ajax
|
||||||
|
Timeout.timeout(Capybara.default_max_wait_time) do
|
||||||
|
loop until page.evaluate_script('jQuery.active').zero?
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
|
||||||
def click_notifications_icon
|
def click_notifications_icon
|
||||||
find("#notifications a").click
|
find("#notifications a").click
|
||||||
|
|||||||
Reference in New Issue
Block a user