summaryrefslogtreecommitdiff
path: root/app/controllers/projects/todos_controller.rb
diff options
context:
space:
mode:
authorJames Lopez <james@jameslopez.es>2016-06-16 14:07:49 +0200
committerJames Lopez <james@jameslopez.es>2016-06-16 14:07:49 +0200
commit2a747d386dbdc05453fce6b8be3f483e8cd9e796 (patch)
tree5530f2fb8856c4e29a33afb128843108e2bb5834 /app/controllers/projects/todos_controller.rb
parent862b359b9a3f271b23f393932fb0e85d65c56c6b (diff)
parent778d72664f386dfee45dab171f137395739958f6 (diff)
downloadgitlab-ce-2a747d386dbdc05453fce6b8be3f483e8cd9e796.tar.gz
fixed merge conflicts
Diffstat (limited to 'app/controllers/projects/todos_controller.rb')
-rw-r--r--app/controllers/projects/todos_controller.rb31
1 files changed, 31 insertions, 0 deletions
diff --git a/app/controllers/projects/todos_controller.rb b/app/controllers/projects/todos_controller.rb
new file mode 100644
index 00000000000..a51bd5e2b49
--- /dev/null
+++ b/app/controllers/projects/todos_controller.rb
@@ -0,0 +1,31 @@
+class Projects::TodosController < Projects::ApplicationController
+ def create
+ todos = TodoService.new.mark_todo(issuable, current_user)
+
+ render json: {
+ todo: todos,
+ count: current_user.todos.pending.count,
+ }
+ end
+
+ def update
+ current_user.todos.find_by_id(params[:id]).update(state: :done)
+
+ render json: {
+ count: current_user.todos.pending.count,
+ }
+ end
+
+ private
+
+ def issuable
+ @issuable ||= begin
+ case params[:issuable_type]
+ when "issue"
+ @project.issues.find(params[:issuable_id])
+ when "merge_request"
+ @project.merge_requests.find(params[:issuable_id])
+ end
+ end
+ end
+end