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 🙏

© 2026 – Pkg Stats / Ryan Hefner

next-hybrid

v16.2.0-hybrid.2

Published

The React Framework

Readme

next-hybrid

Hybrid routing build of Next.js with support for hybrid route segments in the App Router (for example /house-in-[city]) and experimental AI Content Negotiation.

Features

Hybrid Routing

  • Hybrid segments combine static and dynamic parts in a single segment.
  • Routing priority remains: static > hybrid > dynamic > catch-all.
  • Works with the App Router layouts and params API.

AI Content Negotiation (Experimental)

  • Serve Markdown, JSON, Text, or LLM-optimized payloads from the same route.
  • Negotiate content via file extension (e.g. .md, .json, .txt, .llm) or Accept header.
  • Define experimentalGenerateAI in your page to produce these formats.

Create a new app (floating latest)

npm

npx create-next-app@latest my-app
cd my-app
npm install next@npm:next-hybrid
npm run dev

pnpm

pnpm create next-app@latest my-app
cd my-app
pnpm add next@npm:next-hybrid
pnpm dev

bun

bunx create-next-app@latest my-app
cd my-app
bun add next@npm:next-hybrid
bun run dev

Sanity check (package.json)

{
  "dependencies": {
    "next": "npm:next-hybrid",
    "react": "...",
    "react-dom": "..."
  }
}

Hybrid Routing Example

/house-in-nyc           -> static
/house-in-[city]        -> hybrid
/[slug]                 -> dynamic
/[...slug]              -> catch-all
/[[...slug]]            -> optional catch-all
// app/house-in-[city]/page.tsx
export default async function Page({ params }) {
  const { city } = await params
  return <h1>Houses in {city}</h1>
}

AI Content Negotiation Example

Define a page that exports experimentalGenerateAI:

// app/ai/[slug]/page.tsx
import type { ExperimentalAIContent, ExperimentalAIContentContext } from 'next/experimental'

export const experimentalAIFormats = ['markdown', 'json', 'text'] as const

export default function Page({ params }) {
  return <h1>HTML View</h1>
}

export async function experimentalGenerateAI(ctx: ExperimentalAIContentContext): Promise<ExperimentalAIContent> {
  const { slug } = ctx.params as { slug: string }
  return {
    markdown: `# Content for ${slug}`,
    json: { slug, type: 'generated' },
    text: `Content for ${slug}`
  }
}

Access via File Extensions

  • /ai/foo -> HTML
  • /ai/foo.md -> Markdown
  • /ai/foo.json -> JSON
  • /ai/foo.txt -> Text
  • /ai/foo.llm -> LLM JSON (if supported)

Access via Accept Headers

You can also specify the Accept header to negotiate the content type:

# Get Markdown content
curl -H "Accept: text/markdown" http://localhost:3000/ai/foo

# Get JSON content
curl -H "Accept: application/json" http://localhost:3000/ai/foo

# Get Text content
curl -H "Accept: text/plain" http://localhost:3000/ai/foo

# Get LLM-optimized JSON content
curl -H "Accept: application/llm+json" http://localhost:3000/ai/foo

Repository

https://github.com/pablofdezr/next.js

Links

📦 https://www.npmjs.com/package/next-hybrid 🔧 https://github.com/pablofdezr/next.js