Getting Started
Learn how to get setup and run your own component registry.
This guide will walk you through the process of setting up your own component registry.
It assumes you already have a project with components and would like to turn it into a registry.
registry.json
The registry.json
file is only required if you’re using the shadcn-ng
CLI to build your registry.
If you’re using a different build system, you can skip this step as long as your build system produces valid JSON files that conform to the registry-item schema specification.
Add a registry.json file
Create a registry.json
file in the root of your project.
{
"$schema": "https://ui.adrianub.dev/schema/registry.json",
"name": "acme",
"homepage": "https://acme.com",
"items": [
// ...
]
}
This registry.json
file must conform to the registry schema specification.
Add a registry item
Create your component
Add your first component. Here’s an example of a simple <HelloWorld />
component:
import { Component } from '@angular/core'
import { UbButtonDirective } from '~/components/ui/button'
@Component({
selector: 'HelloWorld',
imports: [UbButtonDirective],
template: `<button ubButton>Hello World</button>`
})
export default class HelloWorld { }
Note: This example places the component in the registry
directory. You
can place it anywhere in your project as long as you set the correct path in
the registry.json
file.
registry
└── hello-world
└── hello-world.ts
Add your component to the registry
To add your component to the registry, you need to add your component definition to registry.json
.
{
"$schema": "https://ui.adrianub.dev/schema/registry.json",
"name": "acme",
"homepage": "https://acme.com",
"items": [
{
"name": "hello-world",
"type": "registry:block",
"title": "Hello World",
"description": "A simple hello world component.",
"files": [
{
"path": "registry/hello-world/hello-world.ts",
"type": "registry:component"
}
]
}
]
}
You define your registry item by adding a name
, type
, title
, description
and files
.
For every file you add, you must specify the path
and type
of the file. The path
is the relative path to the file from the root of your project. The type
is the type of the file.
You can read more about the registry item schema and file types in the registry item schema docs.
Build your registry
Install the shadcn-ng CLI
npm install shadcn-ng
Add a build script
Add a registry:build
script to your package.json
file.
{
"scripts": {
"registry:build": "shadcn-ng build"
}
}
Run the build script
Run the build script to generate the registry JSON files.
npm run registry:build
Note: By default, the build script will generate the registry JSON files
in public/r
e.g public/r/hello-world.json
.
You can change the output directory by passing the --output
option. See the shadcn build command for more information.
Publish your registry
To make your registry available to other developers, you can publish it by deploying your project to a public URL.
Guidelines
Here are some guidelines to follow when building components for a registry.
- The following properties are required for the block definition:
name
,description
,type
andfiles
. - Make sure to list all registry dependencies in
registryDependencies
. A registry dependency is the name of the component in the registry eg.input
,button
,card
, etc or a URL to a registry item eg.http://localhost:4200/r/editor.json
. - Make sure to list all dependencies in
dependencies
. A dependency is the name of the package in the registry eg.zod
,ngx-sonner
, etc. To set a version, you can use thename@version
format eg.zod@^3.20.0
. - Imports should always use the
@/registry
or~/registry
path. eg.import { HelloWorld } from "@/registry/hello-world/hello-world"
orimport { HelloWorld } from "~/registry/hello-world/hello-world"
. - Ideally, place your files within a registry item in
components
,services
,lib
directories.
Install using the CLI
To install a registry item using the shadcn-ng
CLI, use the add
command followed by the URL of the registry item.
npx shadcn-ng@latest add http://localhost:4200/r/hello-world.json