diff --git a/app/controllers/experiments_controller.rb b/app/controllers/experiments_controller.rb index 9b615494f..7ff2856af 100644 --- a/app/controllers/experiments_controller.rb +++ b/app/controllers/experiments_controller.rb @@ -20,6 +20,7 @@ class ExperimentsController < ApplicationController before_action :check_archive_permissions, only: :archive before_action :check_clone_permissions, only: %i(clone_modal clone) before_action :check_move_permissions, only: %i(move_modal move) + before_action :set_inline_name_editing, only: %i(canvas module_archive) layout 'fluid'.freeze @@ -311,6 +312,16 @@ class ExperimentsController < ApplicationController render_403 unless can_move_experiment?(@experiment) end + def set_inline_name_editing + return unless can_manage_experiment?(@experiment) + @inline_editable_title_config = { + name: 'title', + params_group: 'experiment', + field_to_udpate: 'name', + path_to_update: experiment_path(@experiment) + } + end + def experiment_annotation_notification(old_text = nil) smart_annotation_notification( old_text: old_text, diff --git a/app/controllers/my_modules_controller.rb b/app/controllers/my_modules_controller.rb index 38303ce10..ad876c878 100644 --- a/app/controllers/my_modules_controller.rb +++ b/app/controllers/my_modules_controller.rb @@ -39,6 +39,7 @@ class MyModulesController < ApplicationController unassign_repository_records assign_samples unassign_samples) + before_action :set_inline_name_editing, only: %i(protocols results activities repository archive) layout 'fluid'.freeze @@ -703,6 +704,16 @@ class MyModulesController < ApplicationController render_403 unless can_complete_module?(@my_module) end + def set_inline_name_editing + return unless can_manage_module?(@my_module) + @inline_editable_title_config = { + name: 'title', + params_group: 'my_module', + field_to_udpate: 'name', + path_to_update: my_module_path(@my_module) + } + end + def my_module_params params.require(:my_module).permit(:name, :description, :due_date, :archived) diff --git a/app/controllers/projects_controller.rb b/app/controllers/projects_controller.rb index f1b56d258..88c68fdf7 100644 --- a/app/controllers/projects_controller.rb +++ b/app/controllers/projects_controller.rb @@ -16,6 +16,7 @@ class ProjectsController < ApplicationController samples_index) before_action :check_create_permissions, only: %i(new create) before_action :check_manage_permissions, only: :edit + before_action :set_inline_name_editing, only: %i(show experiment_archive) # except parameter could be used but it is not working. layout 'fluid' @@ -339,6 +340,16 @@ class ProjectsController < ApplicationController render_403 unless can_manage_project?(@project) end + def set_inline_name_editing + return unless can_manage_project?(@project) + @inline_editable_title_config = { + name: 'title', + params_group: 'project', + field_to_udpate: 'name', + path_to_update: project_path(@project) + } + end + def log_activity(type_of, message_items = {}) message_items = { project: @project.id }.merge(message_items) diff --git a/app/views/experiments/canvas.html.erb b/app/views/experiments/canvas.html.erb index c50336b0b..2769de66f 100644 --- a/app/views/experiments/canvas.html.erb +++ b/app/views/experiments/canvas.html.erb @@ -1,15 +1,6 @@ <% provide(:head_title, t("experiments.canvas.head_title", project: h(@project.name)).html_safe) %> <%= render partial: "shared/sidebar", locals: { current_experiment: @experiment, page: 'canvas' } %> -<%= render partial: "shared/secondary_navigation" , locals: { - editable: { - name: 'title', - active: can_manage_experiment?(@experiment), - width: 'calc(100% - 500px)', - params_group: 'experiment', - field_to_udpate: 'name', - path_to_update: experiment_path(@experiment) - } -}%> +<%= render partial: "shared/secondary_navigation" %>