An open API service indexing awesome lists of open source software.

https://github.com/google/react-schemaorg

Type-checked Schema.org JSON-LD for React
https://github.com/google/react-schemaorg

json-ld jsonld react schema-org schemaorg semantic-web typescript

Last synced: 11 months ago
JSON representation

Type-checked Schema.org JSON-LD for React

Awesome Lists containing this project

README

          

[![react-schemaorg npm version](https://badge.fury.io/js/react-schemaorg.svg)](https://www.npmjs.com/package/react-schemaorg) [![Node.js CI](https://github.com/google/react-schemaorg/actions/workflows/ci.yml/badge.svg)](https://github.com/google/react-schemaorg/actions/workflows/ci.yml) [![Coverage Status](https://coveralls.io/repos/github/google/react-schemaorg/badge.svg?branch=master)](https://coveralls.io/github/google/react-schemaorg?branch=master)

# react-schemaorg

Easily insert valid Schema.org JSON-LD in your React apps.

This library provides `` for plain React apps, and `helmetJsonLdProp()`
for use with [``](https://github.com/nfl/react-helmet).

Uses [schema-dts](https://github.com/google/schema-dts) for Schema.org
TypeScript definitions.

Note: This is not an officially supported Google product.

## Usage

Install [`react-schemaorg`](https://www.npmjs.com/package/react-schemaorg) and
your desired version of
[`schema-dts`](https://www.npmjs.com/package/schema-dts):

```sh
npm install schema-dts
npm install react-schemaorg
```

### Plain React Usage

To insert a simple JSON-LD snippet:

```tsx
import { Person } from "schema-dts";
import { JsonLd } from "react-schemaorg";

export function GraceHopper() {
return (

item={{
"@context": "https://schema.org",
"@type": "Person",
name: "Grace Hopper",
alternateName: "Grace Brewster Murray Hopper",
alumniOf: {
"@type": "CollegeOrUniversity",
name: ["Yale University", "Vassar College"],
},
knowsAbout: ["Compilers", "Computer Science"],
}}
/>
);
}
```

### Directly creating `` tags (for `next/head` and elsewhere)

Certain `<head>` management libraries require `<script>` tags to be directly
included, rather than wrapped in a component. This includes NextJS's
`next/head`, and `react-helmet`. With these, we can use the `jsonLdScriptProps`
export to do the same thing:

```tsx
import { Person } from "schema-dts";
import { jsonLdScriptProps } from "react-schemaorg";
import Head from "next/head";

export default function MyPage() {
return (
<Head>
<script
{...jsonLdScriptProps<Person>({
"@context": "https://schema.org",
"@type": "Person",
name: "Grace Hopper",
alternateName: "Grace Brewster Murray Hopper",
alumniOf: {
"@type": "CollegeOrUniversity",
name: ["Yale University", "Vassar College"],
},
knowsAbout: ["Compilers", "Computer Science"],
})}
/>
</Head>
);
}
```

### [React Helmet](https://github.com/nfl/react-helmet) Usage

To set JSON-LD in React Helmet, you need to pass it to the `script={[...]}` prop
array in the `Helmet` component:

```tsx
import { Person } from "schema-dts";
import { helmetJsonLdProp } from "react-schemaorg";
import { Helmet } from "react-helmet";

<Helmet
script={[
helmetJsonLdProp<Person>({
"@context": "https://schema.org",
"@type": "Person",
name: "Grace Hopper",
alternateName: "Grace Brewster Murray Hopper",
alumniOf: {
"@type": "CollegeOrUniversity",
name: ["Yale University", "Vassar College"],
},
knowsAbout: ["Compilers", "Computer Science"],
}),
]}
/>;
```

## Developers

Use NPM to install dependencies:

```sh
npm install
```

Use tsc to build:

```sh
tsc
```

To contribute changes, see [the CONTRIBUTING.md file](./CONTRIBUTING.md).