Найти в Дзене
ИНТЕРВОЛГА

Доработка генератора документов Битрикс24.

Оглавление

В июле 2019 года к нам обратилась музыкальная студия из Германии за доработкой коробочного Битрикс24. Клиенту требовалось произвольно менять описание товара в PDF-счетах.

Предстояло вмешаться в создание PDF, механизм связывания CRM-сущностей (сделки и лида, сделки и счета, счета и товаров и т.д.) и все это на немецком языке. Как говорится, wölfen бояться — в wald не ходить!

Самостоятельная попытка клиента

Команда заказчика уже пыталась решить эту задачу самостоятельно. Они попробовали изменить шаблон списка товаров. Но добавление HTML-разметки испортило отображение товара в остальных местах сайта:

-2

Кроме того, при последующем обновлении Битрикса24 доработка слетала.

-3

План действий

Мы предложили другой подход, не ломающий вывод товаров в CRM и сохраняющий обновления:

  • добавить новый тип свойства для карточки CRM: визуальный редактор;
  • создать в CRM Счете множественное поле «Описание товара»;
  • при создании Счета (или добавлении в существующий новых товаров) копировать в это поле оригинальное описание товара;
  • при генерации PDF заменять оригинальное описание описанием из поля в CRM Счете;
  • повторить логику для CRM Сделок, Лидов и Предложений, учесть конвертацию сущностей.
-4

Вели обсуждение и писали ТЗ сразу на английском, у нас и команды заказчика с этим не было проблем.

HTML-поле

Несмотря на всю мощь Битрикс24, в нем иногда не хватает простых вещей. Мы добавили свойство «HTML-текст».

-5
-6

Кастомное поле корректно отображается на отдельной странице и в выдвижной карточке Сделки/Лида. Пришлось решать множество конфликтов javascript визуального редактора и карточки CRM. Хотя оба компонента стандартные, мы потратили 10 часов, прежде чем удалось их “подружить”.

-7
-8

Изначально мы выводили описания для товаров в том-же порядке что и товары в списке. Это работало, пока мы не столкнулись с самопроизвольным переставлением товаров в счете (сюрприз Битрикс24). Чтобы предотвратить ошибки пользователя, перед каждым описанием вывели подсказку — название товара.

Наследование описаний из CRM карточки товара

Для наследования описаний товаров мы использовали частично документированные события сущностей Лид, Сделка, Предложение, Счет:

  • OnAfterCrm...Update
  • OnAfterCrm...ProductRowsSave

При конвертации сущностей (лид->компания) и выставлении (сделка ->счет) кастомизированные описания товаров сохраняются.

Кастомизация генератора PDF

Самая сложная часть работы.

Общая схема работы модуля Битрикс24 «Генератор документов»:

-9

Нам пригодилось событие onBeforeProcessDocument , которое испускается сразу после работы встроенного провайдера данных. Обработчик получает список товаров, заменяет оригинальные описания кастомными и возвращает обратно в генератор. Но и тут не обошлось без проблем. Событие подходит для подмены простых полей (адрес, телефон, ИНН...), а у нас поле было множественное. Разработчики Битрикс24 знают о проблеме и планируют ее решить, но без точных сроков.

Итоговая схема работы генератора документов:

-10

Заключение

Мы получили опыт сразу в немецком, английском и узнали больше о внутренней кухне генератора документов. Задача выполнена в срок и перенесена на бой без инцидентов.

Данная доработка — небольшая, штучная, но интересная. Мы готовы помочь вам в решении нетиповых проблем с коробочным Битрикс24.

Полезные ссылки:

Разработка и доработка проектов на 1С-Битрикс.

Внедрение Битрикс24.

Настройка интеграции с 1С любой сложности.

B2B-платформа для автоматизации оптовой торговли.

Блог про сложные проекты.

Техническая поддержка сайтов.