TypeScript
You're viewing Unhead v3 beta documentation. Install with unhead@beta
Recipes

Custom Nodes

Quick Answer: Create custom Schema.org nodes by passing a plain object to useSchemaOrg(). Use @type for the schema type and any valid Schema.org properties.

Why Create Custom Schema.org Nodes?

If you need to add a node that isn't officially implemented, you can provide it yourself. This is useful for:

  • Niche schema types not covered by built-in helpers
  • Emerging schema types not yet added to the library
  • Highly specific industry schemas

Custom nodes are plain objects following the Schema.org specification.

import { useSchemaOrg } from '@unhead/schema-org/typescript'

useSchemaOrg([
  {
    '@type': 'SingleFamilyResidence',
    'numberOfRooms': 3,
    'occupancy': 5,
    'numberOfBathroomsTotal': 2,
    'floorSize': '2000 sqft',
    'petsAllowed': true,
  }
])

How Do I Add TypeScript Support for Custom Nodes?

Use schema-dts for full TypeScript support with custom nodes.

import type { DefinedTerm } from 'schema-dts'
import { useSchemaOrg } from '@unhead/schema-org/typescript'

useSchemaOrg([
  <DefinedTerm> {
    '@type': 'DefinedTerm',
    'name': 'Unhead Schema.org',
    'description': 'Unhead Schema.org is a library for adding Schema.org to your application.',
    'inDefinedTermSet': {
      '@type': 'DefinedTermSet',
      'name': 'Schema.org Libraries',
    },
  }
])
Did this page help you?