Home Next.js Working demo of a multi-select tag input using Next.js and Tailwind CSS

Working demo of a multi-select tag input using Next.js and Tailwind CSS

by therichpost
0 comments
Working demo of a multi-select tag input using Next.js and Tailwind CSS

Hello guys how are you? Welcome back to my blog. Today in this blog post I will show you Working demo of a multi-select tag input using Next.js and Tailwind CSS.

Live Demo

For react js new comers, please check the below links:

  1. Reactjs Tutorials
  2. Nextjs
  3. Bootstrap 5
  4. React Free Ecommerce Templates
  5. React Free Admins

Guys here is the code snippet and please use carefully:

Step 1: Create a New Next.js Project

If you haven’t already, create a new Next.js project:

npx create-next-app@latest my-multiselect-demo
cd my-multiselect-demo

Step 2: Install Necessary Dependencies

Install the necessary dependencies. For this example, we’ll use react-select, a popular library for creating multi-select components in React.

npm install react-select

Step 3: Create the Multi-Select Component

Create a new component called MultiSelect.js inside the components folder (you can create the folder if it doesn’t exist).

// components/MultiSelect.js
import React from 'react';
import Select from 'react-select';

const MultiSelect = ({ options, selectedOptions, onChange }) => {
  return (
    <Select
      isMulti
      value={selectedOptions}
      onChange={onChange}
      options={options}
      className="w-full"
      classNamePrefix="react-select"
    />
  );
};

export default MultiSelect;

Step 4: Apply Tailwind CSS Styles

Add some custom styles for the react-select component in your globals.css or directly in a component file if you are using module-based styling.

/* global.css */
.react-select__control {
  @apply border-gray-300 rounded-lg shadow-sm;
}

.react-select__multi-value {
  @apply bg-blue-500 text-white;
}

.react-select__multi-value__remove {
  @apply text-white hover:bg-blue-700;
}

Step 5: Use the Multi-Select Component in a Page

Open the page.js file and replace the content with the following code to use your MultiSelect component.

import { useState } from 'react';
import MultiSelect from '../components/MultiSelect';

export default function Home() {
  const options = [
    { value: 'tag1', label: 'Tag 1' },
    { value: 'tag2', label: 'Tag 2' },
    { value: 'tag3', label: 'Tag 3' },
    { value: 'tag4', label: 'Tag 4' },
  ];

  const [selectedOptions, setSelectedOptions] = useState([]);

  const handleChange = (selected) => {
    setSelectedOptions(selected);
  };

  return (
    <div className="min-h-screen bg-gray-100 flex items-center justify-center">
      <div className="w-full max-w-md mx-auto bg-white p-8 rounded-xl shadow-md">
        <h1 className="text-2xl font-bold mb-4">Multi-Select Tags</h1>
        <MultiSelect options={options} selectedOptions={selectedOptions} onChange={handleChange} />
        <div className="mt-4">
          <h2 className="text-lg font-semibold">Selected Tags:</h2>
          <ul>
            {selectedOptions.map((option) => (
              <li key={option.value} className="mt-2">
                {option.label}
              </li>
            ))}
          </ul>
        </div>
      </div>
    </div>
  );
}

Step 6: Run the Application

Finally, run your Next.js application:

npm run dev

Visit http://localhost:3000 in your browser to see the multi-select tags in action.

Working demo of a multi-select tag input using Next.js and Tailwind CSS
Working demo of a multi-select tag input using Next.js and Tailwind CSS

This setup provides a simple multi-select tag input using react-select styled with Tailwind CSS, integrated into a Next.js application. The component allows you to select multiple tags, and the selected options will be displayed below the multi-select input.

This is it guys and if you will have any kind of query, suggestion or requirement then feel free to comment below.

Thanks

Ajay

You may also like

Leave a Comment

This site uses Akismet to reduce spam. Learn how your comment data is processed.