Печатные формы — это файлы, полученные на основе информации из LANBilling. Примеры:
Любая печатная форма создаётся по тому или иному шаблону. Он определяет внешний вид формы и содержит дополнительные настройки. В LANBilling уже есть основные шаблоны для документов (счета, акты), отчётов (платежи, задолженности) и других печатных форм. Вы можете добавить собственные шаблоны. К примеру, шаблон для счёта на оплату с особенным оформлением, которое принято у вас в компании. Менеджер будет одинаково работать как со встроенными шаблонами, так и с добавленными.
Некоторые значения в печатных формах могут быть фиксированными. Например, должность сотрудника, который сформировал документ — «главный бухгалтер». Эти значения можно менять при помощи дополнительных полей в шаблонах документов и отчётов. Так вам не придётся каждый раз редактировать файлы с разметкой, чтобы изменить значение. Чтобы использовать эту возможность, для фиксированных значений укажите теги в фигурных скобках.
В этой статье представлены примеры, которые помогут создать файл с шаблоном. Можно подготовить файл в трёх форматах: XML, HTML и PDF.
В качестве примера создадим шаблон для детализации услуг за месяц. Для работы понадобится программа XMLPad. В этой инструкции мы рассмотрим действия с шаблоном на примере файла testOrder.xml. Вы можете назвать свой шаблон иначе.
В редакторе создайте форму шаблона. Строки вида %имя%
используются в качестве идентификаторов переменных. При формировании счёта они будут заменены на реальные значения из вашей базы данных. В качестве уникального идентификатора документа выступает значение orders.order_id, дополненное слева нулями до десяти символов.
Если в документе нужно напечатать штрихкод, используйте шрифт code39h. Согласно спецификации Code 39 команды «старт» и «стоп» обозначаются символом «*».
Сохраните форму как Microsoft Word 2003 XML. В результате получится файл: testOrder0.xml.
Откройте xml-файл с помощью XMLPad. Добавьте теги <!-- start_row -->
и <!-- end_row -->
.
Проверьте идентификаторы переменных. Теги могут сбиться и выглядеть, например, так:
<w:t>%</w:t><w:t>serv</w:t><w:t>%</w:t>
``
В этом случае приведите их к правильному виду:
<w:t>%serv%</w:t>
``
В результате получится готовый xml-шаблон testOrder.xml.
Создайте файл testOrder.sql в кодировке UTF-8. Он нужен для подстановки значений из базы данных в переменные шаблона.
На вход SQL-файла подаётся параметр @ORDER_ID
, который соответствует значению orders.order_id
из базы данных.
В документе можно вывести данные о менеджере, запустившем его формирование. Для этого используйте переменную @logged_person_id
. Например, так:
%man%:select fio from managers where person_id = @logged_person_i
``
Скопируйте в директорию /usr/local/billing/templates
два файла: testOrder.xml
и testOrder.sql
.
В качестве примера создадим шаблон для детализации услуг за месяц. Для работы понадобится программа OpenOffice или MSWord. В этой инструкции мы рассмотрим действия с шаблоном на примере файла testOrder.html. Вы можете назвать свой шаблон иначе.
В редакторе создайте форму шаблона. Строки вида %имя%
используются в качестве идентификаторов переменных. При формировании счёта они будут заменены на реальные значения из вашей базы данных. В качестве уникального идентификатора документа выступает значение orders.order_id, дополненное слева нулями до десяти символов.
Если в документе нужно напечатать штрихкод, используйте шрифт code39h. Согласно спецификации Code 39 команды «старт» и «стоп» обозначаются символом «*».
Сохраните форму как html-документ. В результате получится файл testOrder0.html.
Откройте html-документ в любом текстовом редакторе. Добавьте теги <!-- start_row -->
и <!-- end_row -->
.
Замените ссылку: вместо локального изображения testOrder0_html_m4276a87.gif нужно указать путь до внешней картинки, например https://docs.lanbilling.ru/files/add_template/logo.gif.
Проверьте, что в заголовке установлена кодировка UTF-8.
<META http-equiv="content-type" content="text/html"; charset=utf-8>
``
Сохраните файл в кодировке UTF-8. В результате получится html-шаблон testOrder.html.
Создайте файл testOrder.sql в кодировке UTF-8. Он нужен для подстановки значений из базы данных в переменные шаблона.
На вход SQL-файла подаётся параметр @ORDER_ID
, который соответствует значению orders.order_id
из базы данных.
В документе можно вывести данные о менеджере, запустившем его формирование. Для этого используйте переменную @logged_person_id
. Например, так:
%man%:select fio from managers where person_id = @logged_person_i
``
Скопируйте в директорию /usr/local/billing/templates
два файла: testOrder.html
и testOrder.sql
.
В качестве примера создадим шаблон для счёта на оплату. Для работы понадобится любой текстовый редактор. В этой инструкции мы рассмотрим действия с шаблоном на примере файла inv_test.pdf. Вы можете назвать свой шаблон иначе.
В редакторе создайте форму шаблона с помощью языка разметки HTML. Обратите внимание, содержимое шаблона нужно обернуть в тег <thtml></thtml>. Всё, что находится внутри этого тега, будет передано в php-переменную и преобразуется в формат pdf.
Сохраните файл как pdf-документ. В результате получится файл inv_test.pdf. Обратите внимание, в примере дополнительно есть тег <qrtx></qrtx>. Он содержит данные для формирования QR-кода, передаваемые от
Создайте файл inv_test.post, который нужен для обработки
Создайте файл inv_test.sql в кодировке UTF-8. Он нужен для подстановки значений из базы данных в переменные шаблона.
На вход SQL-файла подаётся параметр @ORDER_ID
, который соответствует значению orders.order_id
из базы данных.
В отчёте можно вывести данные о менеджере, запустившем его формирование. Для этого используйте переменную @logged_person_id
. Например, так:
%man%:select fio from managers where person_id = @logged_person_i
``
Скопируйте в директорию /usr/local/billing/templates
три файла: inv_test.pdf
, inv_test.post
и inv_test.sql
.
Если хотите кастомизировать внешний вид счетов на оплату и предоплату, добавьте в них логотип вашей компании, печати и подписи.
Далее нужно добавить шаблон в административном интерфейсе LANBilling:
Примеры документов, созданных на основе тестовых шаблонов из инструкции: example.xml, example.html и example.pdf.
Есть вопросы по документации? Пожалуйста, напишите их