Explorar el Código

Lists can be reordered with drag and drop (#12909).

git-svn-id: http://svn.redmine.org/redmine/trunk@15336 e93f8b46-1217-0410-a6f0-8f06a7374b81
tags/3.3.0
Jean-Philippe Lang hace 8 años
padre
commit
42b5c332b2

+ 11
- 3
app/controllers/custom_fields_controller.rb Ver fichero

@@ -54,11 +54,19 @@ class CustomFieldsController < ApplicationController

def update
if @custom_field.update_attributes(params[:custom_field])
flash[:notice] = l(:notice_successful_update)
call_hook(:controller_custom_fields_edit_after_save, :params => params, :custom_field => @custom_field)
redirect_back_or_default edit_custom_field_path(@custom_field)
respond_to do |format|
format.html {
flash[:notice] = l(:notice_successful_update)
redirect_back_or_default edit_custom_field_path(@custom_field)
}
format.js { render :nothing => true }
end
else
render :action => 'edit'
respond_to do |format|
format.html { render :action => 'edit' }
format.js { render :nothing => true, :status => 422 }
end
end
end


+ 11
- 3
app/controllers/enumerations_controller.rb Ver fichero

@@ -57,10 +57,18 @@ class EnumerationsController < ApplicationController

def update
if @enumeration.update_attributes(params[:enumeration])
flash[:notice] = l(:notice_successful_update)
redirect_to enumerations_path
respond_to do |format|
format.html {
flash[:notice] = l(:notice_successful_update)
redirect_to enumerations_path
}
format.js { render :nothing => true }
end
else
render :action => 'edit'
respond_to do |format|
format.html { render :action => 'edit' }
format.js { render :nothing => true, :status => 422 }
end
end
end


+ 11
- 3
app/controllers/issue_statuses_controller.rb Ver fichero

@@ -51,10 +51,18 @@ class IssueStatusesController < ApplicationController
def update
@issue_status = IssueStatus.find(params[:id])
if @issue_status.update_attributes(params[:issue_status])
flash[:notice] = l(:notice_successful_update)
redirect_to issue_statuses_path(:page => params[:page])
respond_to do |format|
format.html {
flash[:notice] = l(:notice_successful_update)
redirect_to issue_statuses_path(:page => params[:page])
}
format.js { render :nothing => true }
end
else
render :action => 'edit'
respond_to do |format|
format.html { render :action => 'edit' }
format.js { render :nothing => true, :status => 422 }
end
end
end


+ 11
- 3
app/controllers/roles_controller.rb Ver fichero

@@ -72,10 +72,18 @@ class RolesController < ApplicationController

def update
if @role.update_attributes(params[:role])
flash[:notice] = l(:notice_successful_update)
redirect_to roles_path(:page => params[:page])
respond_to do |format|
format.html {
flash[:notice] = l(:notice_successful_update)
redirect_to roles_path(:page => params[:page])
}
format.js { render :nothing => true }
end
else
render :action => 'edit'
respond_to do |format|
format.html { render :action => 'edit' }
format.js { render :nothing => true, :status => 422 }
end
end
end


+ 15
- 5
app/controllers/trackers_controller.rb Ver fichero

@@ -59,12 +59,22 @@ class TrackersController < ApplicationController
def update
@tracker = Tracker.find(params[:id])
if @tracker.update_attributes(params[:tracker])
flash[:notice] = l(:notice_successful_update)
redirect_to trackers_path(:page => params[:page])
return
respond_to do |format|
format.html {
flash[:notice] = l(:notice_successful_update)
redirect_to trackers_path(:page => params[:page])
}
format.js { render :nothing => true }
end
else
respond_to do |format|
format.html {
edit
render :action => 'edit'
}
format.js { render :nothing => true, :status => 422 }
end
end
edit
render :action => 'edit'
end

def destroy

+ 10
- 0
app/helpers/application_helper.rb Ver fichero

@@ -468,6 +468,16 @@ module ApplicationHelper
:title => l(:label_sort_lowest), :class => 'icon-only icon-move-bottom')
end

def reorder_handle(object, options={})
data = {
:reorder_url => options[:url] || url_for(object),
:reorder_param => options[:param] || object.class.name.underscore
}
content_tag('span', '',
:class => "sort-handle ui-icon ui-icon-arrowthick-2-n-s",
:data => data)
end

