React

React is one of the most popular libraries for web and native user interfaces. If you plan to render an API reference in React, we’ve got great news for you: There’s a React integration of our package to render OpenAPI documents and here’s how you can use it:

InstallationCopied!

npm install @scalar/api-reference-react

UsageCopied!

The API Reference package is written in Vue. That shouldn’t stop you from using it in React, though. We have created a client side wrapper in React:

[!WARNING]
This is untested on SSR/SSG!

import { ApiReferenceReact } from '@scalar/api-reference-react'
import '@scalar/api-reference-react/style.css'

function App() {
  return (
    <ApiReferenceReact
      configuration={{
        url: 'https://cdn.jsdelivr.net/npm/@scalar/galaxy/dist/latest.yaml',
      }}
    />
  )
}

export default App

We wrote a detailed integration guide for React, too.

ExampleCopied!

You can find an example in this repo under examples/react

PropsCopied!

ApiReference only takes one prop which is the configuration object.

configuration: ReferencePropsCopied!

You can find the full configuration options under packages/api-reference.

GuideCopied!

Create a new React project (optional)Copied!

There are tons of ways to set up a new React project. Here is an easy one using Vite to get you started:

We’re using pnpm here. You can also just use npm, yarn or whatever you're used to. ✌️

pnpm create vite my-awesome-app

You’ll see some questions that you can answer to your liking. We just picked React here:

? Select a framework: › - Use arrow-keys. Return to submit.
    Vanilla
    Vue
❯   React
    Preact
    Lit
    Svelte
    Solid
    Qwik
    Others

And we’re big TypeScript fans, but used plain JavaScript for the sake of this tutorial:

? Select a variant: › - Use arrow-keys. Return to submit.
    TypeScript
    TypeScript + SWC
❯   JavaScript
    JavaScript + SWC
    Remix ↗

Okay, your new React project is ready. Jump into the folder, install the dependencies and let’s go!

cd my-awesome-app
pnpm install
pnpm run dev

This boots your development server. Open http://localhost:5173/ to see the beautiful Vite/React example page. That wasn’t too hard, was it? :)

Render your OpenAPI document with ScalarCopied!

Cool, you’ve got your (existing) React project and want to render an API reference. That’s awesome! You’re just two steps away. First, install our package for React:

pnpm add @scalar/api-reference-react

And then, add a new component or just replace the App.jsx with the following content:

// src/App.jsx
import { ApiReferenceReact } from '@scalar/api-reference-react'

import '@scalar/api-reference-react/style.css'

function App() {
  return (
    <ApiReferenceReact
      configuration={{
        url: 'https://cdn.jsdelivr.net/npm/@scalar/galaxy/dist/latest.yaml',
      }}
    />
  )
}

export default App

Open http://localhost:5173/ and you should see your API reference. Done!