A powerful, intelligent data table component for Ash Framework resources, in your Phoenix LiveView applications.

What is Cinder?

Cinder transforms complex data table requirements into simple, declarative markup. With automatic type inference and intelligent defaults, you can build feature-rich tables for Ash resources and queries, with minimal configuration.

<Cinder.Table.table resource={MyApp.User} actor={@current_user}>
  <:col :let={user} field="name" filter sort>{user.name}</:col>
  <:col :let={user} field="email" filter>{user.email}</:col>
  <:col :let={user} field="department.name" filter sort>{user.department.name}</:col>
  <:col :let={user} field="settings__country" filter>{user.settings.country}</:col>
</Cinder.Table.table>

That's it! Cinder automatically provides:

  • ✅ Intelligent filter types based on your Ash resource
  • ✅ Interactive sorting with visual indicators
  • ✅ Pagination with efficient queries
  • ✅ Relationship support via dot notation
  • ✅ Embedded resource support with automatic enum detection
  • ✅ URL state management for bookmarkable views

Sort and filter by calculations, aggregates, attributes, or even relationship data!

Key Features

  • 🧠 Intelligent Defaults: Automatic filter type detection from Ash resource attributes
  • ⚡ Minimal Configuration: 70% fewer attributes required compared to traditional table components
  • 🔗 Complete URL State Management: Filters, pagination, and sorting synchronized with browser URL
  • 🌐 Relationship Support: Dot notation for related fields (e.g., user.department.name)
  • 📦 Embedded Resource Support: Double underscore notation for embedded fields (e.g., user__profile__bio) with automatic enum detection
  • 🖱️ Interactive Row Actions: Click handlers with Phoenix LiveView JS commands for navigation, modals, and custom actions
  • 🎨 Advanced Theming: 8 built-in themes (modern, retro, futuristic, dark, daisy_ui, flowbite, compact, pastel) plus powerful DSL for custom themes
  • 🔧 Developer Experience: Data attributes on every element make theme development and debugging effortless
  • ⚡ Real-time Filtering: Six filter types with debounced updates
  • 🔐 Ash Integration: Native support for Ash Framework resources and authorization

Installation

If you're using Igniter in your project:

mix igniter.install cinder

This will automatically:

  • Add Cinder to your dependencies
  • Configure Tailwind CSS to include Cinder's styles
  • Provide setup instructions and examples

Manual Installation

Add cinder to your list of dependencies in mix.exs:

def deps do
  [
    {:cinder, "~> 0.2"}
  ]
end

Then run:

mix deps.get
mix cinder.install  # Configure Tailwind CSS

The installer will automatically update your Tailwind configuration to include Cinder's CSS classes. If automatic configuration fails, it will provide manual setup instructions.

Quick Start

Basic Table

<Cinder.Table.table resource={MyApp.User} actor={@current_user}>
  <:col :let={user} field="name" filter sort>{user.name}</:col>
  <:col :let={user} field="email" filter>{user.email}</:col>
  <:col :let={user} field="profile__country" filter>{user.profile.country}</:col>
  <:col :let={user} field="created_at" sort>{user.created_at}</:col>
</Cinder.Table.table>

Advanced Query Usage

For complex requirements, use the query parameter:

<Cinder.Table.table query={MyApp.User |> Ash.Query.filter(active: true)} actor={@current_user}>
  <:col :let={user} field="name" filter sort>{user.name}</:col>
  <:col :let={user} field="email" filter>{user.email}</:col>
</Cinder.Table.table>

Interactive Features

Add interactivity with row clicks or action columns:

<Cinder.Table.table
  resource={MyApp.User}
  actor={@current_user}
  row_click={fn user -> JS.navigate(~p"/users/#{user.id}") end}
>
  <:col :let={user} field="name" filter sort>{user.name}</:col>
  <:col :let={user} field="email" filter>{user.email}</:col>

  <!-- Action column - no field required -->
  <:col :let={user} label="Actions">
    <.link patch={~p"/users/#{user.id}/edit"}>Edit</.link>
  </:col>
</Cinder.Table.table>

Theming

Configure a default theme:

# config/config.exs
config :cinder, default_theme: "modern"

Available themes: "default", "modern", "retro", "futuristic", "dark", "daisy_ui", "flowbite", "compact", "pastel"

URL State Management

Enable bookmarkable URLs by adding URL sync to your LiveView:

defmodule MyAppWeb.UsersLive do
  use MyAppWeb, :live_view
  use Cinder.Table.UrlSync

  def handle_params(params, uri, socket) do
    socket = Cinder.Table.UrlSync.handle_params(params, uri, socket)
    {:noreply, socket}
  end

  def render(assigns) do
    ~H"""
    <Cinder.Table.table resource={MyApp.User} actor={@current_user} url_state={@url_state}>
      <:col field="name" filter sort>Name</:col>
    </Cinder.Table.table>
    """
  end
end

Documentation

For detailed examples of filters, sorting, theming, relationships, and advanced query usage, see the examples documentation.

Requirements

  • Phoenix LiveView 1.0+
  • Ash Framework 3.0+
  • Elixir 1.17+

Contributing

Contributions are welcome! Please submit pull requests to our GitHub repository.

License

This project is licensed under the MIT License - see the LICENSE file for details.