diff options
author | Eric Davis <edavis@littlestreamsoftware.com> | 2010-10-08 15:39:39 +0000 |
---|---|---|
committer | Eric Davis <edavis@littlestreamsoftware.com> | 2010-10-08 15:39:39 +0000 |
commit | 4acd990ee2950a575a35b32bdfd8a75f04e958b0 (patch) | |
tree | 2bf8be13397290bfae82a5e3ea7b8126b5615875 /app/controllers | |
parent | 84ebd786d6eb20693f8ba93a04be93e279be0289 (diff) | |
download | redmine-4acd990ee2950a575a35b32bdfd8a75f04e958b0.tar.gz redmine-4acd990ee2950a575a35b32bdfd8a75f04e958b0.zip |
Refactor: extract TimelogController#create from TimelogController#edit
git-svn-id: svn+ssh://rubyforge.org/var/svn/redmine/trunk@4244 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/controllers')
-rw-r--r-- | app/controllers/timelog_controller.rb | 17 |
1 files changed, 16 insertions, 1 deletions
diff --git a/app/controllers/timelog_controller.rb b/app/controllers/timelog_controller.rb index d15ea6a54..b9f8724a0 100644 --- a/app/controllers/timelog_controller.rb +++ b/app/controllers/timelog_controller.rb @@ -17,7 +17,7 @@ class TimelogController < ApplicationController menu_item :issues - before_filter :find_project, :authorize, :only => [:new, :edit, :destroy] + before_filter :find_project, :authorize, :only => [:new, :create, :edit, :destroy] before_filter :find_optional_project, :only => [:index] verify :method => :post, :only => :destroy, :redirect_to => { :action => :index } @@ -93,6 +93,21 @@ class TimelogController < ApplicationController call_hook(:controller_timelog_edit_before_save, { :params => params, :time_entry => @time_entry }) render :action => 'edit' end + + verify :method => :post, :only => :create, :render => {:nothing => true, :status => :method_not_allowed } + def create + @time_entry ||= TimeEntry.new(:project => @project, :issue => @issue, :user => User.current, :spent_on => User.current.today) + @time_entry.attributes = params[:time_entry] + + call_hook(:controller_timelog_edit_before_save, { :params => params, :time_entry => @time_entry }) + + if @time_entry.save + flash[:notice] = l(:notice_successful_update) + redirect_back_or_default :action => 'index', :project_id => @time_entry.project + else + render :action => 'edit' + end + end def edit (render_403; return) if @time_entry && !@time_entry.editable_by?(User.current) |