Merge pull request #1884 from C-Otto/circular-dependencies

(2.3) Circular dependencies
This commit is contained in:
Dan Rice 2015-06-14 18:13:54 -04:00
commit d06b857676
2 changed files with 13 additions and 5 deletions

View file

@ -301,7 +301,6 @@ var TodoItems = {
/* Drag & Drop for successor/predecessor */
var dragged_todo = ui.draggable[0].id.split('_')[2];
var dropped_todo = this.id.split('_')[2];
ui.draggable.remove();
$('.drop_target').hide(); // IE8 doesn't call stop() in this situation
ajax_options = default_ajax_options_for_scripts('POST', relative_to_root('todos/add_predecessor'), $(this));
@ -324,7 +323,7 @@ var TodoItems = {
setup_drag_and_drop: function() {
$('.item-show').draggable({
handle: '.grip',
revert: 'invalid',
revert: true,
start: TodoItems.drag_todo,
stop: function() {
$('.drop_target').hide();

View file

@ -85,7 +85,7 @@ class TodosController < ApplicationController
create_multiple
else
p = Todos::TodoCreateParamsHelper.new(params, current_user)
p.parse_dates() unless mobile?
p.parse_dates unless mobile?
tag_list = p.tag_list
@todo = current_user.todos.build
@ -423,7 +423,16 @@ class TodosController < ApplicationController
update_dependencies
update_attributes_of_todo
@saved = @todo.save
begin
@saved = @todo.save!
rescue ActiveRecord::RecordInvalid => exception
record = exception.record
if record.is_a?(Dependency)
record.errors.each { |key,value| @todo.errors[key] << value }
end
@saved = false
end
# this is set after save and cleared after reload, so save it here
@removed_predecessors = @todo.removed_predecessors
@ -1137,7 +1146,7 @@ end
end
def update_project
@project_changed = false;
@project_changed = false
if params['todo']['project_id'].blank? && !params['project_name'].nil?
if params['project_name'] == 'None'
project = Project.null_object