DEV Community

Cover image for Quickly build UI components with AI
Obisike Treasure for Hackmamba

Posted on

Quickly build UI components with AI

Meta: Learn how to quickly build and customize UI components with AI. Save time on tedious tasks and focus on engaging design.

Building UI components usually means writing a lot of code from scratch, fixing minor bugs, and working closely with designers to bring static designs to life. It’s always time-consuming, with you manually handling every detail, from layout to performance tweaks.

AI is now changing how you can approach building UI elements. Instead of spending hours on repetitive tasks, you can use AI tools to quickly build and refine your UI components.

In this guide, you’ll learn how to build and customize UI elements, create style guides, and develop more complex UIs using AI. By the end, you'll see how tools like Cody reduce the time and effort involved in your UI development.

Prerequisites

To follow along with this tutorial, you’ll need the following:

Once these are in place, you'll need to set up the development environment.

Setting up the environment

You’ll need to set up a React project, install Cody on your VSCode editor, and use Cody to configure TailwindCSS. This setup will serve as your development environment. Check out this GitHub repository to see the full project you'll be building.

Let’s start by creating the React project.

Creating your React project

To create your React project, open your terminal and run the following command:

yarn create vite cody-react --template react-ts
Enter fullscreen mode Exit fullscreen mode

This command initializes a new React project with TypeScript, creating a project folder named cody-react in your current directory.

Next, open the project folder in your VSCode editor. Once it's open, you can proceed to install and configure Cody.

Steps to install and configure Cody

To set up Cody on your VSCode editor, start by installing Cody’s VSCode extension.

Screenshot of the Cody’s extension on VSCode

Next, you’ll have to sign up to be able to use Cody on your VSCode. Select your preferred sign-up method to continue and complete the account creation flow.

Screenshot of the Sign in buttons on the Cody’s extension

For additional information, you can refer to the Cody documentation.

To improve your workflow and avoid the need to rewrite prompts multiple times, utilize Cody's custom commands. This will allow you to apply the same prompts across all the components you create, saving you time and effort.

Let's set up some of Cody's custom commands.

Setting up the Cody commands

To create custom commands in your workspace, follow these steps:
First, open the VS Code Command Palette by pressing Ctrl + Shift + P (Windows/Linux) or Cmd + Shift + P (Mac). Type Cody Menu: Custom Commands and select it.

Screenshot of the VSCode Command Pallete

In the Cody commands menu, select Custom Commands > New Custom Command.

Screenshot of the New Custom Command selection

Enter a descriptive name for your new custom command, such as ui-components-creator.

Screenshot of the entering the name for your custom command

Next, select the “ask” mode since you’ll mostly be using the Cody chat.

Screenshot of the section to select Ask mode

After that, enter the instructions that Cody will use when executing the command. You'll be creating two commands, and here are the detailed instructions for each:

  • For the ui-components-creator command, use the following prompt:
    You are an expert in React+Tailwind+TS UI component design. Design the component. Note: Do not use template literals for tailwind classes.

  • For the ui-components-customizer command, use the following prompt:
    You are an expert in React+Tailwind+TS component design. Customize the component to follow the design system defined in the tailwind.config.js file, create variants based on sizes and colors, and also add things like the hover and active states. Note: Do not use template literals for tailwind classes.

For this project, the ui-components-creator command will be used to generate the basic UI components, while the ui-components-customizer command will be used to customize these components to align with the design system.

Screenshot of the section to enter the prompt

Choose one or more options for the context Cody should use to generate responses. This should include the Current File, Selected Code, and the Current Directory.

Since you’re setting up the command for just this workspace, select the User Settings option.

Screenshot of the seection to save the cody command

Press Enter to finalize the creation of your custom command. For further information, you can refer to the documentation;

Here is how your custom commands should look in your VSCode workspace settings:

// .vscode/cody.json
{
   "ui-components-creator": {
     "prompt": "You are an expert in React+Tailwind+TS UI component design. Design the component. Note: Do not use template literals for tailwind classes.",
     "context": {
        "selection": true,
        "currentFile": true,
        "currentDir": true
     },
     "mode": "ask"
  },
  "ui-component-customizer": {
     "prompt": "You are an expert in React+Tailwind+TS component design. Customize the component to follow the design system defined in the tailwind.config.js file, create variants based on sizes and colors, and also add things like the hover and active states. Note: Do not use template literals for tailwind classes.",
     "context": {
       "selection": true,
       "currentFile": true,
       "currentDir": true,
    },
    "mode": "ask"
  }
}
Enter fullscreen mode Exit fullscreen mode

Next, let’s set up Tailwind CSS in your development environment.

Setting up Tailwind CSS for your development environment

To set up Tailwind CSS on the project, you'll need to install Tailwind CSS and its peer dependencies. This can be done by running the command.

yarn install -D tailwindcss postcss autoprefixer
Enter fullscreen mode Exit fullscreen mode

With the dependencies installed, generate the Tailwind configuration files. This is easily done by executing the command below:

