Introducing LiveTable - Interactive Tables for Phoenix LiveView
Hello Elixir community!
I’m excited to announce the release of LiveTable, a comprehensive table component library built specifically for Phoenix LiveView applications. LiveTable aims to simplify the implementation of complex, interactive data tables while maintaining the real-time capabilities that make LiveView great.
Key Features
Rich Filtering System
Text search across multiple fields
Range filters for numbers, dates, and datetimes
Boolean filters with custom conditions
Select filters with static and dynamic options
Multi-column filtering support
Smart Sorting
Multi-column sorting with shift-click support
Sortable associated fields
Customizable sort directions
Export Capabilities
Background processing with Oban
CSV exports using NimbleCSV
PDF exports using Typst
Real-time Updates
Instant filter feedback
Seamless LiveView integration
Flexible Pagination
Configurable page sizes
Dynamic page navigation
Efficient database querying
Getting Started
Add to your dependencies:
def deps do
[
{:live_table, "~> 0.2.0"}
]
end
Check out our GitHub Repository for complete documentation and examples.
Why LiveTable?
We built LiveTable to address the common need for interactive data tables in Phoenix applications. It provides a robust, out-of-the-box solution that’s both powerful and easy to implement. Whether you’re building an admin panel or a data-heavy user interface, LiveTable handles the complexity while you focus on your application logic.
Demo Application
A live demonstration of LiveTable’s capabilities is available at livetable.gurujada.com. The demo showcases LiveTable’s performance and scalability by managing 1 Million rows with:
Real-time filtering
Multi-column sorting
CSV and PDF export capabilities
The demo application’s source code is hosted at Git Link for reference and learning purposes.
An advanced demo app to showcase livetable’s flexibility giving you complete control over the table, fields and queries is located at JOSAA App.
Josaa is the unified seat allocation board for engineering colleges in India. Students often struggle with choosing the right branch in the right college. This demo app helps to alleviate their problems by filtering colleges based on the student’s rank. All the datatables, card views in this app are powered by LiveTable.
We decided to pivot completely and give full control back to you, the developer:
Query Freedom
Define ANY Ecto query you want
Add filters to your custom queries
Full control over joins, conditions, and data transformation
Custom UI Mode
Completely replace our UI components with your own
Card mode with custom layouts and styling
Custom headers, content, and pagination components
Perfect for design systems and branded interfaces
Streams vs Assigns Choice
Use Phoenix streams for optimal performance
Or stick with traditional assigns if that fits your architecture
Seamless switching between modes
Transformers - The Game Changer
This is the most powerful feature we’ve added:
Complete query control with any input/DOM element
Custom sort orders via select menus
Complex filtering logic that was impossible before
Stateful filters that remember context across requests
URL State Persistence
The icing on the cake - URL remembers everything:
Filter states persist across page refreshes
Shareable URLs with exact table state
Bookmarkable filtered views
Works with all new features seamlessly
Real-World Success
We’re using this in production for an advanced college counselling platform with:
Complex rank calculations based on institution types
Multiple transformers working together
Custom header with integrated filtering UI
Card mode with rich college information display
This app serves as an advanced demo of LiveTable.
Check it out at Josaa App
Git Repo of Josaa App- Git Link
What This Means for You
Simple tables: Still incredibly easy with schema: parameter
Complex applications: Now possible with complete flexibility
Custom designs: Full UI control without fighting the framework
Business logic: Implement any filtering/sorting logic you need
The documentation has been completely rewritten with real-world examples, comprehensive API reference, and step-by-step guides.
The demo application has been moved to https://livetable.gurujada.com
v0.3 will be released on hex shortly. Check it out on git right now!
Excited to see what you all build with this!
What complex table requirements are you struggling with? We’d love to hear how these new features might help! Or any new feature requests!