Skip to content

A magical way to add sorting dynamically to ecto queries

Notifications You must be signed in to change notification settings

Multiverse-io/sortex

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

26 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Sortex

Dynamically sort data in Elixir!

Sortex examines your ecto queries and dynamically adds the desired sorting and any required joins.

Installation

If available in Hex, the package can be installed by adding sortex to your list of dependencies in mix.exs:

def deps do
  [
    {:sortex, "~> 0.1.0"}
  ]
end

You need to configure the route helpers module in your config file as shown below

config :sortex,
  route_helpers_module: YourAppWeb.Router.Helpers

Usage

You can use it like this:

  Animal
  |> Sortex.sort(%{"sort" => %{"field" => "number_of_feet"}})
  |> Repo.all

It also provides View functions to use in Phoenix templates to ensure the parameters are correct for the backend e.g

<table>
  <thead>
    <tr>
      <th><%= sorted_column @conn, helper: :animal_path, action: :show, field: :number_of_feet %></th>
    </tr>
  </thead>
  <tbody>
    <td><%= animal.number_of_feet %></td>
  </tbody>
</table>

It supports assoc fields on schema based queries too, but you do need to tell it the links between schema as a schema could appear more than once in a tree of nested schemas... For example, assuming you have an Animals schema with a Feed assoc and the Feed assoc has a Supplier assoc and you wish to sort by the name field on the Supplier schema you would do this:

<%= sorted_column @conn, helper: :animal_path, action: :show, assoc: [:feed, :supplier] field: :name %></th>

If you are using non schema based queries e.g. from a in "animals", select: %{a.number_of_feet} simple sorts work in the same way. However assocs are slightly different. You just need to give the name of the table and the field e.g:

<%= sorted_column @conn, helper: :animal_path, action: :show, assoc: :supplier field: :name %></th>

(If a table is joined multiple times in the query it will use the first join for it)

Documentation can be generated with ExDoc and published on HexDocs. Once published, the docs can be found at https://hexdocs.pm/sortex.

About

A magical way to add sorting dynamically to ecto queries

Topics

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages