Как сформировать отдельный хидер или футер для первой страницы в mPDF на примере Drupal

Когда вам нужно создать PDF-документ с использованием библиотеки mPDF, бывает необходимо сделать так, чтобы на первой странице отображался отдельный футер (или хидер), отличающийся от остальных страниц. В этом примере мы рассмотрим, как использовать селектор @page :first для задания различных футеров для первой страницы и всех остальных страниц в вашем документе. Этот подход будет полезен не только для проектов на Drupal, но и для любых других случаев, где используется mPDF.

Основы подхода: использование @page :first

Для начала, вам нужно настроить CSS стили для страницы и футеров. Примерно так это выглядит:

Для всех страниц (кроме первой) используется стандартный футер print-page-footer.

Для первой страницы мы устанавливаем особый футер print-page-footer-first.

Дополнительно для рендера в браузере (например, при просмотре на экране) мы скрываем общий футер, чтобы не отображать оба футера сразу.

HTML-шаблон (Twig)

Чтобы настроить рендеринг футеров, нужно воспользоваться специализированными тегами htmlpagefooter из mPDF. Для этого создадим два отдельных контейнера для футеров — один для всех страниц, второй только для первой.

Как видно, мы подключаем один и тот же подшаблон футера (page-foot.twig), но оборачиваем его в разные контейнеры htmlpagefooter. Первый футер будет использоваться для всех страниц, кроме первой, а второй — только для первой страницы. В подшаблон передается параметр isFirst, который определяет, какой контент отобразить.

Логика внутри подшаблона

Теперь давайте разберемся с логикой внутри самого подшаблона page-foot.twig, где вы можете задать условие на отображение различного контента в зависимости от значения флага isFirst.

Здесь мы используем проверку флага isFirst, чтобы определить, какой контент выводить в футере. Когда isFirst равен 1, выводится футер для первой страницы, иначе — стандартный футер.

    Мало букафф? Читайте есчо !

    Как программно отрендерить View в Drupal и получить HTML

    Август 3, 2025 г.

    В некоторых случаях удобно не только встроить View через UI или блок, но и программно срендерить представление (View) и получить HTML — например, для отправки во внешнюю систему, в e-mail, или вывода в нестандартном месте. В этой статье покажем, как ...

    Читать

    Проброс переменных из PHP в JS (в Drupal) с использованием js_settings_alter

    Ноябрь 14, 2025 г.

    В этой статье мы рассмотрим, как пробросить данные из PHP в JavaScript в Drupal 11 с использованием js_settings_alter(). Этот метод позволяет изменять или добавлять переменные в объект drupalSettings, который доступен в JavaScript на всех страницах. ...

    Читать

    Быстро чистим таксономии в Drupal

    Апрель 24, 2025 г.

    Чтобы через админку почистить длинные словари, нужно много времени, даже если вы используете bulk операции. Потому будем чистить их через код. Разберем пример кода: [crayon-6977559bbb302792843192/] Эти две команды удаляют все термины из словаря ...

    Читать

    Отключаем страницы терминов таксономии в Drupal

    Июль 21, 2025 г.

    По умолчанию Drupal генерирует маршруты для каждого термина таксономии. Это означает, что у каждого термина появляется своя страница с URL вида /taxonomy/term/123. В некоторых случаях такие страницы могут быть полезны, например, если вы используете термины ...

    Читать
     

    Комментарии к «Как сформировать отдельный хидер или футер для первой страницы в mPDF на примере Drupal»

    Понравилась статья? Есть вопросы? - пишите в комментариях.



    Комментарий: