Apidog

All-in-one Collaborative API Development Platform

API Design

API Documentation

API Debugging

API Mocking

API Automated Testing

How to Use Shadcn/UI in React.js

Learn how to use Shadcn/UI in React.js to build customizable and lightweight interfaces. Discover how to integrate it with Apidog for easy API management and testing. Perfect for developers looking to enhance their React.js projects!

Ashley Innocent

Updated on November 12, 2024

Building modern and sleek user interfaces is one of the main goals for front-end developers, and with the rise of component libraries, that task has become even easier. Today, I’m going to introduce you to Shadcn/UI, a powerful and customizable component library for React.js. Whether you’re new to React.js or a seasoned developer, Shadcn/UI can enhance your app’s design without the usual bloat of larger frameworks. Plus, I’ll walk you through the setup step-by-step, including how to leverage APIs and tools like Apidog to make development smoother.

By the end of this post, you’ll have a clear understanding of how to use Shadcn/UI in your React.js project. And, if you’re building out your own API or working with one, don’t forget to download Apidog for free—it’s a lifesaver when testing and developing APIs.

button

Let’s get started!

What is Shadcn/UI?

Before diving into the setup, let’s first define what Shadcn/UI is and why it’s a solid choice for your React.js project.

Shadcn/UI is a customizable component library built specifically for React.js. Unlike larger frameworks like Material UI or Bootstrap, Shadcn/UI focuses on giving you more control over the look and feel of your components. It provides you with basic building blocks, allowing you to create a unique interface without being tied to pre-defined themes.

Why Shadcn/UI?

  1. Lightweight: Unlike heavy libraries that bundle tons of components you’ll never use, Shadcn/UI provides only what you need.
  2. Customizable: You can style and structure the components according to your project’s unique requirements.
  3. Optimized for React.js: Seamless integration with React.js means you can focus on writing code rather than tweaking configurations.
  4. APIs Ready: The library is compatible with API tools like Apidog, making it easier to manage and test API endpoints within your React app.

Step-by-Step Guide: How to Use Shadcn/UI in Your React.js Project

Now that you know what Shadcn/UI is, let’s go through the step-by-step process of integrating it into a React.js project. This guide assumes you already have a basic understanding of React and that you have Node.js installed on your machine.

1. Create a New React.js Project

If you already have a React.js project set up, you can skip this step. Otherwise, you can create a new project using the following commands:

npx create-react-app my-shadcn-ui-app
cd my-shadcn-ui-app
npm start

This will create a new React.js project named my-shadcn-ui-app and start the development server. Now, you should see the default React app up and running.

2. Install Shadcn/UI

Add dependencies to your project manually.

Add Tailwind CSS

Components are styled using Tailwind CSS. You need to install Tailwind CSS in your project.

Follow the Tailwind CSS installation instructions to get started.

Add dependencies

Add the following dependencies to your project:

npm install tailwindcss-animate class-variance-authority clsx tailwind-merge

Add icon library

If you're using the default style, install lucide-react:

npm install lucide-react

If you're using the new-york style, install @radix-ui/react-icons:

npm install @radix-ui/react-icons

Configure path aliases

I use the @ alias. This is how I configure it in tsconfig.json:tsconfig.json

{
  "compilerOptions": {   
	"baseUrl": ".",
        "paths": {
        "@/*": ["./*"]
        }
    }
}

The @ alias is a preference. You can use other aliases if you want.

If you use a different alias such as ~, you'll need to update import statements when adding components.

You can now start adding components to your project.

3. Import and Use Shadcn/UI Components

Let’s jump into the fun part—adding some Shadcn/UI components to your React.js app. In your src/App.js file, you can start by importing and using one of Shadcn/UI’s components, such as the button component.

Here’s an example:

import React from 'react';
import { Button } from 'shadcn-ui';

function App() {
  return (
    <div className="App">
      <header className="App-header">
        <h1>Welcome to My Shadcn/UI App</h1>
        <Button variant="primary">Click Me!</Button>
      </header>
    </div>
  );
}

export default App;

The Button component from Shadcn/UI is imported and used in the App component. You can use various props to customize it. In this case, we’re using the variant="primary" prop to give the button a primary styling.

4. Customize the Shadcn/UI Theme

One of the best parts of Shadcn/UI is its customizability. You can tweak the components to match your app’s unique design language.

Shadcn/UI allows you to define a custom theme that can be applied globally. Here’s how to do that:

