Refactor instance method 'ordered_modules' to scope

This commit is contained in:
Urban Rotnik 2019-01-07 15:48:26 +01:00
parent 457e9990c5
commit 686f10cbd0
4 changed files with 7 additions and 10 deletions

View file

@ -74,6 +74,7 @@ class MyModule < ApplicationRecord
Time.current.utc,
Time.current.utc + 1.day)
end)
scope :workflow_ordered, -> { order(workflow_order: :asc) }
# A module takes this much space in canvas (x, y) in database
WIDTH = 30

View file

@ -10,10 +10,6 @@ class MyModuleGroup < ApplicationRecord
optional: true
has_many :my_modules, inverse_of: :my_module_group, dependent: :nullify
def ordered_modules
my_modules.order(workflow_order: :asc)
end
def deep_clone_to_experiment(current_user, experiment)
clone = MyModuleGroup.new(
created_by: created_by,
@ -21,12 +17,12 @@ class MyModuleGroup < ApplicationRecord
)
# Get clones of modules from this group, save them as hash
cloned_modules = ordered_modules.each_with_object({}) do |m, hash|
hash[m.id] = m.deep_clone_to_experiment(current_user, experiment)
hash
cloned_modules = my_modules.workflow_ordered.each_with_object({}) do |m, h|
h[m.id] = m.deep_clone_to_experiment(current_user, experiment)
h
end
ordered_modules.each do |m|
my_modules.workflow_ordered.each do |m|
# Copy connections
m.inputs.each do |inp|
Connection.create(

View file

@ -13,7 +13,7 @@
<% experiment.my_module_groups.each do |my_module_group| %>
<% if my_module_group.my_modules.exists? then %>
<% my_module_group.ordered_modules.each do |my_module| %>
<% my_module_group.my_modules.workflow_ordered.each do |my_module| %>
<li>
<%= form.check_box "modules[#{my_module.id}]", label: my_module.name %>
</li>

View file

@ -19,7 +19,7 @@
<% experiment.my_module_groups.each do |my_module_group| %>
<% next unless my_module_group.my_modules.is_archived(false).exists? %>
<% my_module_group.ordered_modules.is_archived(false).each do |my_module| %>
<% my_module_group.my_modules.workflow_ordered.is_archived(false).each do |my_module| %>
<li>
<%= form.check_box "modules[#{my_module.id}]", label: my_module.name %>
</li>