diff options
author | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2007-05-05 13:22:27 +0000 |
---|---|---|
committer | Jean-Philippe Lang <jp_lang@yahoo.fr> | 2007-05-05 13:22:27 +0000 |
commit | 92b02014d21f0e60230fc7a5c3c5ad71dac6e472 (patch) | |
tree | 30fcce490ea2c6decb6ea34b589f11f04bfd381d /app/views | |
parent | 987e843cd195edc402c8b2c7c665534ddb02af45 (diff) | |
download | redmine-92b02014d21f0e60230fc7a5c3c5ad71dac6e472.tar.gz redmine-92b02014d21f0e60230fc7a5c3c5ad71dac6e472.zip |
Issue relations first commit (not thoroughly tested). 4 kinds of relation are available:
* relates to: do nothing special. Just to know that the 2 issues are related...
* duplicates: will close the related issue with the same status when closing the issue (not implemented yet)
* blocks: will require to close the blocking issue before closing the blocked issue (not implemented yet)
* precedes (end to start relation): start date of the related issue depends on the due date of the preceding issue (implemented). A delay can be set so that the related issue can only start n days after the end of the preceding issue. When setting dates for an issue, dates of all downstream issues are set according to these relations.
To set a relation, the 2 issues have to belong to the same project (may change in the future). So if an issue is moved to another project, all its relations are removed.
Circular dependencies are checked when creating a relation.
git-svn-id: http://redmine.rubyforge.org/svn/trunk@506 e93f8b46-1217-0410-a6f0-8f06a7374b81
Diffstat (limited to 'app/views')
-rw-r--r-- | app/views/issue_relations/_form.rhtml | 10 | ||||
-rw-r--r-- | app/views/issues/_relations.rhtml | 22 | ||||
-rw-r--r-- | app/views/issues/show.rhtml | 6 |
3 files changed, 38 insertions, 0 deletions
diff --git a/app/views/issue_relations/_form.rhtml b/app/views/issue_relations/_form.rhtml new file mode 100644 index 000000000..8b514dc1a --- /dev/null +++ b/app/views/issue_relations/_form.rhtml @@ -0,0 +1,10 @@ +<%= error_messages_for 'relation' %> + +<p><%= f.select :relation_type, collection_for_relation_type_select, {}, :onchange => "setPredecessorFieldsVisibility();" %> +<%= l(:label_issue) %> #<%= f.text_field :issue_to_id, :size => 6 %> +<span id="predecessor_fields" style="display:none;"> +<%= l(:field_delay) %>: <%= f.text_field :delay, :size => 3 %> <%= l(:label_day_plural) %> +</span> +<%= submit_tag l(:button_add) %></p> + +<%= javascript_tag "setPredecessorFieldsVisibility();" %> diff --git a/app/views/issues/_relations.rhtml b/app/views/issues/_relations.rhtml new file mode 100644 index 000000000..f817d3851 --- /dev/null +++ b/app/views/issues/_relations.rhtml @@ -0,0 +1,22 @@ +<h3><%=l(:label_related_issues)%></h3> + +<table style="width:100%"> +<% @issue.relations.each do |relation| %> +<tr> +<td><%= l(relation.label_for(@issue)) %> <%= "(#{lwr(:actionview_datehelper_time_in_words_day, relation.delay)})" if relation.delay && relation.delay != 0 %> <%= link_to_issue relation.other_issue(@issue) %></td> +<td><%=h relation.other_issue(@issue).subject %></td> +<td><div class="square" style="background:#<%= relation.other_issue(@issue).status.html_color %>;"></div> <%= relation.other_issue(@issue).status.name %></td> +<td><%= format_date(relation.other_issue(@issue).start_date) %></td> +<td><%= format_date(relation.other_issue(@issue).due_date) %></td> +<td><%= link_to_remote image_tag('delete.png'), { :url => {:controller => 'issue_relations', :action => 'destroy', :issue_id => @issue, :id => relation}, + :method => :post + }, :title => l(:label_relation_delete) %></td> +</tr> +<% end %> +</table> + +<% if authorize_for('issue_relations', 'new') %> + <% remote_form_for(:relation, @relation, :url => {:controller => 'issue_relations', :action => 'new', :issue_id => @issue}, :method => :post) do |f| %> + <%= render :partial => 'issue_relations/form', :locals => {:f => f}%> + <% end %> +<% end %> diff --git a/app/views/issues/show.rhtml b/app/views/issues/show.rhtml index 2eb01f094..d7d9bcf6d 100644 --- a/app/views/issues/show.rhtml +++ b/app/views/issues/show.rhtml @@ -81,6 +81,12 @@ end %> </div> +<% if authorize_for('issue_relations', 'new') || @issue.relations.any? %> +<div id="relations" class="box"> +<%= render :partial => 'relations' %> +</div> +<% end %> + <div id="history" class="box"> <h3><%=l(:label_history)%> <% if @journals_count > @journals.length %>(<%= l(:label_last_changes, @journals.length) %>)<% end %></h3> |