npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@linktr.ee/registry

v0.0.9

Published

Component registry for LinkApps

Downloads

641

Readme

LinkApp Component Registry

Component registry for LinkApps using the shadcn/ui registry system.

Components

  • Button - Versatile button component with multiple variants
  • Switch - Toggle switch component for on/off states

Development

# Install dependencies
npm install

# Build the registry
npm run registry:build

# Start dev server
npm run dev

Building the Registry

The registry uses the shadcn CLI to build component JSON files:

npm run registry:build

This will generate JSON files in public/r/ directory:

  • public/r/button.json
  • public/r/switch.json
  • public/r/utils.json

Deploying to Vercel

The registry is configured to deploy to Vercel as a static site.

Prerequisites

  1. Install Vercel CLI globally:
npm install -g vercel
  1. Login to Vercel:
vercel login

Deployment Steps

  1. Navigate to the registry directory:
cd packages/registry
  1. Build the registry:
npm run registry:build
  1. Deploy to Vercel:
npm run deploy

Or use Vercel CLI directly:

# Deploy to preview
vercel

# Deploy to production
vercel --prod

First-Time Setup

When deploying for the first time, Vercel will ask:

  • Set up and deploy: Yes
  • Which scope: Select your account/team
  • Link to existing project: No (for first deployment)
  • Project name: Accept default or choose a custom name
  • Directory: ./ (current directory)
  • Override settings: No

Custom Domain (Optional)

After deployment, you can configure a custom domain:

  1. Go to your project in Vercel Dashboard
  2. Navigate to Settings > Domains
  3. Add your custom domain (e.g., registry.linktr.ee)
  4. Follow the DNS configuration instructions

Environment Configuration

By default, the linkapp add command uses http://localhost:3001/r for local development.

To use your deployed registry:

  1. Option 1: Environment Variable

Set the registry URL in your LinkApp project:

# In your LinkApp project .env file
LINKAPP_REGISTRY_URL=https://your-registry.vercel.app/r
  1. Option 2: Command Line Flag
linkapp add button --registry https://your-registry.vercel.app/r
  1. Option 3: Update Default in Code

Modify packages/linkapp/src/commands/add.ts to change the DEFAULT_REGISTRY constant.

Using Components in LinkApps

Once the registry is deployed, developers can install components using:

# Using the linkapp CLI
linkapp add button
linkapp add switch

# Or using a custom registry URL
npx shadcn@latest add https://registry.linktr.ee/r/button.json

Adding New Components

  1. Create your component in registry/default/ui/[component-name].tsx
  2. Add the component definition to registry.json
  3. Run npm run registry:build
  4. Test the component installation

Registry Structure

packages/registry/
├── lib/
│   └── utils.ts              # Utility functions
├── registry/
│   └── default/
│       └── ui/
│           ├── button.tsx    # Button component
│           └── switch.tsx    # Switch component
├── public/
│   └── r/                    # Generated registry JSON files
├── components.json           # shadcn configuration
├── registry.json            # Registry definition
└── package.json

License

UNLICENSED - © Linktree