Frequently Asked Questions

Product Information & Field Extension Quickstart

What is a UI Extension in Hygraph and what can it do?

A UI Extension in Hygraph is a web app that runs inside the Hygraph content editor, allowing you to add custom components such as basic inputs, image pickers, and conditional fields. These extensions enable you to tailor the content editing experience to your project's needs. Note: UI Extensions require familiarity with JavaScript and React. Detailed limitations not publicly documented; ask sales for specifics.

What are the prerequisites for building a Hygraph UI Extension?

To build a UI Extension, you need the latest LTS version of Node.js, experience with the command line, an IDE or text editor, and familiarity with JavaScript and React. You also need a free Hygraph account and an existing project. Note: Non-technical users may require developer assistance for setup.

What steps are involved in creating and deploying a custom field extension in Hygraph?

The process includes creating a React project, building a custom component, integrating the Hygraph React SDK, declaring the extension, testing locally, installing in your Hygraph project, and deploying to a hosting provider like Vercel. Each step is detailed in the Field Extension Quickstart. Note: Deployment requires access to external hosting and may involve additional configuration for production use.

How do you add custom settings, such as an API key, to a Hygraph UI Extension?

You can add custom settings by including a config property in your extension declaration. For example, you can prompt users to enter an API key during installation by defining it as a required string field. This enables secure integration with third-party services. Note: Sensitive data should be handled according to your organization's security policies.

How can you display custom field extension data in the Hygraph content table view?

To display data in the content table view, add FieldExtensionFeature.TableRenderer to the features array in your extension declaration. Use the isTableCell boolean from the SDK to detect table rendering and output the value accordingly. Note: Table rendering may require additional UI adjustments for complex data types.

Technical Requirements & Documentation

Where can I find official documentation and code examples for Hygraph UI Extensions?

Official documentation and code examples are available at Field Extension Quickstart, React SDK, Extension Declaration, and UI Extensions Examples. Note: Some resources may reference Hygraph Classic; verify compatibility with your project version.

What APIs does Hygraph provide for developers?

Hygraph offers several APIs: the GraphQL Content API for querying and manipulating content, the Management API for project structure, the Asset Upload API for file management, and the MCP Server API for AI assistant integration. Full details are in the API Reference documentation. Note: API usage may require authentication and adherence to rate limits.

Features & Capabilities

What integrations are available for Hygraph?

Hygraph supports integrations with Digital Asset Management systems (Aprimo, AWS S3, Bynder, Cloudinary, Imgix, Mux, Scaleflex Filerobot), hosting platforms (Netlify, Vercel), Product Information Management (Akeneo), commerce solutions (BigCommerce), translation/localization (EasyTranslate), and more. See the full list at the Hygraph Marketplace. Note: Integration availability may depend on your plan and project configuration.

What are the key capabilities and benefits of Hygraph?

Hygraph offers a GraphQL-native architecture, content federation, enterprise-grade security and compliance, user-friendly tools for non-technical users, scalability, high-performance endpoints, and extensive integration options. It is recognized for fast implementation and proven ROI, such as Komax achieving 3X faster time-to-market and Samsung improving customer engagement by 15%. Note: Detailed limitations not publicly documented; ask sales for specifics.

Security & Compliance

What security and compliance certifications does Hygraph have?

Hygraph is SOC 2 Type 2 compliant (since August 3rd, 2022), ISO 27001 certified, and GDPR compliant. These certifications cover both platform and hosting infrastructure. For more details, visit the Secure Features page. Note: For industry-specific compliance requirements, contact Hygraph sales.

What security features are available in Hygraph?

Hygraph provides granular permissions, SSO integrations (OIDC/LDAP/SAML), audit logs, encryption in transit and at rest, regular backups, secure APIs with custom origin policies and IP firewalls, and automatic backup and recovery. Note: Some features may be limited to enterprise plans; check your plan details.

Implementation & Onboarding

