Как удалить несколько записей одновременно с помощью Rails 3 и нескольких элементов check_box_tag - PullRequest
2 голосов
/ 24 марта 2012

Я застрял хуже, чем Юго в канаве.

Я добавил изменения, которые в итоге сделали эту работу ниже (помечены жирным шрифтом правки ).

Фон

  • Виджеты имеют много Гаджетов
  • Последний столбец td в таблице имеет check_box_tags для выбора отдельных записей гаджетов для удаления

Желаемое поведение

  • Пользователь должен иметь возможность нажимать «checkall», а также отдельные флажки, чтобы выбирать гаджеты по одному
  • Нажатие кнопки «Удалить выбранное» должно удалить отмеченные записи без обновления страницы

РЕДАКТИРОВАТЬ: Добавление более подробной информации о том, что не работает

Наблюдаемое поведение

  • метод destroy_multiple в gadgets_controller.rb никогда не вызывается
  • вместо этого, кажется, вызывается метод create

    Started POST "/widgets/1/gadgets" ...
    Processing by GadgetsController#create as JS
    Parameters: {"utf8"=>"✓", "authenticity_token"=>"...=", "widget"=>{"gadget_ids"=>["all", "140", "139"]}, "widget_id"=>"1"}
    Widget Load (0.3ms) SELECT "widgets".* FROM "widget" WHERE "widget"."id" = $1 LIMIT 1 [["id", "1"]]
    Rendered gadgets/create.html.haml within layouts/application (1.1ms)
    Rendered layouts/_header.html.haml (0.2ms)
    Completed 200 OK in 36ms (Views: 19.0ms | ActiveRecord: 5.0ms)

Мне тоже неясно по этому поводу: {"gadget_ids"=>["all", "140", "139"]}.

"all" - это идентификатор css id 1, используемый для "checkall". В приведенном ниже файле checkbox.js.coffee я пытаюсь удалить значение «all» из массива с помощью javascript. Когда я записываю массив в консоль, «все» удаляется успешно. И все же он продолжает отправляться на контроллер гаджетов.

EDIT Удаленная форма rails заполняет массив гаджетов для запроса POST. просто нужно было правильно его настроить.

Модель

widget.rb

class Widget < ActiveRecord::Base
  has_many :gadgets
  validates_presence_of :name
end

gadget.rb

class Gadget < ActiveRecord::Base
  belongs_to :widget
  validates_presence_of :widget_id
end

Контроллер гаджетов

class GadgetsController < ApplicationController
  include ApplicationHelper

  before_filter :get_widget
  before_filter :widget_gadgets, only: [ :index ]
  respond_to :json

  def json_widgets
    [ @widget, @gadgets ]
  end

  def index
    respond_with(json_widgets) do |format|
      format.json
      format.html
    end
  end

  def new
    @gadget = @widget.gadgets.new()
  end

  def create
    @gadget=@widget.gadgets.new(params[:gadget])
    if @gadget.save
      flash[:success] = "Gadget was successfully created"
      redirect_to widget_gadgets_path
    end
  end

  def destroy_multiple
    gadget_ids=(params[:gadget_ids])
    to_delete=[]
    gadget_ids.split(',').each do |gadget_id|
      to_delete.push(Gadget.find(gadget_id))
    end
    to_delete.each do |del|
      del.destroy()
    end
    flash.now[:success] = "Gadget Destroyed Successfully"
    respond_to do |format|
      format.html { redirect_to widget_gadgets_path(@widget) }
      format.json { render :json => to_delete.to_json }
    end
  end

  def destroy
    @gadget = gadget.find(params[:gadget_id])
    @widget.gadgets.destroy(@gadget.id)
    respond_to do |format|
      format.html { redirect_to(widget_gadgets_path) }
    end 
  end

  def get_widget
    begin
      @widget = Widget.find(params[:widget_id])
    rescue ActiveRecord::RecordNotFound
      render file: "public/404.html", status: 404
    end
  end

  private
  def widget_gadgets
    @widget=Widget.find(params[:widget_id])
    @gadgets=@widget.gadgets unless @widget.gadgets.nil?
  end      
end

routes.rb

Я пытаюсь использовать блок collection do . Это правильный способ реализации маршрута destroy_multiple?

DestroyMultiple::Application.routes.draw do
  resources :widgets
  resources :gadgets, :only => [ :new, :create ]

  resources :widgets do
    resources :gadgets do
      collection do
        post :destroy_multiple
      end
    end
  end

  match "/:id" => 'widget#gadgets'
  root to: 'widgets#index'
end

1 Ответ

2 голосов
/ 07 апреля 2012

После того, как все заработало, я хотел опубликовать полное решение.

Вместо того, чтобы вводить все это здесь, пожалуйста, смотрите полное приложение на GitHub.

Пока это решение работает, мне было бы очень интересно узнать, как я могу оптимизировать решение.Еще раз спасибо тем, кто помог!

https://github.com/hernamesbarbara/AJAX-Rails-Full-CRUD

...