Hackathon has ended.
HotTable
This is an (minimal) Airtable clone. We left out any of the schema-building functionality and focused squarely on the data management functionality. Moreover, we pushed hard on using semantic HTML, so the table is an actual <table>. Within the space of data management, there are a surprising number of features however:
- Manage which fields are displayed
- Sort by any field in either direction (with multi-column sorting supported as well)
- Filter by any complex query you can imagine (nested ANDs and ORs supported with a full range of predicates)
- Group by any field (sorting in either direction, collapsing or expanding the grouped rows)
- Select rows (with clear visual indication of selected rows)
- Select all rows in the dataset (with clear visual indication of how many records are selected)
- Bulk export selected rows (with whatever display/sort/filter conditions are set on the view)
- Full pagination functionality (select number of items displayed per page, jump to a specific page, see the details of the pagination window)
- Column summaries (see information about the dataset for particular columns, with calculations based on the data-type of the column)
- X- and Y-axis scrollable table on overflow, with fixed headers, footers, and primary columns
- Quick sort, group, hide options for each column in a column header dropdown
- Inline editing of all table cells
- CRUD of views, saving your configuration of a particular combination of fields, sorts, filters, grouping, and pagination
HotTable
Berlin
data:image/s3,"s3://crabby-images/297e8/297e8bf89af09f6d7ba081b3de6bc4d8cd917222" alt=""
data:image/s3,"s3://crabby-images/3dcdd/3dcddfdeeeaa31d7a0c07aa9d936be88be402c37" alt=""
data:image/s3,"s3://crabby-images/ba490/ba490e12207695a50bbe467699a0b1559c0c7904" alt=""
Built with:
- Ransack drives the filtering and sorting. We extended Ransack to drive the fields and grouping.
- Pagy drives the pagination. We applied Tailwind styling to the generated HTML.
- Stimulus drives the "details set" (only one <details> element open at a time), automatic form submission of pagination items, building complex sorts/filters, etc.
- Turbo Drive allows all of the "searching" to run without a mess of updating dozens of parts of the page on any change.
- Turbo Streams drive the column calculations and inline editing to allow for atomic updates of individual table cells.
- Phlex replaces Action::View as our frontend library, allowing us to build layouts, pages, and components all in pure Ruby.
- TurboPower drives key parts of the inline editing flow.
- TailwindCSS for styling
Application Screenshots
data:image/s3,"s3://crabby-images/d39eb/d39eb67c35e97436ab43e49656222a152ccd697b" alt=""
data:image/s3,"s3://crabby-images/86852/86852c05ce5c227d8c35d35555908383faa522ea" alt=""
data:image/s3,"s3://crabby-images/4a219/4a2197f674160e8e0ad5f02ce13002ca91a6b548" alt=""
data:image/s3,"s3://crabby-images/4e13d/4e13d3ebb02a818bdbd6f68bae90cd2403f17a5a" alt=""
data:image/s3,"s3://crabby-images/7f1c7/7f1c79e3383b61dd6f81a52ce046bb5ba3356eb4" alt=""
data:image/s3,"s3://crabby-images/f7431/f7431765c917c616b4796b586a3139721db973e2" alt=""
data:image/s3,"s3://crabby-images/e4df1/e4df128b910867da73252a3a8b405acf07d99f4e" alt=""
data:image/s3,"s3://crabby-images/9faa2/9faa26547c8b9375519b277243664d0477071e21" alt=""
data:image/s3,"s3://crabby-images/01c6e/01c6eebb985a1b49e95338c3a680d6dd6a8568e9" alt=""