ЭТАП 1.2: Безопасное выделение бизнес-логики в хуки
- Create useSupplierSelection.ts: управление выбором поставщиков и поиском
- Create useProductCatalog.ts: загрузка и управление каталогом товаров
- Create useSupplyCart.ts: логика корзины и создания поставки
- Create useRecipeBuilder.ts: построение рецептур товаров (услуги + расходники)
Каждый хук инкапсулирует отдельную область ответственности:
- Состояние и действия изолированы
- GraphQL запросы сгруппированы по функциональности
- Бизнес-логика отделена от UI компонентов
- Полная типизация с TypeScript
No functional changes - pure logic extraction for better maintainability.
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
ЭТАП 1.1: Безопасное выделение интерфейсов и типов
- Create supply-creation.types.ts with all interfaces from create-suppliers-supply-page.tsx
- Establish modular folder structure: blocks/, hooks/, types/
- Define comprehensive TypeScript types for supply creation workflow
- Add props interfaces for future block components
- Include state management and action types
- Maintain full backward compatibility
No functional changes - pure type extraction for better maintainability.
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Remove unused FileText import from add-goods-modal.tsx
- Replace 'any' types with strict types (GoodsSupplier, GoodsProduct)
- Fix potential null pointer exceptions with optional chaining
- Mark unused variables with underscore prefix for linting compliance
- Improve debug logging (console.log → console.warn)
- Add safer form validation with explicit null checks
- Enhance code readability with proper type annotations
All changes are safe and improve code quality without functional impact.
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Add "ALWAYS APPLY ONLY SAFE FIXES" to mandatory principles in interaction-integrity-rules.md
- Include safety principle in session agreements in current-session.md
- Establish protection from risky modifications without explicit consent
- Ensure all changes prioritize system stability and code safety
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Обновлен CLAUDE.md с добавлением принципов качества кода
- Расширен interaction-integrity-rules.md новыми правилами взаимодействия
- Дополнен rules-complete.md техническими требованиями
- Добавлен демо-компонент вариантов кнопки "Назад" в UI Kit
- Обновлены компоненты админ панели и страницы создания расходников
- Уточнены visual-design-rules.md для компонента BackButton
- Исправлены ESLint ошибки и предупреждения
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Новый раздел 1.3 в interaction-integrity-rules.md
- Принципы профессионального подхода к настройке ESLint/линтеров
- Запрет на "заметание под ковер" и широкие паттерны игнорирования
- Алгоритм правильного решения проблем с конфигурацией
- Примеры правильных и неправильных подходов
- Обновлена краткая версия в CLAUDE.md
Правило основано на опыте исправления .eslintignore → точной настройки
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Удален ненужный .eslintignore (файлы уже не существовали)
- Настроен ESLint только для нужных папок: src/, prisma/, scripts/
- Добавлены конкретные служебные файлы в ignores вместо паттернов
- Более точная и профессиональная настройка линтера
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Обернул console.log в проверки development режима и заменил на console.warn
- Исправил типизацию в sidebar.tsx (убрал any types)
- Добавил точки с запятой в market-counterparties.tsx
- Исправил длинную строку в marketplace-api-step.tsx
- Исправил длинную строку в resolvers/index.ts
- Исправил unused parameter в referrals.ts
- Создал .eslintignore для исключения старых файлов
- Все изменения протестированы, сайт работает корректно
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
🛡️ Новые принципы:
- Качество кода важнее скорости разработки
- Pre-commit hooks существуют для защиты проекта
- Исправлять ошибки, а не обходить их
- Обход проверок создает технический долг
- Лучше потратить время на исправление, чем накапливать проблемы
📋 Добавлены подробные инструкции:
- Порядок действий при блокировке коммита
- Когда можно использовать --no-verify
- Как правильно работать с ошибками линтера
📁 Файлы:
- interaction-integrity-rules.md - детальные правила (раздел 1.2)
- CLAUDE.md - краткие принципы для быстрого доступа
🎯 Цель: Предотвращение обхода проверок качества кода в будущем
🚀 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Добавлена полная реферальная система с GraphQL резолверами и UI компонентами
- Улучшена система регистрации с поддержкой ВКонтакте и реферальных ссылок
- Обновлена схема Prisma для поддержки реферальной системы
- Добавлены новые файлы документации правил системы
- Улучшена система партнерства и контрагентов
- Обновлены компоненты авторизации для поддержки новых функций
- Удален устаревший server.log
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
## Что создано:
- logist-cabinet-rules.md - технические правила кабинета логистики по стандартизированной структуре
- Добавлена система тарификации с примерами UI
- Интерфейсы управления заявками и отслеживания доставок
- GraphQL API для логистики (queries, mutations, subscriptions)
## Что изменено в rules-complete.md:
- Раздел 12 "Кабинет логистики" сокращен до краткого описания со ссылкой на специализированный файл
- Убрано ~80 строк дублирующего контента
- Сохранена вся бизнес-логика workflow и статусов
## Что обновлено в CLAUDE.md:
- Добавлен logist-cabinet-rules.md в список кабинет-специфичных правил
- Добавлены автоматические триггеры для логистических задач
Файл следует стандартизированной структуре wholesale-cabinet-rules.md и обеспечивает модульность системы правил.
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Создан файл rules-complete-BACKUP.md как полная резервная копия
- Добавлено предупреждение о запрете редактирования без разрешения
- Файл содержит 3636 строк всех бизнес-правил системы
- Резерв создан для защиты от случайных изменений
⚠️ ВАЖНО: Файл rules-complete-BACKUP.md ЗАПРЕЩЕНО редактировать без явного разрешения пользователя\!
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Разделение rules-complete.md на специализированные файлы
- Создание interaction-integrity-rules.md с методологией работы Claude Code
- Создание wholesale-cabinet-rules.md с техническими деталями кабинета поставщика
- Обновление CLAUDE.md с новой структурой навигации по правилам
- Добавление автоматических триггеров для различных типов задач
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Реализована динамическая загрузка сайдбара с отключением SSR для предотвращения гидратационных расхождений
- Обновлен импорт компонента Sidebar для улучшения производительности и совместимости с клиентским рендерингом
- Реализован хук useEffect для отслеживания состояния монтирования компонента
- Оптимизировано условие скрытия сайдбара в зависимости от маршрута, состояния загрузки и аутентификации пользователя
- Устранен гидратационный рассинхрон при первом рендере
- Добавлен компонент AppShell в RootLayout для улучшения структуры
- Обновлен компонент Sidebar для предотвращения дублирования при рендеринге
- Оптимизированы импорты в компонентах AdvertisingTab и SalesTab
- Реализована логика кэширования статистики селлера в GraphQL резолверах
- Упорядочен импорт компонентов из 'lucide-react' и 'apollo/client'
- Исправлено значение атрибута value в SelectItem на "no-fulfillment" для корректного отображения отсутствия фулфилмент-центров
🤖 Generated with [Claude Code](https://claude.ai/code)
- Убран текст "(с рецептурой)" из названий товаров в корзине
- Добавлен раздел 9.2.6 в rules-complete.md с единым стандартом корзины
- Определены обязательные размеры, структура и функциональность
- Запрещено отображение технических суффиксов в UI корзины
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Add ignores for system folders (.next, node_modules, build, dist)
- Add ignores for config files (*.config.js, *.config.mjs)
- Speed up ESLint by excluding non-source files from checks
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Add pricePerUnit field to Supply model for seller pricing
- Fix updateSupplyPrice mutation to update pricePerUnit only
- Separate purchase price (price) from selling price (pricePerUnit)
- Fix GraphQL mutations to include organization field (CREATE/UPDATE_LOGISTICS)
- Update GraphQL types to make Supply.price required again
- Add comprehensive pricing rules to rules-complete.md sections 11.7.5 and 18.8
- Fix supplies-tab.tsx to show debug info and handle user loading
Architecture changes:
• Supply.price = purchase price from supplier (immutable)
• Supply.pricePerUnit = selling price to sellers (mutable by fulfillment)
• Warehouse shows purchase price only (readonly)
• Services shows/edits selling price only
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Добавлен раздел 17.3: Правила безопасности - разделение данных и функционала
- Новые критические запреты 24-26: запрет использования пользовательских данных в логике
- Расширен глоссарий: контекстно-зависимые термины для SupplyOrder
- Уточнена терминология: четкое разделение "Маркет" vs "Маркетплейс"
- Добавлены примеры безопасного и уязвимого кода
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Обновлена схема Prisma с новыми полями и связями
- Актуализированы правила системы в rules-complete.md
- Оптимизированы GraphQL типы, запросы и мутации
- Улучшены компоненты интерфейса и валидация данных
- Исправлены критические ESLint ошибки: удалены неиспользуемые импорты и переменные
- Добавлены тестовые файлы для проверки функционала
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>
- Добавлена автогенерация артикулов СФ (SF-T для товаров, SF-C для расходников)
- Добавлены поля для комплектов: количество и цена за комплект
- Добавлены поля учета движения товаров: заказано, в пути, остаток, продано
- Создан компонент статистики склада с общими показателями и разбивкой по типам
- Реализовано переключение между карточным и табличным режимом отображения (5 карточек в ряду)
- Обновлены GraphQL схемы для поддержки новых полей
- Улучшен пользовательский интерфейс: убран заголовок, оптимизирована компоновка
- Синхронизированы поля между карточками и таблицей для единообразного отображения
🤖 Generated with [Claude Code](https://claude.ai/code)
Co-Authored-By: Claude <noreply@anthropic.com>