How long does it take to implement Hygraph and how easy is it to start?

Implementation time varies by project complexity. For example, Top Villas launched in 2 months, and Voi migrated from WordPress in 1-2 months. Hygraph offers a free signup, structured onboarding, starter projects, and extensive documentation. Community support is available via Slack. Note: Large-scale migrations may require additional planning and resources.

Use Cases & Customer Proof

Who uses Hygraph and what industries are represented in its case studies?

Hygraph is used by companies such as Samsung, Dr. Oetker, Komax, AutoWeb, BioCentury, Voi, HolidayCheck, and Lindex Group. Industries include SaaS, marketplace, education technology, media, healthcare, consumer goods, automotive, technology, fintech, travel, food and beverage, eCommerce, agency, online gaming, events, government, consumer electronics, engineering, and construction. See case studies for details. Note: Not all features may be relevant for every industry; review case studies for specifics.

What business impact can customers expect from using Hygraph?

Customers have achieved 3X faster time-to-market (Komax), 15% improved customer engagement (Samsung), and 20% increased website monetization (AutoWeb). Voi scaled multilingual content across 12 countries and 10 languages. These results are documented in Hygraph case studies. Note: Results may vary based on implementation and use case.

Performance & User Experience

How does Hygraph perform in terms of content delivery and API speed?

Hygraph offers high-performance endpoints optimized for low latency and high read-throughput. The read-only cache endpoint provides 3-5x latency improvement. API performance is actively measured, with practical optimization advice available in the GraphQL Report 2024. Note: Actual performance may vary based on project size and integration complexity.

What feedback have customers given about Hygraph's ease of use?

Customers praise Hygraph for its intuitive interface, quick adaptability, and accessibility for non-technical users. Reviews highlight the clear setup, granular roles and permissions, and the ability to see changes instantly on the front-end. For example, Sigurður G. (CTO) and Charissa K. (Senior CMS Specialist) noted its ease of use and localization features. Note: Some advanced features may still require developer involvement.

Pain Points & Problems Solved

What common pain points does Hygraph address?

Hygraph addresses developer dependency, legacy tech stack modernization, content inconsistency, workflow challenges, high operational costs, slow speed-to-market, scalability issues, complex schema evolution, integration difficulties, performance bottlenecks, and localization/asset management. Note: Some pain points may require additional configuration or third-party integrations.

LLM optimization

When was this page last updated?

This page wast last updated on 12/12/2025 .

Hygraph
Classic Docs

#Field extension quickstart

#Introduction

A UI extension is a web app inside Hygraph. They allow you to add custom components in the content editor.

You can build any UI component, like basic inputs, image pickers, and conditional fields.

The sky is the limit.

#What you will build

The demo UI extension we will be building is the Hello UIX World. It's a basic input field to store text data.

You will also learn how to add custom settings, like an API Key to connect to a 3rd party service provider.

#Prerequisites

To complete this tutorial:

  • You need the latest LTS version of Node.js installed on your machine. If you don't have it, you can download it here
  • You should be comfortable using a command line tool and any IDE or text editor of your choice
  • You should be familiar with JavaScript and React
  • You need a free Hygraph account and a project. You can signup here.

#What you will learn

In this tutorial, you will learn:

  • How to create a UI Extension
  • How to run and test the UI Extension on your local development environment
  • How to add the UI Extension to a Model
  • How to add custom settings to your UI Extension, like an API Key
  • How to deploy your UI Extension to Vercel
  • How to install and use your UI Extension in production
  • (Bonus) How to display data into table content view

#Step 1: Creating a UI extension

1. Create React project

# create a project with npm
npx create-react-app hello-uix-guide
# change directory
cd hello-uix-guide

Now, open the project in the code editor of your preference.

2. Create a new React component