a) Create a Custom Theme File

First, create a new file called theme.js in your src directory. In this file, you’ll define your custom theme as follows:

const theme = {
  colors: {
    primary: '#ff6347', // Tomato color
    secondary: '#4caf50', // Green color
  },
  fonts: {
    body: 'Arial, sans-serif',
    heading: 'Georgia, serif',
  },
};

export default theme;

b) Apply the Theme to Your Components

Now that you have your custom theme defined, you can apply it to your components using the ThemeProvider component. Update your src/App.js file as follows:

import React from 'react';
import { Button, ThemeProvider } from 'shadcn-ui';
import theme from './theme';

function App() {
  return (
    <ThemeProvider theme={theme}>
      <div className="App">
        <header className="App-header">
          <h1>Welcome to My Shadcn/UI App</h1>
          <Button variant="primary">Click Me!</Button>
        </header>
      </div>
    </ThemeProvider>
  );
}

export default App;

In this updated code, we’ve imported ThemeProvider from Shadcn/UI and wrapped our app inside it, passing the custom theme as a prop.

5. Managing APIs with Apidog in Your Shadcn/UI + React Project

Now that your front-end is looking great with Shadcn/UI, it’s time to make it functional by connecting it to an API. This is where Apidog comes in handy. If you haven’t heard of Apidog before, it’s a robust API management tool that simplifies API testing, documentation, and collaboration between developers.

Why Use Apidog with Your React.js App?

  • API testing made easy: You can test your API endpoints right inside your React project.
  • Seamless collaboration: Apidog lets you generate and share API documentation with your team.
  • Speed up development: Easily mock API responses to speed up the development process.

Using Apidog for API Calls

Let’s say you’re building a React.js app that fetches data from a weather API. Here’s how you could use Apidog to manage the API calls:

Step 1: Open Apidog and create a new request.

Apidog

Step 2: In the test editor, enter the URL of your API endpoint, select the HTTP method, and add any headers, parameters, or body data that you need. For example, you can test the route that returns a simple message that we created earlier:

Apidog

Step 3: Click on the Send button and see the result of your test. You should see the status code, the response time, and the response body of your API. For example, you should see something like this:

Apidog

Apidog is a great tool for testing your APIs, as it helps you ensure the quality, reliability, and performance of your web services. It also saves you time and effort, as you don’t need to write any code or install any software to test your APIs. You can just use your browser and enjoy the user-friendly interface and features of Apidog.

6. Best Practices for Using Shadcn/UI and Apidog in React.js

Here are some best practices you should follow to get the most out of Shadcn/UI and Apidog:

  • Optimize performance: Use only the Shadcn/UI components you need to keep your bundle size small.
  • Modularize your components: Break down your UI into small, reusable components.
  • Test your APIs: Use Apidog to thoroughly test your API endpoints and ensure they are working as expected.
  • Use version control: Regularly commit your changes to avoid losing progress and to collaborate effectively with your team.

Conclusion: Building React.js Apps with Shadcn/UI and Apidog

Congratulations! You now have all the knowledge you need to use Shadcn/UI in your React.js projects. From setting up the library to customizing the components, you’ve seen how easy it is to create beautiful UIs. And with Apidog, managing your API calls becomes a breeze.

Remember, whether you’re building an internal tool or a customer-facing application, Shadcn/UI gives you the flexibility to create something unique, while Apidog helps streamline your API workflow.

P.S. If you're working on APIs, don't forget to download Apidog for free—it will save you hours of development and testing time!

button

How to Import/Export Collection Data in PostmanTutorials

How to Import/Export Collection Data in Postman

In this article, we will discuss how to import/export Postman collections and explore alternative method to fix it, which offer more flexibility without any restrictions on the number of runs.

David Demir

December 9, 2024

How to Install Newman and Run Postman Collections in NewmanTutorials

How to Install Newman and Run Postman Collections in Newman

By following this guide, you will learn how to install Newman and execute Postman collections, enabling you to automate your API testing process. A recommend Apidog as a powerful alternative.

David Demir

December 5, 2024

How to Fetch GraphQL with API?Tutorials

How to Fetch GraphQL with API?

Discover how to fetch GraphQL data efficiently using the Fetch API and Apidog. Learn advanced techniques, optimize performance, and secure your API for robust applications. Download Apidog for free to streamline your API workflows.

Ashley Innocent

November 28, 2024