Building apps for people is an experiment in human behavior. We strive to make iterations easier and fun. User experience is the integral part of an application, micro interactions play a vital role in forming a better user experience. In this article we’ll be looking at one such micro interaction, which is to build a smart and super easy-to-use multi select checkboxes.
Often NextJS is used to build dashboards and admin panels for its reactive approach. In many such apps there is an option to perform bulk operations on elements, like bulk deletion of posts, bulk updating of statuses and more. Applications like Gmail do it in an interactive way to make it easier to select multiple items without going one by one which would take the user an eternity to complete!
Pro tip: Learn how to manage cookie based auth for a multi-tenant NextJS application →
Setting up the project
In this article I’ll be creating a simple NextJS application. Personally I prefer NextJS as the primary framework for all my React apps as it comes with so many options.
So lets get started by creating the NextJS project,
This will get you a project codebase with all the dependencies installed and ready for you. Let’s go and create a simple page for us to put lists and checkboxes.
Before we proceed, we need to have the data for our app; a list of something that we can act upon. In our case let it be the list of posts that we need to do some bulk operation on.
We’re going to create a simple JSON data for the purpose of this article, but this data can be source from anywhere like APIs or the database itself in your application.
Now lets create the ReactJS component and loop the JSON data to form the list.
With this you’ll get the basic skeleton of the application with a post list and a checkbox for each item in the list.
Now let us add the select functionality, for this we need to create a state which will hold all the selected item’s IDs and display it in a status section.
Initialize a new state selectedIDs
Add an onChange
event for the checkboxes to update the selectedIds state every time we check a checkbox.
In the handleChange
function check if the current event is check or uncheck event and update the selectedIds state accordingly.
Lets add a status section on selected items counter to show how many posts have been selected.
Finally putting it all together we’ll get something like below as our post list with multi select.
Now comes our secret recipe of the process which is to add ability to do multi select like how Gmail or file explorers do.
We should be able select multiple checkboxes by clicking and holding the Shift
key on the keyboard.
There are two things we need to do here,
- When the check box is clicked we need to check if the
Shift
key is pressed - Get the last checked item and currently checked item and all the ones in-between
After implementing these two the handleChange
event will look like like this,
So now when you select a checkbox and hold shift and select another checkbox below, the items in between will be selected and all of them will also be added to the selectedIds
state. You can send this to the server to perform any bulk operation.
Here’s everything with all the bells and whistles implemented on FeatureOS’s dashboard.
Subscribe to our newsletter
Get the latest updates from our team delivered directly to your inbox.
Related Posts
How we migrated our Rails 6 app from AWS RDS to Planetscale
The story of how we ran away from AWS RDS to Planetscale for our Rails 6 app. Sort of a love letter to Planetscale.
How to disable Tailwind CSS Prose class for code and pre tags
Learn how to disable Tailwind CSS Prose typography class for pre and code blocks when using Rehype.
How we migrated to Radix UI on NextJS and Tailwind
This is a guide of how we migrated to Radix UI on NextJS and Tailwind CSS. Our journey and experience towards moving to Radix UI.