scinote-web/app/controllers/user_my_modules_controller.rb

131 lines
3 KiB
Ruby
Raw Normal View History

2016-02-12 23:52:43 +08:00
class UserMyModulesController < ApplicationController
before_action :load_vars
before_action :check_view_permissions, only: :index
before_action :check_manage_permissions, only: %i(create index_edit destroy)
def index
@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(
partial: 'index.html.erb'
),
my_module_id: @my_module.id,
2017-05-09 16:18:57 +08:00
counter: @my_module.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
def index_edit
@user_my_modules = @my_module.user_my_modules
@unassigned_users = @my_module.unassigned_users
@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
if @um.save
log_activity(:assign_user_to_module)
2016-02-12 23:52:43 +08:00
respond_to do |format|
2017-12-20 20:39:35 +08:00
format.json do
redirect_to my_module_users_edit_path(format: :json),
turbolinks: false,
status: 303
end
2016-02-12 23:52:43 +08:00
end
else
respond_to do |format|
format.json do
render json: {
errors: @um.errors
2016-02-12 23:52:43 +08:00
}
end
2016-02-12 23:52:43 +08:00
end
end
end
def destroy
if @um.destroy
log_activity(:unassign_user_from_module)
2016-02-12 23:52:43 +08:00
respond_to do |format|
format.json do
redirect_to my_module_users_edit_path(format: :json),
turbolinks: false,
status: 303
end
2016-02-12 23:52:43 +08:00
end
else
respond_to do |format|
format.json do
render json: {
errors: @um.errors
2016-02-12 23:52:43 +08:00
}
end
2016-02-12 23:52:43 +08:00
end
end
end
private
def load_vars
@my_module = MyModule.find_by_id(params[:my_module_id])
if @my_module
2016-08-03 15:34:10 +08:00
@project = @my_module.experiment.project
2016-02-12 23:52:43 +08:00
else
render_404
end
if action_name == "destroy"
@um = UserMyModule.find_by_id(params[:id])
unless @um
render_404
end
end
end
def check_view_permissions
render_403 unless can_read_experiment?(@my_module.experiment)
2016-02-12 23:52:43 +08:00
end
def check_manage_permissions
render_403 unless can_manage_users_in_module?(@my_module)
2016-02-12 23:52:43 +08:00
end
def init_gui
@users = @my_module.unassigned_users
end
def um_params
params.require(:user_my_module).permit(:user_id, :my_module_id)
end
def log_activity(type_of)
Activities::CreateActivityService
.call(activity_type: type_of,
owner: current_user,
team: @um.my_module.experiment.project.team,
project: @um.my_module.experiment.project,
subject: @um.my_module,
message_items: { my_module: @my_module.id,
user_target: @um.user.id })
end
2016-02-12 23:52:43 +08:00
end