Особенности проектирования под Битрикс Александр Сербул Руководитель направления контроля качества интеграции и внедрений @AlexSerbul Прежде всего… Пройти курсы (http://dev.1c-bitrix.ru/learning/): Администратор. Базовый Администратор. Модули Администратор. Бизнес Администратор «1С-Битрикс: Корпоративный портал» Контент-менеджер Многосайтовость Причины большинства «кривых» проектов: - Проектировщик не читал курсы по Битриксу - Разработчикам дали полную свободу Кто проектирует веб-систему? Проектировать может: - Менеджер проекта вместе с Клиентом - Аналитик Разработчики могут, но обычно занимаются реализацией задач. Обязательно подключается дизайнер/юзабилист. Риски Проектировщиков: Менеджер – пытается угодить Клиенту в ущерб архитектуре Аналитик – старается все сделать чересчур правильно Разработчик – чтобы было удобно программировать Сделайте правильный выбор! Проектирование под Битрикс Права и роли – кто и что может делать и где Структура контента сайта – список страниц и разделов Шаблоны сайта и их динамика Меню Свойства страниц и разделов, управление ими Модели данных и работа с ними – инфоблоки и админки к ним Компоненты и их размещение на страницах Поиск на сайте, выгрузка во внешние системы Веб-сервисы Синхронизация данных с внешними системами Многосайтовость Структура информации Главная О компании Руководство Новости Фотогалерея Каталог Детальная продукта Дерево разделов и страниц Шаблоны Типы управляемого меню в шаблонах Главная страница Вложенная статика Вложенная каталога Для печати PDA Праздничный на новый год Верхнее Левое Нижнее и т.п. Структура веб-страницы Компонент – это кирпичик с динамическим функционалом. Страница сайта Компонент: «Список новостей» Настраивается: -Кол-во на странице -Число слов краткого описания до «…» -Формат даты и .т.п. Компонент 2 Компонент 3 Стандартных компонентов в продукте больше трехсот. Структура проекта на Битрикс Стандартный компонент Стандартный компонент Стандартный компонент Стандартный компонент Стандартная страница/раздел Стандартная страница/раздел Стандартная страница/раздел Стандартный Стандартный модуль Стандартный модуль Стандартный модуль модуль Кастомная страница/раздел Кастомная страница/раздел Кастомные обработчики событий Кастомный компонент Кастомный компонент Кастомный компонент Кастомный компонент Кастомный компонент Кастомный модуль Кастомный модуль Кастомный модуль Компоненты Страница /раздел проекта Свои таблицы в СУБД Контроллеры ajax Кастомный инфоблок Кастомный инфоблок Кастомные типы свойств Модули Страница /раздел проекта Кастомная форма Кастомная инфоблокаформа элемента инфоблока Веб-сервисы Публичная часть Многочисленные настройки и объекты проекта Админка Особенности составления ТЗ Публичная часть веб-системы модифицируется очень гибко можно написать все, что угодно Административная часть Битрикс – модифицируется ограниченно, далеко не везде Имеется много стандартных, обновляемых компонентов Имеется много стандартных админок для модулей В ТЗ описываем, что то-то и то-то будет реализовано через стандартные возможности Битрикс Иногда «стандарт» приходится описывать в ТЗ Основное время тратим на риски «нестандартного» функционала Структура ТЗ Краткое описание реализации на стандартных возможностях Битрикс – публичка и админка Даем ссылки на официальную техдокументацию и курсы Подробное описание нестандартного функционала Детальное описание и прототипы кастомных админок Если Заказчик активно хочет менять стандартные админки – пишем для него персональный кастомный административный раздел: “htdocs/customer_admin/…” Структура ТЗ на Битриксе ТЗ на интернет-проект Шаблон 1 Шаблон 2 Шаблон 3 Компонент 1 Компонент 2 Компонент 3 Группы пользователей и политика разделения доступа Компонент N Типы меню Типы справочников/списков (инфоблоки) Дерево разделов и страниц «Нестандарт» Типичный проект среднего размера: -2-3 шаблона -20-30 компонентов -50 разделов и страниц -5 групп пользователей с разными правами -10-20 инфоблоков -«нестандарт» Права и роли в ТЗ Описываем роли и их иерархию Настраиваем права в админке: на модули, файлы и т.п. Добавляем свои уровни доступа Создаем учетки в созданных группах Проверяем доступы в публичной части, кнопки на административной панели Инфоблоки в ТЗ Типы инфоблоков Типы полей инфоблоков Модель сущностей, логическая модель данных Кто знает о ком – направление связей Денормализация данных Права на сущности Обработчики событий Риски: «Глубокие выборки» Обновление данных Целостность данных Компоненты в ТЗ Описываем все компоненты и их размещение на страницах – подробно Описываем связи компонентов с инфоблоками Описываем все свойства нестандартных компонентов Логика работы, как управляется Полезные компоненты можно добавлять в свою библиотеку Сложные компоненты «нравятся» разработчикам – мотивация Когда кода слишком много – делайте свой модуль E-commerce в ТЗ Обычно, самое сложное именно тут Интернет-магазин или торговый каталог? Хочу много корзин Логика формирования нестандартных цен и скидок – корзина, события … Товары, цены, SKU, остатки … и инфоблоки Статусы заказов – State Machine Diagram Проектируем формат импорта/экспорта Веб-сервисы в ТЗ Нестандарт с 1С Интеграция с SAP SOAP, REST – веб-сервисы CSV и XML – когда и зачем Может файликами на FTP? ;-) Очереди сообщений – нужны ли? Обновление инфоблоков по событию Управляемый кэш Deployment Diagram Спасибо за внимание! Вопросы? Александр Сербул [email protected] @AlexSerbul