Frage

Das Problem liegt in Folgendes: Filter: Kontakt,: AS =>: String funktioniert erfolgreich, wenn ich die ID für den Kontakt eingeben kann. Das ist jedoch nicht praktisch, wenn Sie über 2000 Kontakte haben. Wie kann ich erfolgreich filtern: Kontakt, AS =>: String, aber es suche nach: Name anstelle von: id.

Ich habe Folgendes ohne Erfolg ausprobiert:

filter :contact, :as => :string, :collection => proc {Contact.where(:name => 'Paul' )}
filter :contact, :as => :string, :collection => proc { (Contact.order.all).resources{|c| [c.name]}} 

Hinweis: Mein Repository kann gefunden werden hier.

Modell: order.rb

belongs_to :contact

Migration:

def change
create_table :orders do |t|
  t.string :tag
  t.text :description
  t.string :technician_id
  t.string :status
  t.string :type
  t.string :contact_id
  t.string :business_id

  t.timestamps
end

Ende

Admin/ Bestellungen/ - Bestellungen.RB

filter :business
filter :contact, :as => :string, :collection => proc { (Contact.order.all).resources{|c| [c.name]}}

filter :tag
filter :description, :label => "Status"
filter :created_at

index do   
  column :business
  column :contact
  column :tag
  column :status
  column :description, :sortable => false do |order|
  truncate(order.description, :length => 30)
end  
War es hilfreich?

Lösung

ActiveDmin verwendet Meta_Search Gem. Versuchen Sie Folgendes:

filter :contact_name, :as => :string
Lizenziert unter: CC-BY-SA mit Zuschreibung
Nicht verbunden mit StackOverflow
scroll top