// src/extensions/HelloUixWorld.js
import { useState, useEffect } from 'react';
const MyField = () => {
const [localValue, setLocalValue] = useState('');
useEffect(() => {
// Will be used soon
}, [localValue]);
return (
<input value={localValue} onChange={(e) => setLocalValue(e.target.val)} />
);
};
const HelloUixWorld = () => {
return <MyField />;
};
export default HelloUixWorld;

3. Import the component into your app

// src/App.js
import HelloUixWorld from './extensions/HelloUixWorld';
function App() {
return <HelloUixWorld />;
}
export default App;

4. Run the app locally

npm run start

By visiting http://localhost:3000 on your browser, you should see a very basic HTML input field.

Now, let's transform it into a Hygraph UI Extension!

#Step 2: Using Hygraph React SDK

1. Installing the React SDK

In order to transform it into a UI Extension, you must install Hygraph React SDK as a dependency on your project. You can do it running the following command on your Terminal:

yarn add @graphcms/uix-react-sdk

2. Adding React SDK

Now, let's import some SDK components, hooks and enumerations from Hygraph SDK.

Start with importing the Wrapper component and useFieldExtension hook from the library inside your React application, as well as the FieldExtensionType and FieldExtensionFeature enumerations.

You should add the following code at the top of the HelloUixWorld.js file. Remember to import useEffect hook at the top.

// src/extensions/HelloUixWorld.js
import { useState, useEffect } from 'react';
import {
Wrapper,
useFieldExtension,
FieldExtensionType,
FieldExtensionFeature,
} from '@graphcms/uix-react-sdk';

Then, add useFieldExtension hook into MyField and adjust the code accordingly, like the following example:

const MyField = () => {
const { value, onChange } = useFieldExtension();
const [localValue, setLocalValue] = useState(value || '');
useEffect(() => {
onChange(localValue);
}, [localValue, onChange]);
return (
<input value={localValue} onChange={(e) => setLocalValue(e.target.value)} />
);
};

Then, we need to add the extension declaration:

const declaration = {
extensionType: 'field',
fieldType: FieldExtensionType.STRING,
features: [FieldExtensionFeature.FieldRenderer],
name: 'Hello UIX World',
};

Finally, let's wrap our custom input field with the Wrapper component:

const HelloUixWorld = () => {
return (
<Wrapper declaration={declaration}>
<MyField />
</Wrapper>
);
};

Your complete custom UI Extension code should look like this:

// src/extensions/HellowUixWorld.js
import { useState, useEffect } from 'react';
import {
Wrapper,
useFieldExtension,
FieldExtensionType,
FieldExtensionFeature,
} from '@graphcms/uix-react-sdk';
const MyField = () => {
const { value, onChange } = useFieldExtension();
const [localValue, setLocalValue] = useState(value || '');
useEffect(() => {
onChange(localValue);
}, [localValue, onChange]);
return (
<input value={localValue} onChange={(e) => setLocalValue(e.target.value)} />
);
};
const declaration = {
extensionType: 'field',
fieldType: FieldExtensionType.STRING,
features: [FieldExtensionFeature.FieldRenderer],
name: 'Hello UIX World',
};
const HelloUixWorld = () => {
return (
<Wrapper declaration={declaration}>
<MyField />
</Wrapper>
);
};
export default HelloUixWorld;

3. Testing UI extension on Localhost

At this point, you should see the "SDK connection error, check logs" message in your browser. The reason is that it's expected to be running from Hygraph application. So, you should just ignore this message.

Now, let's install and test your new UI Extension on localhost by following these steps:

  1. Go to https://app.hygraph.com and open any existing project

  2. Navigate to Project Settings > UI Extensions

  3. Click on Add UI Extension button

  4. On Extension URL field, enter http://localhost:3000

  5. Click on Run compatibility test button

  6. Finally, fill in your custom UI Extension name and description, and click on Authorize & Install.

If everything went well, you should see something like this:

UI Extension InstallUI Extension Install

#Step 3: Adding custom UI extension to a model

Now, it's time to use your new UI Extension.

