Project

General

Profile

Feature #3058 » 0004-add-time-entries-tab-to-issue-history-tabs.patch

Marius BĂLTEANU, 2019-06-20 08:19

View differences:

app/controllers/issues_controller.rb
104 104
        @allowed_statuses = @issue.new_statuses_allowed_to(User.current)
105 105
        @priorities = IssuePriority.active
106 106
        @time_entry = TimeEntry.new(:issue => @issue, :project => @issue.project)
107
        @time_entries = @issue.time_entries.visible.preload(:activity, :user)
107 108
        @relation = IssueRelation.new
108 109
        retrieve_previous_and_next_issue_ids
109 110
        render :template => 'issues/show'
app/helpers/issues_helper.rb
557 557
      tabs << {:name => 'notes', :label => :label_issue_history_notes, :onclick => 'showIssueHistory("notes", this.href)'} if journals_with_notes.any?
558 558
      tabs << {:name => 'properties', :label => :label_issue_history_properties, :onclick => 'showIssueHistory("properties", this.href)'} if journals_without_notes.any?
559 559
    end
560
    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
560 561
    tabs << {:name => 'changesets', :label => :label_associated_revisions, :partial => 'issues/tabs/changesets', :locals => {:changesets => @changesets}} if @changesets.present?
561 562
    tabs
562 563
  end
app/views/issues/tabs/_time_entries.html.erb
1
<% for time_entry in tab[:locals][:time_entries] %>
2
  <div id="time-entry-<%= time_entry.id %>" class="time_entry journal">
3
    <% if time_entry.editable_by?(User.current) -%>
4
      <div class="contextual">
5
        <%= link_to l(:button_edit), edit_time_entry_path(time_entry),
6
                    :title => l(:button_edit),
7
                    :class => 'icon-only icon-edit' %>
8
        <%= link_to l(:button_delete), time_entry_path(time_entry),
9
                    :data => {:confirm => l(:text_are_you_sure)},
10
                    :method => :delete,
11
                    :title => l(:button_delete),
12
                    :class => 'icon-only icon-del' %>
13
      </div>
14
    <% end -%>
15
    <h4>
16
      <%= avatar(time_entry.user, :size => "24") %>
17
      <%= authoring time_entry.created_on, time_entry.user, :label => :label_added_time_by %>
18
    </h4>
19
    <ul class="details">
20
      <li>
21
        <strong><%= l(:label_time_entry_plural) %></strong>:
22
        <%= l_hours_short time_entry.hours %>
23
      </li>
24
    </ul>
25
    <p><%= time_entry.comments %></p>
26
  </div>
27
  <%= call_hook(:view_issues_history_time_entry_bottom, { :time_entry => time_entry }) %>
28
<% end %>
test/functional/issues_controller_test.rb
2515 2515

  
2516 2516
  def test_show_display_changesets_tab_for_issue_with_changesets
2517 2517
    project = Project.find(2)
2518
    issue = Issue.find(3)
2518
    issue = Issue.find(9)
2519 2519
    issue.changeset_ids = [102]
2520 2520
    issue.save!
2521 2521

  
2522 2522
    @request.session[:user_id] = 2
2523
    get :show, :params => {:id => 3}
2523
    get :show, :params => {:id => issue.id}
2524 2524

  
2525 2525
    assert_select '#history' do
2526 2526
      assert_select 'div.tabs ul a', 1
......
2528 2528
    end
2529 2529
  end
2530 2530

  
2531
  def test_show_should_display_spent_time_tab_for_issue_with_time_entries
2532
    @request.session[:user_id] = 1
2533
    get :show, :params => {:id => 3}
2534
    assert_response :success
2535

  
2536
    assert_select '#history' do
2537
      assert_select 'div.tabs ul a', 1
2538
      assert_select 'div.tabs a[id=?]', 'tab-time_entries', :text => 'Spent time'
2539
    end
2540

  
2541
    assert_select 'div[id=?]', 'time-entry-3' do
2542
      assert_select 'a[title=?][href=?]', 'Edit', '/time_entries/3/edit'
2543
      assert_select 'a[title=?][href=?]', 'Delete', '/time_entries/3'
2544

  
2545
      assert_select 'ul[class=?]', 'details', :text => /1.00 h/
2546
    end
2547
  end
2548

  
2531 2549
  def test_get_new
2532 2550
    @request.session[:user_id] = 2
2533 2551
    get :new, :params => {
(23-23/28)