Настройка локализации контента Payload CMS

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

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

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

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

Предлагаемые услуги
Показано 1 из 1 услугВсе 2065 услуг
Настройка локализации контента Payload CMS
Простая
от 1 рабочего дня до 3 рабочих дней
Часто задаваемые вопросы

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

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

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

  • 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

Локализация контента в Payload CMS

Payload поддерживает многоязычный контент на уровне полей: каждое помеченное как localized поле хранит отдельные значения для каждой локали. В PostgreSQL это колонка с JSONB-объектом {ru: "...", en: "...", uk: "..."}.

Конфигурация локалей

// payload.config.ts
export default buildConfig({
  localization: {
    locales: [
      { label: 'Русский', code: 'ru' },
      { label: 'English', code: 'en' },
      { label: 'Українська', code: 'uk' },
    ],
    defaultLocale: 'ru',
    fallback: true,  // если перевода нет — использовать дефолтную локаль
  },
})

Локализованные поля

// collections/Posts.ts
fields: [
  {
    name: 'title',
    type: 'text',
    localized: true,  // отдельное значение для каждой локали
    required: true,
  },
  {
    name: 'content',
    type: 'richText',
    localized: true,
  },
  {
    name: 'slug',
    type: 'text',
    localized: true,  // slug тоже можно локализовать
    unique: true,
  },
  {
    name: 'featuredImage',
    type: 'upload',
    relationTo: 'media',
    // НЕ localized — одно изображение для всех локалей
  },
]

Запросы с локалью

// Получить посты на русском
const posts = await payload.find({
  collection: 'posts',
  locale: 'ru',
})

// Получить пост на всех языках сразу
const allLocales = await payload.findByID({
  collection: 'posts',
  id: postId,
  locale: 'all',
})
// allLocales.title = { ru: '...', en: '...', uk: '...' }

// REST API:
// GET /api/posts?locale=en
// GET /api/posts/123?locale=all

Интеграция с Next.js i18n

// app/[locale]/posts/[slug]/page.tsx
import { getPayload } from 'payload'
import { notFound } from 'next/navigation'

type Locale = 'ru' | 'en' | 'uk'

export default async function PostPage({
  params,
}: {
  params: { locale: Locale; slug: string }
}) {
  const payload = await getPayload({ config })

  const result = await payload.find({
    collection: 'posts',
    locale: params.locale,
    where: {
      and: [
        { slug: { equals: params.slug } },
        { _status: { equals: 'published' } },
      ],
    },
  })

  if (!result.docs[0]) notFound()
  return <PostPage post={result.docs[0]} />
}

export async function generateStaticParams() {
  const payload = await getPayload({ config })
  const locales: Locale[] = ['ru', 'en', 'uk']
  const params: { locale: Locale; slug: string }[] = []

  for (const locale of locales) {
    const posts = await payload.find({ collection: 'posts', locale, limit: 1000 })
    posts.docs.forEach(post => {
      if (post.slug) params.push({ locale, slug: post.slug as string })
    })
  }
  return params
}

Сроки

Настройка локализации для 3 языков с адаптацией существующих коллекций и Next.js роутинга — 1–2 дня.