paint-brush
An Intro to Data Tables On Railsby@sameer1612
5,889 reads
5,889 reads

An Intro to Data Tables On Rails

by Sameer KumarJuly 1st, 2021
Read on Terminal Reader
Read this story w/o Javascript
tldt arrow

Too Long; Didn't Read

Using Ruby on Ruby on Rails, we can hook up datatable in UI and exchange data without page refresh. This article is written considering the reader is fresher to rails, so, reserving in-depth exploration for part 2. The author is a Sr. engineer at Sedin Technologies, India, working as Sr. Sameer Kumar: https://www.linkedin.com//sameer1612/datatable-demo. Kumar: "You can call me the world's happiest engineer. I’ll definitely write on it soon"

People Mentioned

Mention Thumbnail

Companies Mentioned

Mention Thumbnail
Mention Thumbnail
featured image - An Intro to Data Tables On Rails
Sameer Kumar HackerNoon profile picture

You are a developer full of joy and enthusiasm toward changing the world, writing ninja codes driving million-dollar businesses every day. Maybe you have to write code for displaying customer/products/orders data in a table and you spend a month writing pagination, sorting, searching, async fetching and blah-blah. Well, let me help you then by opening the gates to datatables.

Introduction

Since you already are an awesome developer, I’ll skip the formal introduction, and let’s get started by knowing how our new friend is going to help us:

  1. You don’t need to loop through @orders and display each object in your view file.
  2. No table or list tags need to be implemented and managed explicitly.
  3. No backend logic needs to be put in your controllers for sorting and filtering data displayed.
  4. Uniformity for all such tabular implementations.
  5. Lesser the code, the Happier the developer. 💁

Setup

1. rails new tables -T

# -T
skips testing from your application. We won’t need it for our demo app.

2. Add the following gems in your Gemfile:

ajax-datatables-rails

jquery-datatables

3. Let's quickly scaffold a model, say, the Customer:

rails g scaffold customer name age city gender

4. Time to scaffold a datatable for our lovely customers:

rails g datatable Customer

Let’s start implementing datatable now. Our target to hook up datatable in UI and exchange data without page refresh.

First, we’ll modify app/views/customers/index.html.erb as:

Well, since this is just a demo, let’s go the dirty way and hook scripts right in our view files. But, beware if you do in your actual application, Hell is a sure thing for you.

What you need to notice here is that we are using a table tag with a data-source attribute assigned to UsersController’s index route. Rest we don't need to provide any data in the table body. After all, if we do everything, what datatable is for.

Now, its time for putting some logic in the datatable file we generated earlier, our app/datatables/customer_datatable.rb will now look like this:

  • view_columns: These are actual binding for the data you are going to display. The source key is essential for any operation on data. By default, all columns are sortable and searchable, so this is the place where you can enable or disable properties on the column.
  • data: This method essentially generates all the entries which are going to go in the table we created earlier. This is the place where you can customize your data. For example, let's say if we want to color-code genders as pink and blue text, we can easily put a ternary in place of record.gender and surround each case with some HTML tags.
  • get_raw_records: This is the source of data. records variable which you saw in the data method gets its value from the query we run here.

Let’s try to run now

👉 Github codes for this demo: https://github.com/sameer1612/datatable-demo

That’s all Folks! Easy Peezy.

I am planning to write on Ruby on Rails, every Sunday. 🙌
👉 This article is written considering the reader is fresher to rails, so, reserving in-depth exploration for part 2. Stay Tuned!

If you have any doubts, put them in the comments, I’ll answer asap. Also, if you want to know about some specific topic, do mention it, I’ll definitely write on it soon.

If you want to connect:

👉 Sameer Kumar: https://www.linkedin.com/in/sameerkumar1612/

Also published on Medium subdomain: https://sameer1612.medium.com/datatable-on-rails-e371fe5a747d