- B1: Next.js 15 + Payload CMS 3.0 + Postgres 16, ESLint, Prettier, Husky, Vitest - B2: 9 collections, 6 globals, 12 Page Builder blocks, access control, slugify/revalidate hooks - B3: ezy.com.ua payments, Binotel HMAC webhook, leads API, Telegram bot, Resend email, rate limiting - B4: Tariffs collection with ezy API sync (cron + manual), dynamic pricing source-of-truth - B5: 13 test files covering unit libs and all API routes - B6: Dockerfile multi-stage, docker-compose.prod.yml, nginx.conf SSL, GitHub Actions CI/CD, health endpoint - B7: docs/admin-guide-ua.md (marketer guide), docs/deploy.md (VPS instructions), README quickstart Co-Authored-By: Claude Sonnet 4.6 <noreply@anthropic.com>
22 lines
697 B
TypeScript
22 lines
697 B
TypeScript
import type { GlobalConfig } from 'payload'
|
|
import { isAdminOrEditor } from '@/access/isAdminOrEditor'
|
|
import { revalidateGlobalAfterChange } from '@/hooks/revalidatePath'
|
|
|
|
export const Header: GlobalConfig = {
|
|
slug: 'header',
|
|
access: { read: () => true, update: isAdminOrEditor },
|
|
hooks: { afterChange: [revalidateGlobalAfterChange] },
|
|
fields: [
|
|
{ name: 'logo', type: 'upload', relationTo: 'media' },
|
|
{ name: 'logoAlt', type: 'text' },
|
|
{
|
|
name: 'navLinks',
|
|
type: 'array',
|
|
fields: [
|
|
{ name: 'label', type: 'text' },
|
|
{ name: 'href', type: 'text' },
|
|
{ name: 'openInNewTab', type: 'checkbox', defaultValue: false },
|
|
],
|
|
},
|
|
],
|
|
}
|