summaryrefslogtreecommitdiff
path: root/app/services/design_management/move_designs_service.rb
diff options
context:
space:
mode:
authorGitLab Bot <gitlab-bot@gitlab.com>2020-08-11 03:11:00 +0000
committerGitLab Bot <gitlab-bot@gitlab.com>2020-08-11 03:11:00 +0000
commitbdca0979165cb662173d959c358fce0c539c7544 (patch)
tree5a2a58ea3738592da1d84a2ed53410deea752a51 /app/services/design_management/move_designs_service.rb
parent1a3d7fe0b65d92e322bfe33aebe6b64419203f4f (diff)
downloadgitlab-ce-bdca0979165cb662173d959c358fce0c539c7544.tar.gz
Add latest changes from gitlab-org/gitlab@master
Diffstat (limited to 'app/services/design_management/move_designs_service.rb')
-rw-r--r--app/services/design_management/move_designs_service.rb10
1 files changed, 9 insertions, 1 deletions
diff --git a/app/services/design_management/move_designs_service.rb b/app/services/design_management/move_designs_service.rb
index c490dc8f370..4052c189969 100644
--- a/app/services/design_management/move_designs_service.rb
+++ b/app/services/design_management/move_designs_service.rb
@@ -20,7 +20,9 @@ module DesignManagement
return error(:not_adjacent) if any_in_gap?
return error(:not_same_issue) unless all_same_issue?
+ move_nulls_to_end
current_design.move_between(previous_design, next_design)
+ current_design.save!
success
end
@@ -36,6 +38,12 @@ module DesignManagement
delegate :issue, :project, to: :current_design
+ def move_nulls_to_end
+ current_design.class.move_nulls_to_end(issue.designs)
+ next_design.reset if next_design && next_design.relative_position.nil?
+ previous_design.reset if previous_design && previous_design.relative_position.nil?
+ end
+
def neighbors
[previous_design, next_design].compact
end
@@ -45,7 +53,7 @@ module DesignManagement
end
def any_in_gap?
- return false unless previous_design && next_design
+ return false unless previous_design&.relative_position && next_design&.relative_position
!previous_design.immediately_before?(next_design)
end