def breadcrumb(*args)
elements = args.flatten
elements.any? ? content_tag('p', (args.join(" \xc2\xbb ") + " \xc2\xbb ").html_safe, :class => 'breadcrumb') : nil

+ 2
- 3
app/views/custom_fields/_index.html.erb Ver fichero

@@ -1,4 +1,4 @@
<table class="list">
<table class="list custom_fields">
<thead><tr>
<th><%=l(:field_name)%></th>
<th><%=l(:field_field_format)%></th>
@@ -7,7 +7,6 @@
<th><%=l(:field_is_for_all)%></th>
<th><%=l(:label_used_by)%></th>
<% end %>
<th><%=l(:button_sort)%></th>
<th></th>
</tr></thead>
<tbody>
@@ -21,8 +20,8 @@
<td><%= checked_image custom_field.is_for_all? %></td>
<td><%= l(:label_x_projects, :count => custom_field.projects.count) if custom_field.is_a? IssueCustomField and !custom_field.is_for_all? %></td>
<% end %>
<td class="reorder"><%= reorder_links('custom_field', {:action => 'update', :id => custom_field, :back_url => back_url}, :put) %></td>
<td class="buttons">
<%= reorder_handle(custom_field, :url => custom_field_path(custom_field), :param => 'custom_field') %>
<%= delete_link custom_field_path(custom_field) %>
</td>
</tr>

+ 4
- 0
app/views/custom_fields/index.html.erb Ver fichero

@@ -9,3 +9,7 @@
<% else %>
<p class="nodata"><%= l(:label_no_data) %></p>
<% end %>

<%= javascript_tag do %>
$(function() { $("table.custom_fields tbody").positionedItems(); });
<% end %>

+ 9
- 4
app/views/enumerations/index.html.erb Ver fichero

@@ -5,12 +5,11 @@

<% enumerations = klass.shared %>
<% if enumerations.any? %>
<table class="list"><thead>
<table class="list enumerations"><thead>
<tr>
<th><%= l(:field_name) %></th>
<th><%= l(:field_is_default) %></th>
<th><%= l(:field_active) %></th>
<th><%=l(:button_sort)%></th>
<th></th>
</tr></thead>
<% enumerations.each do |enumeration| %>
@@ -18,8 +17,10 @@
<td class="name"><%= link_to enumeration, edit_enumeration_path(enumeration) %></td>
<td class="tick"><%= checked_image enumeration.is_default? %></td>
<td class="tick"><%= checked_image enumeration.active? %></td>
<td class="reorder"><%= reorder_links('enumeration', {:action => 'update', :id => enumeration}, :put) %></td>
<td class="buttons"><%= delete_link enumeration_path(enumeration) %></td>
<td class="buttons">
<%= reorder_handle(enumeration, :url => enumeration_path(enumeration), :param => 'enumeration') %>
<%= delete_link enumeration_path(enumeration) %>
</td>
</tr>
<% end %>
</table>
@@ -30,3 +31,7 @@
<% end %>

<% html_title(l(:label_enumerations)) -%>

<%= javascript_tag do %>
$(function() { $("table.enumerations tbody").positionedItems(); });
<% end %>

+ 6
- 3
app/views/issue_statuses/index.html.erb Ver fichero

@@ -5,14 +5,13 @@

<h2><%=l(:label_issue_status_plural)%></h2>

<table class="list">
<table class="list issue_statuses">
<thead><tr>
<th><%=l(:field_status)%></th>
<% if Issue.use_status_for_done_ratio? %>
<th><%=l(:field_done_ratio)%></th>
<% end %>
<th><%=l(:field_is_closed)%></th>
<th><%=l(:button_sort)%></th>
<th></th>
</tr></thead>
<tbody>
@@ -23,8 +22,8 @@
<td><%= status.default_done_ratio %></td>
<% end %>
<td><%= checked_image status.is_closed? %></td>
<td class="reorder"><%= reorder_links('issue_status', {:action => 'update', :id => status, :page => params[:page]}, :put) %></td>
<td class="buttons">
<%= reorder_handle(status) %>
<%= delete_link issue_status_path(status) %>
</td>
</tr>
@@ -33,3 +32,7 @@
</table>

