diff --git a/app/services/boards/issues/move_service.rb b/app/services/boards/issues/move_service.rb
index 7455314450bbbf01a7f2517d0f7acfec12d0a67d..97fe099ccb5f59bde92e0050ddb26f5751102e81 100644
--- a/app/services/boards/issues/move_service.rb
+++ b/app/services/boards/issues/move_service.rb
@@ -6,36 +6,24 @@ module Boards
         return false unless valid_move?
 
         update_service.execute(issue)
-        reopen_service.execute(issue) if moving_from.done?
-        close_service.execute(issue)  if moving_to.done?
-
-        true
       end
 
       private
 
       def valid_move?
-        moving_from.present? && moving_to.present?
+        moving_from_list.present? && moving_to_list.present?
       end
 
       def issue
         @issue ||= project.issues.visible_to_user(user).find_by!(iid: params[:id])
       end
 
-      def moving_from
-        @moving_from ||= board.lists.find_by(id: params[:from_list_id])
-      end
-
-      def moving_to
-        @moving_to ||= board.lists.find_by(id: params[:to_list_id])
+      def moving_from_list
+        @moving_from_list ||= board.lists.find_by(id: params[:from_list_id])
       end
 
-      def close_service
-        ::Issues::CloseService.new(project, user)
-      end
-
-      def reopen_service
-        ::Issues::ReopenService.new(project, user)
+      def moving_to_list
+        @moving_to_list ||= board.lists.find_by(id: params[:to_list_id])
       end
 
       def update_service
@@ -45,18 +33,24 @@ module Boards
       def issue_params
         {
           add_label_ids: add_label_ids,
-          remove_label_ids: remove_label_ids
+          remove_label_ids: remove_label_ids,
+          state_event: issue_state
         }
       end
 
+      def issue_state
+        return 'reopen' if moving_from_list.done?
+        return 'close'  if moving_to_list.done?
+      end
+
       def add_label_ids
-        [moving_to.label_id].compact
+        [moving_to_list.label_id].compact
       end
 
       def remove_label_ids
         label_ids =
-          if moving_to.label?
-            moving_from.label_id
+          if moving_to_list.label?
+            moving_from_list.label_id
           else
             board.lists.label.pluck(:label_id)
           end