npx tailwindcss init -p
Enter fullscreen mode Exit fullscreen mode

This command will create both tailwind.config.js and postcss.config.js files in your project.

To ensure Tailwind can remove unused styles in production, open the tailwind.config.js file and specify the paths to all your template files. Your configuration should look something like this:

module.exports = {
  content: [
    "./src/**/*.{js,jsx,ts,tsx}",
  ],
  theme: {
    extend: {},
  },
  plugins: [],
};
Enter fullscreen mode Exit fullscreen mode

Next, you need to add Tailwind’s directives to your CSS. Create a CSS file in the src directory, for example, src/index.css, and include the following directives:

@tailwind base;
@tailwind components;
@tailwind utilities;
Enter fullscreen mode Exit fullscreen mode

Import this CSS file into your React application by adding import './index.css'; to your src/index.js or src/index.tsx file.

For more detailed information, you can refer to the Tailwind CSS documentation.

Next, you’ll need to set up your Tailwind CSS theme configuration, which will serve as the design guide for your components. This configuration will include defining colors, padding, and other style properties. For this tutorial, we’ll be using the following color codes: #00CBEC, #A112FF, and #FF5543.

Navigate to your tailwind.config.json file. Use Opt + K (or Alt + K on Windows) to open Cody’s Edit Command interface. Highlight all the content of the file.

The project’s existing Tailwind Configuration

Next, enter the following prompt:

Update the Tailwind configuration to include the colors #00CBEC, #A112FF, and #FF5543, along with custom fonts, spacing, and other design systems elements like border-radius, box shadows, and breakpoints.

Then click Submit.

Addition of a prompt to Cody to edit the project’s tailwind.config file

After that, review and Accept the changes proposed by Cody.

Accept generated code from Cody to edit the project’s tailwind.config file.

Once you’ve successfully set up tailwind on your project, let’s create the UI components.

Creating basic UI components

A good UI is built with components like buttons, switches, text inputs, progress bars, tabs, and many more. These elements are the core of a UI design system and shape the user experience.

Traditionally, creating these components involves manually writing the code, which can be time-consuming, especially when handling multiple components. Cody simplifies this by generating code for a component directly within your project.

You’ll build the following components:

  • Button: Allows users to perform actions by clicking.
  • Switch: This lets users toggle between different states.
  • Text input: Allows users to enter text.
  • Progress bar: Shows the progress of an operation.
  • Tabs: Organizes high-level content.

To build these components with Cody, start by creating a dedicated components directory. Then, create a .tsx file for each component, such as Switch.tsx or TextInput.tsx. Let's begin by creating the button component.

Creating the button component

Here’s how to create a button component with Cody:

Note: The steps for creating this button can be used to create other UI elements.

After creating your Button.tsx file, open a new Cody chat by right-clicking on the code editor, selecting the Cody option from the menu, and choosing New Chat in Editor.

Cody chat right-click option.

Alternatively, you can click the Cody icon. If an existing conversation is open, click New Chat to start a new one.

Cody's VS Code extension icon selection

Next, click the Prompts and select the ui-components-creator option on the palette.

Cody's prompt selection

Then click the play icon or press Enter.

Cody's play icon selection

Cody will then generate the required code for the component, which you can review.

Cody's code generation

Next, click Apply to add the code to the file.

Apply Cody's generated code

Then click Accept to accept the modifications made to the file.

Accept Cody's generated code.

Here is the code generated by Cody:

Be sure to save the changes in the file.
This is how the component would look.

View of the button component

The switch component

The switch component lets users toggle between different states on your website or your application. It's a straightforward way to turn features or settings on and off, with clear visual feedback showing the current state.
Once you have created your Switch.tsx component file, follow the same steps used when creating the button component.

This is the react component code generated by Cody:

Here is how the component is going to look.

View of the switch component

The text input component

The text input component allows users to enter the text on a website or an application.
In your created TextInput.tsx component file, follow the steps illustrated in the first button component example.

The generated code is as follows.

This is the input component designed by Cody.

View of the text input component

The progress bar component

A progress bar component shows that the application has received a user's request and is moving closer to carrying out a requested action from that user.
In the ProgressBar.tsx you created, replicate the procedures shown in the initial button component example.

See the code example generated by Cody:

This generates the output:

View of the progress bar component

The tabs component

A tab component organizes high-level content in an application and supports switching between views, data sets, or functional aspects of the application.
In your created Tabs.tsx component file, apply the steps demonstrated in the button component example.

Cody generates the following:

View of the Tabs component

Customizing your UI components

A consistent design enhances user experience. Customizing your components to follow a design pattern is crucial for achieving this consistency. Here's how to do it using Cody.

The button component

A button component for a design system must have variants such as size and color. Let's get Cody to do this. Since you’ve created the prompt to handle the customization request, all you need to do is follow the following steps:

First, open the Button.tsx component file. Then, open a New Chat in Editor by following the previously highlighted steps.

Cody chat

On the chat field, type in @. This brings out a list of files you can select from to add the file as context to your prompt. Select the tailwind.config.js file.