<% html_title(l(:label_issue_status_plural)) -%>

<%= javascript_tag do %>
$(function() { $("table.issue_statuses tbody").positionedItems(); });
<% end %>

+ 7
- 8
app/views/roles/index.html.erb Ver fichero

@@ -5,22 +5,17 @@

<h2><%=l(:label_role_plural)%></h2>

<table class="list">
<table class="list roles">
<thead><tr>
<th><%=l(:label_role)%></th>
<th><%=l(:button_sort)%></th>
<th></th>
</tr></thead>
<tbody>
<% for role in @roles %>
<tr class="<%= cycle("odd", "even") %>">
<tr class="<%= cycle("odd", "even") %> <%= role.builtin? ? "builtin" : "givable" %>">
<td class="name"><%= content_tag(role.builtin? ? 'em' : 'span', link_to(role.name, edit_role_path(role))) %></td>
<td class="reorder">
<% unless role.builtin? %>
<%= reorder_links('role', {:action => 'update', :id => role, :page => params[:page]}, :put) %>
<% end %>
</td>
<td class="buttons">
<%= reorder_handle(role) unless role.builtin? %>
<%= link_to l(:button_copy), new_role_path(:copy => role), :class => 'icon icon-copy' %>
<%= delete_link role_path(role) unless role.builtin? %>
</td>
@@ -30,3 +25,7 @@
</table>

<% html_title(l(:label_role_plural)) -%>

<%= javascript_tag do %>
$(function() { $("table.roles tbody").positionedItems({items: ".givable"}); });
<% end %>

+ 6
- 5
app/views/trackers/index.html.erb Ver fichero

@@ -5,11 +5,10 @@

<h2><%=l(:label_tracker_plural)%></h2>

<table class="list">
<table class="list trackers">
<thead><tr>
<th><%=l(:label_tracker)%></th>
<th></th>
<th><%=l(:button_sort)%></th>
<th></th>
</tr></thead>
<tbody>
@@ -23,10 +22,8 @@
</span>
<% end %>
</td>
<td class="reorder">
<%= reorder_links('tracker', {:action => 'update', :id => tracker, :page => params[:page]}, :put) %>
</td>
<td class="buttons">
<%= reorder_handle(tracker) %>
<%= delete_link tracker_path(tracker) %>
</td>
</tr>
@@ -35,3 +32,7 @@
</table>

<% html_title(l(:label_tracker_plural)) -%>

<%= javascript_tag do %>
$(function() { $("table.trackers tbody").positionedItems(); });
<% end %>

+ 39
- 0
public/javascripts/application.js Ver fichero

@@ -590,6 +590,45 @@ function beforeShowDatePicker(input, inst) {
$(input).datepicker("option", "defaultDate", default_date);
}

(function($){
$.fn.positionedItems = function(sortableOptions, options){
var settings = $.extend({
firstPosition: 1
}, options );

return this.sortable($.extend({
handle: ".sort-handle",
helper: function(event, ui){
ui.children().each(function(){
$(this).width($(this).width());
});
return ui;
},
update: function(event, ui) {
var sortable = $(this);
var url = ui.item.find(".sort-handle").data("reorder-url");
var param = ui.item.find(".sort-handle").data("reorder-param");
var data = {};
data[param] = {position: ui.item.index() + settings['firstPosition']};
$.ajax({
url: url,
type: 'put',
dataType: 'script',
data: data,
success: function(data){
sortable.children(":even").removeClass("even").addClass("odd");
sortable.children(":odd").removeClass("odd").addClass("even");
},
error: function(jqXHR, textStatus, errorThrown){
alert(jqXHR.status);
sortable.sortable("cancel");
}
});
},
}, sortableOptions));
}
}( jQuery ));

function initMyPageSortable(list, url) {
$('#list-'+list).sortable({
connectWith: '.block-receiver',

+ 1
- 1
test/functional/trackers_controller_test.rb Ver fichero

@@ -152,7 +152,7 @@ class TrackersControllerTest < ActionController::TestCase

def test_move_lower
tracker = Tracker.find_by_position(1)
put :update, :id => 1, :tracker => { :move_to => 'lower' }
put :update, :id => 1, :tracker => { :position => '2' }
assert_equal 2, tracker.reload.position
end


Cargando…
Cancelar
Guardar