@@ -17,7 +17,7 | |||||
17 |
|
17 | |||
18 | class TimelogController < ApplicationController |
|
18 | class TimelogController < ApplicationController | |
19 | menu_item :issues |
|
19 | menu_item :issues | |
20 | before_filter :find_project, :authorize, :only => [:new, :edit, :destroy] |
|
20 | before_filter :find_project, :authorize, :only => [:new, :create, :edit, :destroy] | |
21 | before_filter :find_optional_project, :only => [:index] |
|
21 | before_filter :find_optional_project, :only => [:index] | |
22 |
|
22 | |||
23 | verify :method => :post, :only => :destroy, :redirect_to => { :action => :index } |
|
23 | verify :method => :post, :only => :destroy, :redirect_to => { :action => :index } | |
@@ -93,6 +93,21 class TimelogController < ApplicationController | |||||
93 | call_hook(:controller_timelog_edit_before_save, { :params => params, :time_entry => @time_entry }) |
|
93 | call_hook(:controller_timelog_edit_before_save, { :params => params, :time_entry => @time_entry }) | |
94 | render :action => 'edit' |
|
94 | render :action => 'edit' | |
95 | end |
|
95 | end | |
|
96 | ||||
|
97 | verify :method => :post, :only => :create, :render => {:nothing => true, :status => :method_not_allowed } | |||
|
98 | def create | |||
|
99 | @time_entry ||= TimeEntry.new(:project => @project, :issue => @issue, :user => User.current, :spent_on => User.current.today) | |||
|
100 | @time_entry.attributes = params[:time_entry] | |||
|
101 | ||||
|
102 | call_hook(:controller_timelog_edit_before_save, { :params => params, :time_entry => @time_entry }) | |||
|
103 | ||||
|
104 | if @time_entry.save | |||
|
105 | flash[:notice] = l(:notice_successful_update) | |||
|
106 | redirect_back_or_default :action => 'index', :project_id => @time_entry.project | |||
|
107 | else | |||
|
108 | render :action => 'edit' | |||
|
109 | end | |||
|
110 | end | |||
96 |
|
111 | |||
97 | def edit |
|
112 | def edit | |
98 | (render_403; return) if @time_entry && !@time_entry.editable_by?(User.current) |
|
113 | (render_403; return) if @time_entry && !@time_entry.editable_by?(User.current) |
@@ -1,6 +1,6 | |||||
1 | <h2><%= l(:label_spent_time) %></h2> |
|
1 | <h2><%= l(:label_spent_time) %></h2> | |
2 |
|
2 | |||
3 | <% labelled_tabular_form_for :time_entry, @time_entry, :url => {:action => 'edit', :id => @time_entry, :project_id => @time_entry.project} do |f| %> |
|
3 | <% labelled_tabular_form_for :time_entry, @time_entry, :url => {:action => (@time_entry.new_record? ? 'create' : 'edit'), :id => @time_entry, :project_id => @time_entry.project} do |f| %> | |
4 | <%= error_messages_for 'time_entry' %> |
|
4 | <%= error_messages_for 'time_entry' %> | |
5 | <%= back_url_hidden_field_tag %> |
|
5 | <%= back_url_hidden_field_tag %> | |
6 |
|
6 |
@@ -40,7 +40,8 ActionController::Routing::Routes.draw do |map| | |||||
40 | timelog.with_options :action => 'new', :conditions => {:method => :get} do |time_edit| |
|
40 | timelog.with_options :action => 'new', :conditions => {:method => :get} do |time_edit| | |
41 | time_edit.connect 'issues/:issue_id/time_entries/new' |
|
41 | time_edit.connect 'issues/:issue_id/time_entries/new' | |
42 | end |
|
42 | end | |
43 |
|
43 | |||
|
44 | timelog.connect 'projects/:project_id/timelog/edit', :action => 'create', :conditions => {:method => :post} | |||
44 | timelog.connect 'time_entries/:id/destroy', :action => 'destroy', :conditions => {:method => :post} |
|
45 | timelog.connect 'time_entries/:id/destroy', :action => 'destroy', :conditions => {:method => :post} | |
45 | end |
|
46 | end | |
46 |
|
47 |
@@ -84,10 +84,10 Redmine::AccessControl.map do |map| | |||||
84 | end |
|
84 | end | |
85 |
|
85 | |||
86 | map.project_module :time_tracking do |map| |
|
86 | map.project_module :time_tracking do |map| | |
87 | map.permission :log_time, {:timelog => :edit}, :require => :loggedin |
|
87 | map.permission :log_time, {:timelog => [:new, :create, :edit]}, :require => :loggedin | |
88 | map.permission :view_time_entries, :timelog => [:index], :time_entry_reports => [:report] |
|
88 | map.permission :view_time_entries, :timelog => [:index], :time_entry_reports => [:report] | |
89 | map.permission :edit_time_entries, {:timelog => [:new, :edit, :destroy]}, :require => :member |
|
89 | map.permission :edit_time_entries, {:timelog => [:new, :create, :edit, :destroy]}, :require => :member | |
90 | map.permission :edit_own_time_entries, {:timelog => [:new, :edit, :destroy]}, :require => :loggedin |
|
90 | map.permission :edit_own_time_entries, {:timelog => [:new, :create, :edit, :destroy]}, :require => :loggedin | |
91 | map.permission :manage_project_activities, {:project_enumerations => [:update, :destroy]}, :require => :member |
|
91 | map.permission :manage_project_activities, {:project_enumerations => [:update, :destroy]}, :require => :member | |
92 | end |
|
92 | end | |
93 |
|
93 |
@@ -72,11 +72,11 class TimelogControllerTest < ActionController::TestCase | |||||
72 | assert_tag :tag => 'option', :content => '--- Please select ---' |
|
72 | assert_tag :tag => 'option', :content => '--- Please select ---' | |
73 | end |
|
73 | end | |
74 |
|
74 | |||
75 |
def test_post_ |
|
75 | def test_post_create | |
76 | # TODO: should POST to issues’ time log instead of project. change form |
|
76 | # TODO: should POST to issues’ time log instead of project. change form | |
77 | # and routing |
|
77 | # and routing | |
78 | @request.session[:user_id] = 3 |
|
78 | @request.session[:user_id] = 3 | |
79 |
post : |
|
79 | post :create, :project_id => 1, | |
80 | :time_entry => {:comments => 'Some work on TimelogControllerTest', |
|
80 | :time_entry => {:comments => 'Some work on TimelogControllerTest', | |
81 | # Not the default activity |
|
81 | # Not the default activity | |
82 | :activity_id => '11', |
|
82 | :activity_id => '11', |
@@ -238,6 +238,7 class RoutingTest < ActionController::IntegrationTest | |||||
238 | should_route :get, "/projects/ecookbook/issues/567/time_entries/new", :controller => 'timelog', :action => 'new', :project_id => 'ecookbook', :issue_id => '567' |
|
238 | should_route :get, "/projects/ecookbook/issues/567/time_entries/new", :controller => 'timelog', :action => 'new', :project_id => 'ecookbook', :issue_id => '567' | |
239 | should_route :get, "/time_entries/22/edit", :controller => 'timelog', :action => 'edit', :id => '22' |
|
239 | should_route :get, "/time_entries/22/edit", :controller => 'timelog', :action => 'edit', :id => '22' | |
240 |
|
240 | |||
|
241 | should_route :post, "/projects/ecookbook/timelog/edit", :controller => 'timelog', :action => 'create', :project_id => 'ecookbook' | |||
241 | should_route :post, "/time_entries/22/edit", :controller => 'timelog', :action => 'edit', :id => '22' |
|
242 | should_route :post, "/time_entries/22/edit", :controller => 'timelog', :action => 'edit', :id => '22' | |
242 | should_route :post, "/time_entries/55/destroy", :controller => 'timelog', :action => 'destroy', :id => '55' |
|
243 | should_route :post, "/time_entries/55/destroy", :controller => 'timelog', :action => 'destroy', :id => '55' | |
243 | end |
|
244 | end |
General Comments 0
You need to be logged in to leave comments.
Login now