forked from smpallen99/ex_admin
-
Notifications
You must be signed in to change notification settings - Fork 11
How to use the sortable_table_for feature
Scott Swezey edited this page Oct 5, 2018
·
1 revision
Create a sorted sorted table allowing drag and drop for the rows, with ajax updates.
With a many-to-many join table:
defmodule MyApp.ExAdmin.Category do
use ExAdmin.Register
alias MyApp.{Category,CategoryProperty}
@position_column "priority" # "position" by default
register_resource Category do
show category do
attributes_table
panel "Properties" do
sortable_table_for(category, :category_properties) do
# call of `sort_handle_column` could be omitted
sort_handle_column "arrows" # "bars" by default
column :property
column :required, toggle: ~w(Yes No) # ~w(YES NO) in case `toggle: true`
column :displayable, toggle: true
end
end
end
query do
%{
show: [preload: [
# :any,
# :other,
# :associations,
category_properties: from(CategoryProperty, order_by: [:priority], preload: [:property])
# nested preload in from clause could be omitted if you don't use nested associations inside sortable tables
]],
# all: [preload: [:all, :associations, :used, :in_views, :and, :in_forms]]
}
end
end
end
With a has_many
relationship:
defmodule Survey.ExAdmin.Question do
use ExAdmin.Register
@position_column "key"
register_resource Survey.Question do
menu priority: 3
show question do
attributes_table
panel "Choices" do
sortable_table_for(question, :choices) do
#sort_handle_column
column :name
end
end
end
query do
%{
show: [preload: [
:survey,
choices: from(Survey.Choice, order_by: [:key])
]],
all: [preload: [:survey]]
}
end
end
end