mirror of
https://github.com/redmine/redmine.git
synced 2025-11-15 09:46:02 +01:00
Add time entries tab to issue history tabs (#3058).
Patch by Marius BALTEANU. git-svn-id: http://svn.redmine.org/redmine/trunk@18274 e93f8b46-1217-0410-a6f0-8f06a7374b81
This commit is contained in:
@@ -104,6 +104,7 @@ class IssuesController < ApplicationController
|
|||||||
@allowed_statuses = @issue.new_statuses_allowed_to(User.current)
|
@allowed_statuses = @issue.new_statuses_allowed_to(User.current)
|
||||||
@priorities = IssuePriority.active
|
@priorities = IssuePriority.active
|
||||||
@time_entry = TimeEntry.new(:issue => @issue, :project => @issue.project)
|
@time_entry = TimeEntry.new(:issue => @issue, :project => @issue.project)
|
||||||
|
@time_entries = @issue.time_entries.visible.preload(:activity, :user)
|
||||||
@relation = IssueRelation.new
|
@relation = IssueRelation.new
|
||||||
retrieve_previous_and_next_issue_ids
|
retrieve_previous_and_next_issue_ids
|
||||||
render :template => 'issues/show'
|
render :template => 'issues/show'
|
||||||
|
|||||||
@@ -557,6 +557,7 @@ module IssuesHelper
|
|||||||
tabs << {:name => 'notes', :label => :label_issue_history_notes, :onclick => 'showIssueHistory("notes", this.href)'} if journals_with_notes.any?
|
tabs << {:name => 'notes', :label => :label_issue_history_notes, :onclick => 'showIssueHistory("notes", this.href)'} if journals_with_notes.any?
|
||||||
tabs << {:name => 'properties', :label => :label_issue_history_properties, :onclick => 'showIssueHistory("properties", this.href)'} if journals_without_notes.any?
|
tabs << {:name => 'properties', :label => :label_issue_history_properties, :onclick => 'showIssueHistory("properties", this.href)'} if journals_without_notes.any?
|
||||||
end
|
end
|
||||||
|
tabs << {:name => 'time_entries', :label => :label_time_entry_plural, :partial => 'issues/tabs/time_entries', :locals => {:time_entries => @time_entries}} if User.current.allowed_to?(:view_time_entries, @project) && @issue.spent_hours > 0
|
||||||
tabs << {:name => 'changesets', :label => :label_associated_revisions, :partial => 'issues/tabs/changesets', :locals => {:changesets => @changesets}} if @changesets.present?
|
tabs << {:name => 'changesets', :label => :label_associated_revisions, :partial => 'issues/tabs/changesets', :locals => {:changesets => @changesets}} if @changesets.present?
|
||||||
tabs
|
tabs
|
||||||
end
|
end
|
||||||
|
|||||||
28
app/views/issues/tabs/_time_entries.html.erb
Normal file
28
app/views/issues/tabs/_time_entries.html.erb
Normal file
@@ -0,0 +1,28 @@
|
|||||||
|
<% for time_entry in tab[:locals][:time_entries] %>
|
||||||
|
<div id="time-entry-<%= time_entry.id %>" class="time_entry journal">
|
||||||
|
<% if time_entry.editable_by?(User.current) -%>
|
||||||
|
<div class="contextual">
|
||||||
|
<%= link_to l(:button_edit), edit_time_entry_path(time_entry),
|
||||||
|
:title => l(:button_edit),
|
||||||
|
:class => 'icon-only icon-edit' %>
|
||||||
|
<%= link_to l(:button_delete), time_entry_path(time_entry),
|
||||||
|
:data => {:confirm => l(:text_are_you_sure)},
|
||||||
|
:method => :delete,
|
||||||
|
:title => l(:button_delete),
|
||||||
|
:class => 'icon-only icon-del' %>
|
||||||
|
</div>
|
||||||
|
<% end -%>
|
||||||
|
<h4>
|
||||||
|
<%= avatar(time_entry.user, :size => "24") %>
|
||||||
|
<%= authoring time_entry.created_on, time_entry.user, :label => :label_added_time_by %>
|
||||||
|
</h4>
|
||||||
|
<ul class="details">
|
||||||
|
<li>
|
||||||
|
<strong><%= l(:label_time_entry_plural) %></strong>:
|
||||||
|
<%= l_hours_short time_entry.hours %>
|
||||||
|
</li>
|
||||||
|
</ul>
|
||||||
|
<p><%= time_entry.comments %></p>
|
||||||
|
</div>
|
||||||
|
<%= call_hook(:view_issues_history_time_entry_bottom, { :time_entry => time_entry }) %>
|
||||||
|
<% end %>
|
||||||
@@ -2537,12 +2537,12 @@ class IssuesControllerTest < Redmine::ControllerTest
|
|||||||
|
|
||||||
def test_show_display_changesets_tab_for_issue_with_changesets
|
def test_show_display_changesets_tab_for_issue_with_changesets
|
||||||
project = Project.find(2)
|
project = Project.find(2)
|
||||||
issue = Issue.find(3)
|
issue = Issue.find(9)
|
||||||
issue.changeset_ids = [102]
|
issue.changeset_ids = [102]
|
||||||
issue.save!
|
issue.save!
|
||||||
|
|
||||||
@request.session[:user_id] = 2
|
@request.session[:user_id] = 2
|
||||||
get :show, :params => {:id => 3}
|
get :show, :params => {:id => issue.id}
|
||||||
|
|
||||||
assert_select '#history' do
|
assert_select '#history' do
|
||||||
assert_select 'div.tabs ul a', 1
|
assert_select 'div.tabs ul a', 1
|
||||||
@@ -2550,6 +2550,24 @@ class IssuesControllerTest < Redmine::ControllerTest
|
|||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
def test_show_should_display_spent_time_tab_for_issue_with_time_entries
|
||||||
|
@request.session[:user_id] = 1
|
||||||
|
get :show, :params => {:id => 3}
|
||||||
|
assert_response :success
|
||||||
|
|
||||||
|
assert_select '#history' do
|
||||||
|
assert_select 'div.tabs ul a', 1
|
||||||
|
assert_select 'div.tabs a[id=?]', 'tab-time_entries', :text => 'Spent time'
|
||||||
|
end
|
||||||
|
|
||||||
|
assert_select 'div[id=?]', 'time-entry-3' do
|
||||||
|
assert_select 'a[title=?][href=?]', 'Edit', '/time_entries/3/edit'
|
||||||
|
assert_select 'a[title=?][href=?]', 'Delete', '/time_entries/3'
|
||||||
|
|
||||||
|
assert_select 'ul[class=?]', 'details', :text => /1.00 h/
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
def test_get_new
|
def test_get_new
|
||||||
@request.session[:user_id] = 2
|
@request.session[:user_id] = 2
|
||||||
get :new, :params => {
|
get :new, :params => {
|
||||||
|
|||||||
Reference in New Issue
Block a user