scinote-web/app/controllers/my_modules_controller.rb

393 lines
9.9 KiB
Ruby

class MyModulesController < ApplicationController
include SampleActions
before_action :load_vars, only: [
:show, :edit, :update, :destroy,
:description, :due_date, :protocols, :results,
:samples, :activities, :activities_tab,
:assign_samples, :unassign_samples,
:delete_samples,
:samples_index, :archive]
before_action :load_markdown, only: [ :results ]
before_action :load_vars_nested, only: [:new, :create]
before_action :check_edit_permissions, only: [
:edit, :update, :description, :due_date
]
before_action :check_destroy_permissions, only: [:destroy]
before_action :check_view_info_permissions, only: [:show]
before_action :check_view_activities_permissions, only: [:activities, :activities_tab]
before_action :check_view_protocols_permissions, only: [:protocols]
before_action :check_view_results_permissions, only: [:results]
before_action :check_view_samples_permissions, only: [:samples, :samples_index]
before_action :check_view_archive_permissions, only: [:archive]
before_action :check_assign_samples_permissions, only: [:assign_samples]
before_action :check_unassign_samples_permissions, only: [:unassign_samples]
layout "fluid"
# Define submit actions constants (used in routing)
ASSIGN_SAMPLES = 'Assign'
UNASSIGN_SAMPLES = 'Unassign'
# Action defined in SampleActions
DELETE_SAMPLES = 'Delete'
def show
respond_to do |format|
format.html
format.json {
render :json => {
:html => render_to_string({
:partial => "show.html.erb"
})
}
}
end
end
# Description modal window in full-zoom canvas
def description
respond_to do |format|
format.html
format.json {
render json: {
html: render_to_string({
partial: "description.html.erb"
}),
title: t("my_modules.description.title", module: @my_module.name)
}
}
end
end
def activities
@last_activity_id = params[:from].to_i || 0
@per_page = 10
@activities = @my_module.last_activities(@last_activity_id, @per_page +1 )
@more_activities_url = ""
@overflown = @activities.length > @per_page
@activities = @my_module.last_activities(@last_activity_id, @per_page)
if @activities.count > 0
@more_activities_url = url_for(
controller: 'my_modules',
action: 'activities',
format: :json,
from: @activities.last.id)
end
respond_to do |format|
format.html
format.json {
# 'activites' partial includes header and form for adding older
# activities. 'list' partial is used for showing more activities.
partial = "activities.html.erb"
if @activities.last.id > 0
partial = "my_modules/activities/list_activities.html.erb"
end
render :json => {
:per_page => @per_page,
:results_number => @activities.length,
:more_url => @more_activities_url,
:html => render_to_string({
:partial => partial
})
}
}
end
end
# Different controller for showing activities inside tab
def activities_tab
@activities = @my_module.last_activities(1, @per_page)
respond_to do |format|
format.html
format.json {
render :json => {
:html => render_to_string({
:partial => "activities.html.erb"
})
}
}
end
end
# Due date modal window in full-zoom canvas
def due_date
respond_to do |format|
format.html
format.json {
render json: {
html: render_to_string({
partial: "due_date.html.erb"
}),
title: t("my_modules.due_date.title", module: @my_module.name)
}
}
end
end
def edit
session[:return_to] ||= request.referer
end
def update
@my_module.assign_attributes(my_module_params)
@my_module.last_modified_by = current_user
description_changed = @my_module.description_changed?
if @my_module.archived_changed?(from: false, to: true)
saved = @my_module.archive(current_user)
if saved
# Currently not in use
Activity.create(
type_of: :archive_module,
project: @my_module.experiment.project,
my_module: @my_module,
user: current_user,
message: t(
'activities.archive_module',
user: current_user.full_name,
module: @my_module.name
)
)
end
elsif @my_module.archived_changed?(from: true, to: false)
saved = @my_module.restore(current_user)
if saved
Activity.create(
type_of: :restore_module,
project: @my_module.experiment.project,
my_module: @my_module,
user: current_user,
message: t(
'activities.restore_module',
user: current_user.full_name,
module: @my_module.name
)
)
end
else
saved = @my_module.save
if saved and description_changed then
Activity.create(
type_of: :change_module_description,
project: @my_module.experiment.project,
my_module: @my_module,
user: current_user,
message: t(
"activities.change_module_description",
user: current_user.full_name,
module: @my_module.name
)
)
end
end
respond_to do |format|
if saved
format.html {
flash[:success] = t("my_modules.update.success_flash",
module: @my_module.name)
redirect_to(:back)
}
format.json {
alerts = []
alerts << "alert-red" if @my_module.is_overdue?
alerts << "alert-yellow" if @my_module.is_one_day_prior?
render json: {
status: :ok,
due_date_label: render_to_string(
partial: "my_modules/due_date_label.html.erb",
locals: { my_module: @my_module }
),
module_header_due_date_label: render_to_string(
partial: "my_modules/module_header_due_date_label.html.erb",
locals: { my_module: @my_module }
),
description_label: render_to_string(
partial: "my_modules/description_label.html.erb",
locals: { my_module: @my_module }
),
alerts: alerts
}
}
else
format.html {
render :edit
}
format.json {
render json: @my_module.errors,
status: :unprocessable_entity
}
end
end
end
def protocols
@protocol = @my_module.protocol
end
def results
end
def samples
@samples_index_link = samples_index_my_module_path(@my_module, format: :json)
@organization = @my_module.experiment.project.organization
end
def archive
@archived_results = @my_module.archived_results
end
# Submit actions
def assign_samples
if params[:sample_ids].present?
samples = []
params[:sample_ids].each do |id|
sample = Sample.find_by_id(id)
sample.last_modified_by = current_user
sample.save
if sample
samples << sample
end
end
@my_module.get_downstream_modules.each do |my_module|
new_samples = samples.select { |el| my_module.samples.exclude?(el) }
my_module.samples.push(*new_samples)
end
end
redirect_to samples_my_module_path(@my_module)
end
def unassign_samples
if params[:sample_ids].present?
samples = []
params[:sample_ids].each do |id|
sample = Sample.find_by_id(id)
sample.last_modified_by = current_user
sample.save
if sample
samples << sample
end
end
@my_module.get_downstream_modules.each do |my_module|
my_module.samples.destroy(samples & my_module.samples)
end
end
redirect_to samples_my_module_path(@my_module)
end
# AJAX actions
def samples_index
@organization = @my_module.experiment.project.organization
respond_to do |format|
format.html
format.json {
render json: ::SampleDatatable.new(view_context, @organization, nil, @my_module)
}
end
end
private
def load_vars
@direct_upload = ENV['PAPERCLIP_DIRECT_UPLOAD'] == "true"
@my_module = MyModule.find_by_id(params[:id])
if @my_module
@experiment = @my_module.experiment
@project = @my_module.experiment.project if @experiment
else
render_404
end
end
# Initialize markdown parser
def load_markdown
@markdown = Redcarpet::Markdown.new(
Redcarpet::Render::HTML.new(
filter_html: true,
no_images: true
)
)
end
def check_edit_permissions
unless can_edit_module(@my_module)
render_403
end
end
def check_destroy_permissions
unless can_archive_module(@my_module)
render_403
end
end
def check_view_info_permissions
unless can_view_module_info(@my_module)
render_403
end
end
def check_view_activities_permissions
unless can_view_module_activities(@my_module)
render_403
end
end
def check_view_protocols_permissions
unless can_view_module_protocols(@my_module)
render_403
end
end
def check_view_results_permissions
unless can_view_results_in_module(@my_module)
render_403
end
end
def check_view_samples_permissions
unless can_view_module_samples(@my_module)
render_403
end
end
def check_view_archive_permissions
unless can_view_module_archive(@my_module)
render_403
end
end
def check_assign_samples_permissions
unless can_add_samples_to_module(@my_module)
render_403
end
end
def check_unassign_samples_permissions
unless can_delete_samples_from_module(@my_module)
render_403
end
end
def my_module_params
params.require(:my_module).permit(:name, :description, :due_date,
:archived)
end
end