Selecting the tailwind config using the @ command

Next, click Prompts and select the ui-components-customizer option.

Selecting the ui-component-customizer command

Then press Enter.

Code generated by the ui-component-customizer command

Review the generated code, apply the changes, and accept them.

Accepting generated code

Note: You can choose to accept some of the changes, depending on what you want.

Here is the final code update for the button.

This is how the button looks afterward.

View of the button component with the design system

Customizing the switch component

To customize the switch component, first, open the Switch.tsx file so Cody can add it to its prompt context. Then, start a new chat by following the same steps you used earlier when customizing the buttons.
Just like with the button customization, add the tailwind.config.js file to the chat's context, then select the ui-component-customizer command from the prompts.
Cody will generate this:

Here is the final look of the switch component.

View of the switch component with the design system

Customizing the text input component

Similar to the switch component, follow the steps used in customizing the component, then apply and accept the changes from Cody.

Generated TextInput component code from Cody

After applying and accepting the code changes, you’ll notice that on line 3, there is a typescript error. You can use Cody to rectify this.

To do this, hover over the underlined error to display the menu.

Display of errors in the generated TextInput component code from Cody

Next, click Quick Fix.

Selecting the Quick Fix option in the generated TextInput component code

Then click Ask Cody to Fix.

Selecting the Ask Cody to Fix option in the generated TextInput component code

Once that is completed, accept the changes Cody suggested.

Accepting the Cody Fix option in the generated TextInput component code

Here is the final result.

Also, here is the final output of the modifications.

View of the input component with the design system

You can repeat similar steps for the Progress Bar and the Tabs components.
Here is the progress bar customized look.

View of the progress bar component with the design system

And here is the new tab component.

View of the tab component with the design system.

Building complex UI component systems

Now that you’ve generated the basic UI components and customized them to match your design system, you can combine these components to create a complete user interface. You can achieve this by referencing the components via their files using the @ key within your prompt.

To demonstrate, let’s create a login and register UI using all the components you created.
Navigate to your App.tsx file and open a new chat in the editor.

Cody chat referencing the App.tsx file.

Next, add all your component files and the tailwind.config.json file in the chat section.

Cody chats with the component files added to the Cody’s context.

Then add the following prompt:

You are an expert in designing UI pages. You are good with react+tailwind+ts. Use the components and images from free sources like Unsplash to design a login and register UI. The login and register should be separate using the Tabs and the progress bar should calibrate when the form is being filled. Once a form field is filled out, the progress should be increased on the progress bar, and the terms and conditions should switch, too.
Enter fullscreen mode Exit fullscreen mode

Next, apply the changes to your App.tsx.

Cody's chat prompt for generating a login and register UI.

After applying and accepting the changes, save the file, and then on your terminal, run the following command to start your application.

npm run dev
Enter fullscreen mode Exit fullscreen mode

This starts the react development server at localhost.

View of the Login and Register components.

As you can see, the image is broken. You can use Cody to fix it.
Navigate to the <img> tag on the App.tsx file and highlight it.

Selecting the <img/> tag in the generated code.

Use the Opt + K command (on Mac) or the Alt + K command (on Windows) to bring out Cody’s Edit Code interface. Then, enter the following prompt.

Replace the src with "https://images.pexels.com/photos/27582545/pexels-photo-27582545/free-photo-of-neon-lights.jpeg"
Enter fullscreen mode Exit fullscreen mode

Next, accept and save the changes.

Replacing the image on the generated code

Here is the final code generated by Cody.

This is how the page looks.

Final View of the Login Screen

Watch the video to see the Login and Register screen designed by Cody using the components.

Now that you have completed the UI, you can enhance it further by adding more context to your prompt to specify how you want your UI to look. Feel free to experiment with different prompts that you come up with.

Final thoughts

Throughout this article, you've seen how Cody can transform how you build UI components, from basic buttons to complex, dynamic systems. Cody handles the heavy lifting so you can focus on crafting good UI/UX designs. Whether you’re customizing components or managing complex UI systems, Cody provides the tools to make the process faster and more efficient.

Now, it's your turn to put these capabilities into practice. Here are a few ideas to get you started:

  • E-commerce product page: Create a responsive product page with a carousel, product details, and an "Add to Cart" button.
  • Dashboard interface: Build a dashboard with interactive charts, data tables, and navigation tabs.
  • Form validation: Design a multi-step form with real-time validation and progress indicators.
  • Landing page: Develop a landing page with a hero section, feature highlights, and a call-to-action button.

Experiment with these projects and see how Cody can assist you in building faster and improving your development workflow. Sign up now to build UIs faster with Cody.

Top comments (2)

Collapse
 
ash_arutam_3fce868e24bbd6 profile image
Ash Arutam

more effective use ready UI frameworks

Collapse
 
otrex profile image
Obisike Treasure

Thanks for the suggestion!
UI frameworks are definitely handy, but sometimes custom components are needed for unique designs or specific project requirements. Plus, using Cody makes building custom UIs faster and easier.