2026-04-02 17:01:22 +03:00
|
|
|
# Next.js Template
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
Шаблон проекта на Next.js, построенный по [стайлгайду](https://gromlab.ru/docs/nextjs-style-guide).
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
## Стек
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
- **Next.js 16** — фреймворк
|
|
|
|
|
- **React 19** / **TypeScript 5** — UI и типизация
|
|
|
|
|
- **Mantine UI 8** — компоненты
|
|
|
|
|
- **Zustand 5** — глобальное состояние
|
|
|
|
|
- **SWR 2** — получение данных
|
|
|
|
|
- **PostCSS Modules** — стили
|
|
|
|
|
- **Biome** — линтер и форматтер
|
|
|
|
|
- **clsx** — конкатенация CSS-классов
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
## Архитектура
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
Проект использует кастомизированный FSD (Feature-Sliced Design):
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
```
|
|
|
|
|
src/
|
|
|
|
|
├── app/ # Роутинг Next.js, провайдеры, глобальные стили
|
|
|
|
|
├── screens/ # Собранные страницы (UI)
|
|
|
|
|
├── layouts/ # Каркасы и шаблоны страниц
|
|
|
|
|
├── widgets/ # Крупные самостоятельные блоки интерфейса
|
|
|
|
|
├── features/ # Пользовательские сценарии
|
|
|
|
|
├── entities/ # Бизнес-сущности
|
|
|
|
|
└── shared/ # Переиспользуемый код (UI, утилиты, типы)
|
|
|
|
|
```
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
Зависимости идут строго сверху вниз: `app` -> `screens` -> `layouts` -> `widgets` -> `features` -> `entities` -> `shared`.
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
## Быстрый старт
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
```bash
|
|
|
|
|
npx tiged git@gromlab.ru:templates/nextjs.git my-app
|
|
|
|
|
cd my-app
|
|
|
|
|
npm install
|
|
|
|
|
npm run dev
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
|
## Генерация кода
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
Модули создаются из шаблонов `.templates/`:
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
```bash
|
|
|
|
|
npx @gromlab/create component button src/shared/ui
|
|
|
|
|
npx @gromlab/create feature auth src/features
|
|
|
|
|
npx @gromlab/create widget header src/widgets
|
|
|
|
|
npx @gromlab/create entity user src/entities
|
|
|
|
|
npx @gromlab/create layout admin src/layouts
|
|
|
|
|
npx @gromlab/create screen profile src/screens
|
|
|
|
|
npx @gromlab/create store auth src/shared/model
|
|
|
|
|
```
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
## Скрипты
|
init: шаблон Next.js приложения
- Next.js 16 + React 19 + TypeScript
- Mantine UI + PostCSS Modules
- Biome (линтинг и форматирование)
- Zustand, SWR
- Структура FSD (screens, widgets, features, entities, shared)
- Шаблоны генерации (.templates/): component, screen, feature, widget, entity, layout, store
- Конфигурация VS Code (расширения, настройки)
- CSS-токены (цвета, отступы, радиусы, медиа)
- Open Graph метаданные
- Тестовый home screen с Mantine
2026-03-28 22:11:43 +03:00
|
|
|
|
2026-04-02 17:01:22 +03:00
|
|
|
| Команда | Описание |
|
|
|
|
|
|---|---|
|
|
|
|
|
| `npm run dev` | Запуск dev-сервера |
|
|
|
|
|
| `npm run build` | Сборка для продакшена |
|
|
|
|
|
| `npm run start` | Запуск продакшен-сервера |
|
|
|
|
|
| `npm run lint` | Проверка кода (Biome) |
|
|
|
|
|
| `npm run format` | Форматирование кода (Biome) |
|