Add description field to administrator users like evaluators description
This commit is contained in:
@@ -28,4 +28,22 @@ class Admin::AdministratorsController < Admin::BaseController
|
||||
|
||||
redirect_to admin_administrators_path
|
||||
end
|
||||
|
||||
def edit
|
||||
end
|
||||
|
||||
def update
|
||||
if @administrator.update(update_administrator_params)
|
||||
notice = t("admin.administrators.form.updated")
|
||||
redirect_to admin_administrators_path, notice: notice
|
||||
else
|
||||
render :edit
|
||||
end
|
||||
end
|
||||
|
||||
private
|
||||
|
||||
def update_administrator_params
|
||||
params.require(:administrator).permit(:description)
|
||||
end
|
||||
end
|
||||
|
||||
@@ -77,7 +77,9 @@ module AdminHelper
|
||||
end
|
||||
|
||||
def admin_select_options
|
||||
Administrator.all.order("users.username asc").includes(:user).collect { |v| [ v.name, v.id ] }
|
||||
Administrator.with_user
|
||||
.collect { |v| [ v.description_or_name, v.id ] }
|
||||
.sort_by { |a| a[0] }
|
||||
end
|
||||
|
||||
def admin_submit_action(resource)
|
||||
|
||||
@@ -51,7 +51,7 @@ module Abilities
|
||||
can :comment_as_administrator, [Debate, Comment, Proposal, Poll::Question, Budget::Investment,
|
||||
Legislation::Question, Legislation::Proposal, Legislation::Annotation, Topic]
|
||||
|
||||
can [:search, :create, :index, :destroy], ::Administrator
|
||||
can [:search, :create, :index, :destroy, :edit, :update], ::Administrator
|
||||
can [:search, :create, :index, :destroy], ::Moderator
|
||||
can [:search, :show, :edit, :update, :create, :index, :destroy, :summary], ::Valuator
|
||||
can [:search, :create, :index, :destroy], ::Manager
|
||||
|
||||
@@ -3,4 +3,14 @@ class Administrator < ApplicationRecord
|
||||
delegate :name, :email, :name_and_email, to: :user
|
||||
|
||||
validates :user_id, presence: true, uniqueness: true
|
||||
|
||||
scope :with_user, -> { includes(:user) }
|
||||
|
||||
def description_or_name
|
||||
description.presence || name
|
||||
end
|
||||
|
||||
def description_or_name_and_email
|
||||
"#{description_or_name} (#{email})"
|
||||
end
|
||||
end
|
||||
|
||||
15
app/views/admin/administrators/edit.html.erb
Normal file
15
app/views/admin/administrators/edit.html.erb
Normal file
@@ -0,0 +1,15 @@
|
||||
<%= back_link_to admin_administrators_path %>
|
||||
|
||||
<h2><%= t("admin.administrators.form.edit_title") %></h2>
|
||||
|
||||
<div class="callout highlight">
|
||||
<strong><%= @administrator.name %></strong><br>
|
||||
<%= @administrator.email %>
|
||||
</div>
|
||||
|
||||
<div class="margin-top">
|
||||
<%= form_for [:admin, @administrator] do |f| %>
|
||||
<%= f.text_field :description %>
|
||||
<%= f.submit class: "button success" %>
|
||||
<% end %>
|
||||
</div>
|
||||
@@ -11,6 +11,7 @@
|
||||
<th scope="col" class="text-center"><%= t("admin.administrators.index.id") %></th>
|
||||
<th scope="col"><%= t("admin.administrators.index.name") %></th>
|
||||
<th scope="col"><%= t("admin.administrators.index.email") %></th>
|
||||
<th scope="col"><%= t("admin.administrators.index.description") %></th>
|
||||
<th scope="col" class="small-3"><%= t("admin.shared.actions") %></th>
|
||||
</thead>
|
||||
<% @administrators.each do |administrator| %>
|
||||
@@ -24,13 +25,18 @@
|
||||
<td>
|
||||
<%= administrator.email %>
|
||||
</td>
|
||||
<td>
|
||||
<%= administrator.description %>
|
||||
</td>
|
||||
<td>
|
||||
<% if administrator.persisted? %>
|
||||
<%= link_to t("admin.actions.edit"),
|
||||
edit_admin_administrator_path(administrator),
|
||||
class: "button hollow" %>
|
||||
<%= link_to t("admin.administrators.administrator.delete"),
|
||||
admin_administrator_path(administrator),
|
||||
method: :delete,
|
||||
class: "button hollow alert expanded"
|
||||
%>
|
||||
class: "button hollow alert" %>
|
||||
<% else %>
|
||||
<%= link_to t("admin.administrators.administrator.add"),
|
||||
{ controller: "admin/administrators", action: :create,
|
||||
|
||||
@@ -13,9 +13,9 @@
|
||||
</td>
|
||||
<td class="small">
|
||||
<% if investment.administrator.present? %>
|
||||
<span title="<%= t("admin.budget_investments.index.assigned_admin") %>">
|
||||
<%= investment.administrator.name %>
|
||||
</span>
|
||||
<span title="<%= t("admin.budget_investments.index.assigned_admin") %>">
|
||||
<%= investment.administrator.description_or_name %>
|
||||
</span>
|
||||
<% else %>
|
||||
<%= t("admin.budget_investments.index.no_admin_assigned") %>
|
||||
<% end %>
|
||||
|
||||
@@ -46,7 +46,7 @@
|
||||
|
||||
<div class="small-12 medium-6">
|
||||
<%= f.select(:administrator_id,
|
||||
@admins.collect{ |a| [a.name_and_email, a.id ] },
|
||||
@admins.collect{ |a| [a.description_or_name_and_email, a.id ] },
|
||||
{ include_blank: t("admin.budget_investments.edit.undefined") }) %>
|
||||
</div>
|
||||
</div>
|
||||
|
||||
@@ -728,6 +728,7 @@ en:
|
||||
title: Administrators
|
||||
name: Name
|
||||
email: Email
|
||||
description: Description
|
||||
id: Administrator ID
|
||||
no_administrators: There are no administrators.
|
||||
administrator:
|
||||
@@ -736,6 +737,9 @@ en:
|
||||
restricted_removal: "Sorry, you can't remove yourself from the administrators"
|
||||
search:
|
||||
title: "Administrators: User search"
|
||||
form:
|
||||
edit_title: "Edit administrator"
|
||||
updated: "Administrator updated successfully"
|
||||
moderators:
|
||||
index:
|
||||
title: Moderators
|
||||
|
||||
@@ -126,6 +126,8 @@ es:
|
||||
one: Enlace
|
||||
other: Enlaces
|
||||
attributes:
|
||||
administrator:
|
||||
description: Descripción
|
||||
budget:
|
||||
name: "Nombre"
|
||||
description_accepting: "Descripción durante la fase de presentación de proyectos"
|
||||
|
||||
@@ -727,6 +727,7 @@ es:
|
||||
title: Administradores
|
||||
name: Nombre
|
||||
email: Email
|
||||
description: Descripción
|
||||
id: ID de Administrador
|
||||
no_administrators: No hay administradores.
|
||||
administrator:
|
||||
@@ -735,6 +736,9 @@ es:
|
||||
restricted_removal: "Lo sentimos, no puedes eliminarte a ti mismo de la lista"
|
||||
search:
|
||||
title: "Administradores: Búsqueda de usuarios"
|
||||
form:
|
||||
edit_title: "Editar administrador"
|
||||
updated: "Administrador actualizado correctamente"
|
||||
moderators:
|
||||
index:
|
||||
title: Moderadores
|
||||
|
||||
@@ -106,7 +106,7 @@ namespace :admin do
|
||||
get :search, on: :collection
|
||||
end
|
||||
|
||||
resources :administrators, only: [:index, :create, :destroy] do
|
||||
resources :administrators, only: [:index, :create, :destroy, :edit, :update] do
|
||||
get :search, on: :collection
|
||||
end
|
||||
|
||||
|
||||
@@ -0,0 +1,5 @@
|
||||
class AddDescriptionToAdministrator < ActiveRecord::Migration
|
||||
def change
|
||||
add_column :administrators, :description, :string
|
||||
end
|
||||
end
|
||||
@@ -67,6 +67,7 @@ ActiveRecord::Schema.define(version: 20190429125842) do
|
||||
|
||||
create_table "administrators", force: :cascade do |t|
|
||||
t.integer "user_id"
|
||||
t.string "description"
|
||||
t.index ["user_id"], name: "index_administrators_on_user_id", using: :btree
|
||||
end
|
||||
|
||||
|
||||
@@ -3,7 +3,7 @@ require "rails_helper"
|
||||
describe "Admin administrators" do
|
||||
let!(:admin) { create(:administrator) }
|
||||
let!(:user) { create(:user, username: "Jose Luis Balbin") }
|
||||
let!(:user_administrator) { create(:administrator) }
|
||||
let!(:user_administrator) { create(:administrator, description: "admin_alias") }
|
||||
|
||||
before do
|
||||
login_as(admin.user)
|
||||
@@ -14,6 +14,7 @@ describe "Admin administrators" do
|
||||
expect(page).to have_content user_administrator.id
|
||||
expect(page).to have_content user_administrator.name
|
||||
expect(page).to have_content user_administrator.email
|
||||
expect(page).to have_content user_administrator.description
|
||||
expect(page).not_to have_content user.name
|
||||
end
|
||||
|
||||
@@ -100,4 +101,19 @@ describe "Admin administrators" do
|
||||
end
|
||||
end
|
||||
|
||||
context "Edit" do
|
||||
let!(:administrator1) { create(:administrator, user: create(:user,
|
||||
username: "Bernard Sumner",
|
||||
email: "bernard@sumner.com")) }
|
||||
|
||||
scenario "admin can edit administrator1" do
|
||||
visit(edit_admin_administrator_path(administrator1))
|
||||
fill_in "administrator_description", with: "Admin Alias"
|
||||
click_button "Update Administrator"
|
||||
|
||||
expect(page).to have_content("Administrator updated successfully")
|
||||
expect(page).to have_content("Admin Alias")
|
||||
end
|
||||
end
|
||||
|
||||
end
|
||||
|
||||
@@ -149,8 +149,9 @@ describe "Admin budget investments" do
|
||||
|
||||
scenario "Filtering by admin", :js do
|
||||
user = create(:user, username: "Admin 1")
|
||||
user2 = create(:user, username: "Admin 2")
|
||||
administrator = create(:administrator, user: user)
|
||||
|
||||
create(:administrator, user: user2, description: "Alias")
|
||||
create(:budget_investment, title: "Realocate visitors", budget: budget,
|
||||
administrator: administrator)
|
||||
create(:budget_investment, title: "Destroy the city", budget: budget)
|
||||
@@ -166,6 +167,13 @@ describe "Admin budget investments" do
|
||||
expect(page).not_to have_link("Destroy the city")
|
||||
expect(page).to have_link("Realocate visitors")
|
||||
|
||||
select "Alias", from: "administrator_id"
|
||||
click_button "Filter"
|
||||
|
||||
expect(page).to have_content("There are no investment projects")
|
||||
expect(page).not_to have_link("Destroy the city")
|
||||
expect(page).not_to have_link("Realocate visitors")
|
||||
|
||||
select "All administrators", from: "administrator_id"
|
||||
click_button "Filter"
|
||||
|
||||
@@ -1066,12 +1074,12 @@ describe "Admin budget investments" do
|
||||
scenario "Add administrator" do
|
||||
budget_investment = create(:budget_investment)
|
||||
user = create(:user, username: "Marta", email: "marta@admins.org")
|
||||
create(:administrator, user: user)
|
||||
create(:administrator, user: user, description: "Marta desc")
|
||||
|
||||
visit admin_budget_budget_investment_path(budget_investment.budget, budget_investment)
|
||||
click_link "Edit classification"
|
||||
|
||||
select "Marta (marta@admins.org)", from: "budget_investment[administrator_id]"
|
||||
select "Marta desc (marta@admins.org)", from: "budget_investment[administrator_id]"
|
||||
click_button "Update"
|
||||
|
||||
expect(page).to have_content "Investment project updated succesfully."
|
||||
|
||||
45
spec/models/administrator_spec.rb
Normal file
45
spec/models/administrator_spec.rb
Normal file
@@ -0,0 +1,45 @@
|
||||
require "rails_helper"
|
||||
|
||||
describe Administrator do
|
||||
|
||||
describe "#description_or_name" do
|
||||
let!(:user) { create(:user, username: "Billy Wilder" )}
|
||||
|
||||
it "returns description if present" do
|
||||
administrator = create(:administrator, user: user, description: "John Doe")
|
||||
|
||||
expect(administrator.description_or_name).to eq("John Doe")
|
||||
end
|
||||
|
||||
it "returns name if description is nil" do
|
||||
administrator = create(:administrator, user: user)
|
||||
|
||||
expect(administrator.description_or_name).to eq("Billy Wilder")
|
||||
end
|
||||
|
||||
it "returns name if description is blank" do
|
||||
administrator = create(:administrator, description: "")
|
||||
|
||||
expect(administrator.description_or_name).to eq(administrator.name)
|
||||
end
|
||||
end
|
||||
|
||||
describe "#description_or_name_and_email" do
|
||||
let!(:user) { create(:user, username: "Billy Wilder", email: "test@test.com")}
|
||||
|
||||
it "returns description and email if decription present" do
|
||||
administrator = create(:administrator,
|
||||
description: "John Doe",
|
||||
user: user)
|
||||
|
||||
expect(administrator.description_or_name_and_email).to eq("John Doe (test@test.com)")
|
||||
end
|
||||
|
||||
it "returns name and email if description is not present" do
|
||||
administrator = create(:administrator, user: user)
|
||||
|
||||
expect(administrator.description_or_name_and_email).to eq("Billy Wilder (test@test.com)")
|
||||
end
|
||||
end
|
||||
|
||||
end
|
||||
Reference in New Issue
Block a user