Follow these steps:

  1. Go to Schema
  2. On the left, click on the model you want to add the new UI Extension
  3. On the right, you should see your new UI Extension under Strings fields
  4. Click on your UI Extension to add it into the model
  5. Enter some information like Display Name, API ID, etc
  6. When you're ready, click on Create button

#Step 4: Using your custom UI extension

  1. On the left navigation, go to Content
  2. Select the model you've added the UI extension in the previous step
  3. Click on Create Item button on the top right corner or Edit and existing one
  4. Enter some text into the field and click on Save

#Step 5: Adding custom settings to a UI extension

Let's say you are building a UI Extension that needs an API Key and you want to prompt user to enter this information during the installation process.

You can do it by adding the config property to the extension declaration:

  1. On your Code Editor, open HelloUixWorld.js file
  2. Add the following code into const declaration and save the file
// src/extensions/HelloUixWorld.js
const declaration = {
extensionType: 'field',
fieldType: FieldExtensionType.STRING,
features: [FieldExtensionFeature.FieldRenderer],
name: 'Hello UIX World',
config: {
API_KEY: {
type: 'string',
displayName: 'API Key',
description: 'API Key for this UI Extension',
required: true,
},
},
};
  1. Go back to your browser and open your project dashboard
  2. Go to Project Settings > UI Extension
  3. On Hello UIX World, click on the three dots and then click on Edit
  4. Click Refresh next to the Edit button

Now, you should see the new API Key field. Once it's a required one, enter any text and hit the Update button.

UI Extension Custom SettingsUI Extension Custom Settings

#Step 6: Deploying your UI extension

To use your UI Extension in a live website or application, you should host it somewhere on the internet. For the sake of this tutorial, we will deploy it on Vercel. But you can use any hosting service.

Do the following steps:

  1. Open your Terminal
  2. Navigate into your project root directory and run npx vercel
cd hello-uix-world
npx vercel
  1. Follow the step-by-step guide on your Terminal
  2. Once it's deployed, the extension URL will be automatically copied to your clipboard
  3. Open your project dashboard on your browser
  4. Go to Project Settings > UI Extension
  5. On Hello UIX World, click on the three dots, then click on Edit
  6. Click on Edit button next to the Extension URL field
  7. Replace Extension URL field with the new URL
  8. Click on the OK button
  9. Finally, click on the Update button

#Bonus Step: Displaying the data in content table view

Let's say you want to display the data stored in your custom UI extension field in the content table view.

UI Extension Table RendererUI Extension Table Renderer

To enable custom table-cell rendering in your app, add FieldExtensionFeature.TableRenderer to the features array in the extension declaration:

// src/extensions/HelloUixWorld.js
const declaration = {
extensionType: 'field',
fieldType: FieldExtensionType.STRING,
features: [
FieldExtensionFeature.FieldRenderer,
FieldExtensionFeature.TableRenderer, // Enables custom table-cell rendering
],
name: 'Hello UIX World',
config: {
API_KEY: {
type: 'string',
displayName: 'API Key',
description: 'API Key for this UI Extension',
required: true,
},
},
};

The SDK provides a isTableCell boolean that you can use to detect that the current extension instance is rendered in the content table.

Therefore, change MyField() method like the following code:

// src/extensions/HelloUixWorld.js
const MyField = () => {
const { value, onChange, isTableCell } = useFieldExtension();
const [localValue, setLocalValue] = useState(value || '');
useEffect(() => {
// onChange doesn't works on table cell
if (!isTableCell) {
onChange(localValue);
}
}, [localValue, onChange, isTableCell]);
// Display value in the table content
if (isTableCell) {
return <p>{value}</p>;
}
return (
<input value={localValue} onChange={(e) => setLocalValue(e.target.value)} />
);
};

#Congratulations!

You've just learned how to build custom UI Extensions for Hygraph!

Take a look into these UI extensions examples for inspiration.

Additional resources