Разработка кастомных Contentful Apps (расширений)

Наша компания занимается разработкой, поддержкой и обслуживанием сайтов любой сложности. От простых одностраничных сайтов до масштабных кластерных систем построенных на микро сервисах. Опыт разработчиков подтвержден сертификатами от вендоров.

Разработка и обслуживание любых видов сайтов:

Информационные сайты или веб-приложения
Сайты визитки, landing page, корпоративные сайты, онлайн каталоги, квиз, промо-сайты, блоги, новостные ресурсы, информационные порталы, форумы, агрегаторы
Сайты или веб-приложения электронной коммерции
Интернет-магазины, B2B-порталы, маркетплейсы, онлайн-обменники, кэшбэк-сайты, биржи, дропшиппинг-платформы, парсеры товаров
Веб-приложения для управления бизнес-процессами
CRM-системы, ERP-системы, корпоративные порталы, системы управления производством, парсеры информации
Сайты или веб-приложения электронных услуг
Доски объявлений, онлайн-школы, онлайн-кинотеатры, конструкторы сайтов, порталы предоставления электронных услуг, видеохостинги, тематические порталы

Это лишь некоторые из технических типов сайтов, с которыми мы работаем, и каждый из них может иметь свои специфические особенности и функциональность, а также быть адаптированным под конкретные потребности и цели клиента

Предлагаемые услуги
Показано 1 из 1 услугВсе 2065 услуг
Разработка кастомных Contentful Apps (расширений)
Средняя
~3-5 рабочих дней
Часто задаваемые вопросы

Наши компетенции:

Этапы разработки

Последние работы

  • image_website-b2b-advance_0.png
    Разработка сайта компании B2B ADVANCE
    1262
  • image_web-applications_feedme_466_0.webp
    Разработка веб-приложения для компании FEEDME
    1171
  • image_websites_belfingroup_462_0.webp
    Разработка веб-сайта для компании БЕЛФИНГРУПП
    874
  • image_ecommerce_furnoro_435_0.webp
    Разработка интернет магазина для компании FURNORO
    1094
  • image_crm_enviok_479_0.webp
    Разработка веб-приложения для компании Enviok
    831
  • image_bitrix-bitrix-24-1c_fixper_448_0.png
    Разработка веб-сайта для компании ФИКСПЕР
    851

Разработка кастомных Contentful Apps (расширений)

Contentful Apps — механизм расширения интерфейса редактора через iframe-приложения, которые монтируются в поля, боковую панель или целые экраны. Это не просто UI-виджеты: через Contentful App SDK приложение получает доступ к Entry API, Space API и может запускать App Actions — серверные функции, исполняемые в контексте Contentful.

Архитектура Contentful App

Каждое приложение состоит из двух частей: frontend (React/Vue/Vanilla JS, размещается на любом хостинге) и опциональный App Backend (AWS Lambda или любой HTTP-эндпоинт для App Actions и Events). Оба регистрируются в App Definition через Contentful Management API или Web App.

App Definition
  ├── Locations: field, sidebar, entry-editor, page, home
  ├── Parameters: instance params (per-field) + installation params (per-space)
  └── App Actions: serverless functions callable from UI or API

Типичные сценарии:

  • Кастомный field editor — например, цветовой пикер, связанный с дизайн-токенами из Figma
  • Sidebar extension — панель SEO-анализа, которая читает поля Entry в реальном времени
  • Page location — полноэкранный Asset Manager с интеграцией Cloudinary
  • App Actions — генерация AI-описаний через OpenAI при сохранении Entry

Разработка Field Extension

Инициализация SDK:

import { init, FieldExtensionSDK } from '@contentful/app-sdk';

init((sdk: FieldExtensionSDK) => {
  // Читаем текущее значение поля
  const value = sdk.field.getValue();

  // Подписываемся на изменения из внешних источников
  sdk.field.onValueChanged((newValue) => {
    setFieldValue(newValue);
  });

  // Обновляем значение
  sdk.field.setValue({ color: '#ff5500', token: 'brand-primary' });

  // Авторесайз iframe под контент
  sdk.window.startAutoResizer();
});

Для React-приложений удобнее @contentful/react-apps-toolkit:

import { useSDK, useFieldValue } from '@contentful/react-apps-toolkit';

const ColorPickerField = () => {
  const sdk = useSDK<FieldExtensionSDK>();
  const [value, setValue] = useFieldValue<string>();

  return (
    <ColorPicker
      value={value}
      onChange={(color) => setValue(color.hex)}
      tokens={sdk.parameters.installation.designTokens}
    />
  );
};

App Actions (серверная логика)

App Actions позволяют запускать серверный код из интерфейса Contentful без кастомного бэкенда — Contentful проксирует вызов на зарегистрированный endpoint:

// Регистрация App Action в App Definition (через CMA)
// callType: "request" | "event"
// url: https://your-backend.com/actions/generate-seo

// Вызов из frontend приложения
const result = await sdk.cma.appAction.callById({
  spaceId: sdk.ids.space,
  environmentId: sdk.ids.environment,
  appDefinitionId: sdk.ids.app,
  appActionId: 'generate-seo',
  parameters: {
    entryId: sdk.ids.entry,
    locale: sdk.locales.default,
  },
});

На стороне сервера (Node.js/Express):

app.post('/actions/generate-seo', async (req, res) => {
  // Верифицируем подпись Contentful
  verifySignature(req.headers['x-contentful-signature'], req.body);

  const { entryId, locale } = req.body.parameters;
  const entry = await cma.entry.get({ entryId });

  const seoData = await openai.chat.completions.create({
    model: 'gpt-4o',
    messages: [{ role: 'user', content: buildSeoPrompt(entry, locale) }],
  });

  res.json({ result: { seoTitle: seoData.choices[0].message.content } });
});

Installation Parameters и конфигурация

Параметры установки задаются один раз при инсталляции приложения в Space. Через них передаются API-ключи, токены, конфиги — без хардкода в коде приложения:

// Экран настроек приложения
const ConfigScreen = () => {
  const sdk = useSDK<AppExtensionSDK>();
  const [params, setParams] = useState(sdk.parameters.installation);

  sdk.app.onConfigure(() => ({
    parameters: params,
    targetState: {
      EditorInterface: {
        // Автоматически подключить к полям типа Symbol
        controls: [{ fieldId: 'seoTitle', widgetId: sdk.ids.app }],
      },
    },
  }));
};

Сборка и деплой

Contentful предоставляет CLI для локальной разработки и деплоя:

# Создание нового приложения по шаблону
npx create-contentful-app@latest my-app --template typescript

# Локальная разработка с туннелем
npm run start  # запускает на localhost:3000
contentful-app-scripts activate  # временно регистрирует localhost в App Definition

# Деплой на Contentful-хостинг (бесплатно для Apps)
npm run build
contentful-app-scripts upload  # загружает dist/ в Contentful CDN

Сроки и объём работ

Тип расширения Сложность Время разработки
Простой field editor (пикер, слайдер) Низкая 1–2 дня
Sidebar с внешним API Средняя 3–5 дней
Page location (полный экран) Высокая 1–2 недели
App Actions + серверный бэкенд Высокая 1–2 недели
Полноценное приложение с конфиг-экраном Высокая 2–3 недели

При разработке обязательно покрываем тестами с @contentful/app-sdk mock-объектами и настраиваем CI для автоматического деплоя через contentful-app-scripts upload.