Как сформировать отдельный хидер или футер для первой страницы в 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, или вывода в нестандартном месте. В этой статье покажем, как ...

    Читать

    Drupal: шаблоны для taxonomy_term и view mode — как добавить?

    Июль 19, 2025 г.

    При работе с таксономией в Drupal нередко возникает потребность отображать термины по-разному в зависимости от контекста. Например, один и тот же термин в режиме teaser должен выводиться компактно, а в режиме full — с подробным описанием. Если вы используете ...

    Читать

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

    Апрель 6, 2025 г.

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

    Читать

    Чтение данных из oembed провайдера

    Март 11, 2025 г.

    В Drupal 10/11 поддержка Oembed провайдеров в ядре (модуль media) позволяет легко и непринуждённо читать данные о медиа прямо из провайдера. Ранее я рассказывал как зарегистрировать oembed для rutube, чтобы иметь возможность оперировать видео контентом ...

    Читать
     

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

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



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