2011-10-09 00:36:38 +03:00
|
|
|
class NotesController < ApplicationController
|
2011-10-26 18:46:25 +05:00
|
|
|
before_filter :project
|
2011-10-09 00:36:38 +03:00
|
|
|
|
|
|
|
# Authorize
|
|
|
|
before_filter :add_project_abilities
|
2011-12-15 23:57:46 +02:00
|
|
|
|
|
|
|
before_filter :authorize_read_note!
|
2011-10-26 18:46:25 +05:00
|
|
|
before_filter :authorize_write_note!, :only => [:create]
|
2011-10-09 00:36:38 +03:00
|
|
|
|
|
|
|
respond_to :js
|
|
|
|
|
2012-02-24 09:16:06 +02:00
|
|
|
def index
|
2012-02-27 20:29:27 +02:00
|
|
|
notes
|
|
|
|
respond_with(@notes)
|
2012-02-24 09:16:06 +02:00
|
|
|
end
|
|
|
|
|
2011-10-09 00:36:38 +03:00
|
|
|
def create
|
|
|
|
@note = @project.notes.new(params[:note])
|
|
|
|
@note.author = current_user
|
2011-12-17 15:58:35 +02:00
|
|
|
@note.notify = true if params[:notify] == '1'
|
2011-12-24 17:28:20 +01:00
|
|
|
@note.notify_author = true if params[:notify_author] == '1'
|
2011-12-17 15:58:35 +02:00
|
|
|
@note.save
|
2011-10-09 00:36:38 +03:00
|
|
|
|
|
|
|
respond_to do |format|
|
|
|
|
format.html {redirect_to :back}
|
2011-10-26 18:46:25 +05:00
|
|
|
format.js
|
2011-10-09 00:36:38 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
def destroy
|
|
|
|
@note = @project.notes.find(params[:id])
|
2011-10-17 13:39:03 +03:00
|
|
|
return access_denied! unless can?(current_user, :admin_note, @note)
|
2011-10-09 00:36:38 +03:00
|
|
|
@note.destroy
|
|
|
|
|
|
|
|
respond_to do |format|
|
2011-10-26 18:46:25 +05:00
|
|
|
format.js { render :nothing => true }
|
2011-10-09 00:36:38 +03:00
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2012-02-24 09:16:06 +02:00
|
|
|
protected
|
|
|
|
|
2012-02-27 20:29:27 +02:00
|
|
|
def notes
|
2012-07-20 08:39:34 +03:00
|
|
|
@notes = NotesLoad.new(project, current_user, params).execute
|
2012-02-24 09:16:06 +02:00
|
|
|
end
|
2011-10-09 00:36:38 +03:00
|
|
|
end
|