scinote-web/app/controllers/user_my_modules_controller.rb

144 lines
3.4 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
2016-02-12 23:52:43 +08:00
class UserMyModulesController < ApplicationController
include InputSanitizeHelper
2016-02-12 23:52:43 +08:00
before_action :load_vars
before_action :check_view_permissions, except: %i(create destroy)
before_action :check_manage_permissions, only: %i(create destroy)
2020-04-14 23:25:36 +08:00
def index_old
@user_my_modules = @my_module.user_my_modules
respond_to do |format|
2016-11-22 22:19:12 +08:00
format.json do
render json: {
html: render_to_string(
2020-04-14 23:25:36 +08:00
partial: 'index_old.html.erb'
),
my_module_id: @my_module.id,
counter: @my_module.designated_users.count # Used for counter badge
}
2016-11-22 22:19:12 +08:00
end
end
end
2016-02-12 23:52:43 +08:00
2020-04-14 23:25:36 +08:00
def index
respond_to do |format|
format.json do
render json: {
html: render_to_string(
2020-04-14 23:25:36 +08:00
partial: 'index.html.erb'
)
}
end
end
end
2016-02-12 23:52:43 +08:00
def index_edit
@user_my_modules = @my_module.user_my_modules
@undesignated_users = @my_module.undesignated_users.order(full_name: :asc)
2016-02-12 23:52:43 +08:00
@new_um = UserMyModule.new(my_module: @my_module)
respond_to do |format|
format.json do
render json: {
my_module: @my_module,
html: render_to_string(
partial: 'index_edit.html.erb'
)
2016-02-12 23:52:43 +08:00
}
end
2016-02-12 23:52:43 +08:00
end
end
def create
@um = UserMyModule.new(um_params.merge(my_module: @my_module))
@um.assigned_by = current_user
2016-02-12 23:52:43 +08:00
if @um.save
@um.log_activity(:designate_user_to_my_module, current_user)
2016-02-12 23:52:43 +08:00
respond_to do |format|
2017-12-20 20:39:35 +08:00
format.json do
render json: {
user: {
id: @um.user.id,
full_name: @um.user.full_name,
avatar_url: avatar_path(@um.user, :icon_small),
user_module_id: @um.id
}, status: :ok
}
2017-12-20 20:39:35 +08:00
end
2016-02-12 23:52:43 +08:00
end
else
respond_to do |format|
format.json do
render json: {
errors: @um.errors
}, status: :unprocessable_entity
end
2016-02-12 23:52:43 +08:00
end
end
end
def destroy
if @um.destroy
@um.log_activity(:undesignate_user_from_my_module, current_user)
2016-02-12 23:52:43 +08:00
respond_to do |format|
format.json do
render json: {}, status: :ok
end
2016-02-12 23:52:43 +08:00
end
else
respond_to do |format|
format.json do
render json: {
errors: @um.errors
}, status: :unprocessable_entity
end
2016-02-12 23:52:43 +08:00
end
end
end
def search
users = @my_module.users
.where.not(id: @my_module.designated_users.select(:id))
.search(false, params[:query])
.limit(Constants::SEARCH_LIMIT)
users = users.map do |user|
{
value: user.id,
label: sanitize_input(user.full_name),
params: { avatar_url: avatar_path(user, :icon_small) }
}
end
2016-02-12 23:52:43 +08:00
render json: users
end
2016-02-12 23:52:43 +08:00
private
2016-02-12 23:52:43 +08:00
def load_vars
@my_module = MyModule.find(params[:my_module_id])
@project = @my_module.experiment.project
@um = UserMyModule.find(params[:id]) if action_name == 'destroy'
rescue ActiveRecord::RecordNotFound
render_404
2016-02-12 23:52:43 +08:00
end
def check_view_permissions
render_403 unless can_read_my_module?(@my_module)
2016-02-12 23:52:43 +08:00
end
def check_manage_permissions
render_403 unless can_manage_my_module_designated_users?(@my_module)
2016-02-12 23:52:43 +08:00
end
def um_params
params.require(:user_my_module).permit(:user_id, :my_module_id)
end
end