Drupal 初心者講座

第 14 回 Drupal のテーマシステムについて

第 14 回 Drupal のテーマシステムについて
この記事の目次

Drupalとテーマ

テーマとは、サイトの視覚的な見え方を定義する一連のファイルをまとめたソフトウェアパッケージです。これまで見てきた Drupal のコアシステム(モジュール)は、サイトに表示されるコンテンツ(HTML 文書、データ、画像など)を決定するものでした。テーマは、それらを実際に Web ページとして表示するためのマークアップや CSS のスタイルを決定する役割を果たします。

もう少し詳しく見ると、Drupal のシステムには 5 つのレイヤーが存在します。

  1. データ(ノードなど):表示される内容の元となるデータです。
  2. モジュール:特定の機能を提供するプラグインです。Drupal のコアシステムもプラグインの集合として提供されます。
  3. ブロックとメニュー:ブロックシステムの回で説明した 2 つのコンテンツ形態を定義するレイヤーです。ブロックは他のページに埋め込まれる表示要素、メニューは特定のパスへのナビゲーションですが、これはつまり独自の URL を持つページを表しています。Drupal でコンテンツを表示するには、このいずれかの形態をとります。
  4. ユーザーのアクセス許可:権限設定の回で紹介した機能に対応するレイヤーです。ユーザーの識別と、それに基づき操作を許可するかどうかを判断する機能を提供します。
  5. テンプレート:出力される HTML ページのひな型を提供するものです。テンプレートを基に最終的な出力を生成する処理系をテンプレートエンジンと呼びます。テンプレートは、使用するエンジンに対応した文法で記述します。Drupal 8 以降では、テンプレートエンジンに Twig を使用します。
Drupalのテーマシステムについて

Drupal システムのレイヤー構成

出典:https://www.drupal.org/docs/8/understanding-drupal-8/overview

なお、Drupal 8 以降では、Web ページではなく XML や JSON 等の形式でデータを返す REST 機能も標準でサポートされ、コアの標準機能で Drupal を API サーバーして稼働させることが可能です。これを利用すると、ページのマークアップはブラウザ上のスクリプト(JavaScript 等)で生成し、表示データだけを取得する手法でサイトを構築することもできます。こうした方法は、最上部(頭の部分)に位置するテーマシステムを使用しないことから "Headless" とか "Decoupled"(分離した)などと呼ばれ、Web サイトの新しい構築形態として注目されています。

Drupalのテーマシステムについて

伝統的な構成と Decouped 構成

出典:https://dri.es/the-future-of-decoupled-drupal

ただし、テーマシステムを利用しない完全な Decoupled 構成には複数のデメリットが指摘されています。たとえば、ブロックシステムが提供する便利なレイアウト機能が利用できなくなります。ドラッグ&ドロップでページ上の表示要素を移動したり、表示/非表示を切り替えたりする機能は、特別なプログラミングのスキルがなくても習得できますが、Angular や React といった JavaScript フレームワークで構築した画面のレイアウトを変更するにはプログラミングのスキルが必要となる場合が出てくるでしょう。また他にも、BigPipe を利用するサイトでは高度なキャッシュ機構を独自に再構築する必要があることや、JavaScript を実行するための負荷がかかり、とりわけモバイルデバイスではその負荷によりバッテリーを浪費する、といった欠点もあり、適用には注意が必要です。

これに対して、ページの大枠については従来どおりテーマシステムを利用してサーバー側で生成し、必要に応じて REST API で表示データを取得する "progressive decoupling" という方法が提唱されています。この方法であれば、Drupal が長年蓄積してきた仕組みを利用して効率的にサイトを構築しながら、REST API を利用するさまざまなクライアント(モバイルアプリケーション、種々の端末装置、家電機器など)に同じデータを提供することが可能です。”Decoupled” はおそらく、テーマシステムによるサーバー側のページ生成処理に置き換わるものではなく、Drupal の適用範囲を広げる新しい構成の選択肢と見るのが妥当でしょう。REST API や JavaScript フレームワークによる SPI の潮流が今後さらに勢いを増すとしても、通常のサイト構築において、テーマシステムが果たす役割の重要性に変わりはありません。

既存テーマの利用

BartikDrupal インストール後の初期デフォルト テーマ
SevenDrupal のデフォルト管理用テーマ
StarkDrupal のデフォルト HTML マークアップをデモする最小構成テーマ
ClassyBartik や Seven の基になっているベーステーマ
ClaroDrupal 9 から追加された新しい管理用テーマ

また、コミュニティによって開発されている contributed(寄与)テーマも数多く存在します。drupal.org で公開されているテーマは次のページから検索でき、自由にダウンロードして使用することができます。

https://www.drupal.org/project/project_theme

テーマをインストールするには、入手した圧縮ファイルを展開し、できたフォルダを所定の場所にコピーします。上に示したコアに含まれるテーマは、core/themes フォルダに、それ以外の追加テーマは themes フォルダにインストールします。なお、複数のテーマをインストールする場合などは、テーマの種類別にサブフォルダに分けることもできます。一般に次のような分け方が推奨されています。

  • themes/contrib contributed テーマ(drupal.org で公開されているテーマ)の格納場所
  • themes/custom 独自開発のテーマの格納場所

インストールしたテーマは、テーマの管理画面に表示されます。

Drupalのテーマシステムについて

Drupal 8 のテーマ管理画面

テーマは、フロンエンド用と管理用とのどちらか(または両方)に使用できます。フロントエンドテーマとは一般のサイト訪問者がページを閲覧したときに適用されるテーマのことで、デフォルトテーマとも呼ばれます。一般的なサイトの見栄えはデフォルトテーマによって決まります。 管理用テーマは、文字通り管理画面(/admin 以下のパスを持つページ)に適用されるテーマです。デフォルトテーマとは別に、管理用テーマとして指定します。また、コンテンツの編集に管理用テーマを使用することもできます。ただし、全ての contributed テーマが管理用ページを正しく表示できることを保証しているわけではありません。特に Ajax 周りの動作で問題になるケースがよくあります。管理用テーマをコアに含まれているテーマ以外に変更する場合は、十分に検証してください。

Drupalのテーマシステムについて

管理用テーマの設定

テーマの管理 UI には、グローバル設定という全テーマ共通の環境設定があります。ここで以下のように指定した設定が既定値となりますが、個別のテーマ設定で再定義することもできます。

Drupalのテーマシステムについて

 

テーマのカスタマイズ

入手したテーマをインストールしただけでは、特定の要素が適切に(意図した体裁で)表示されないこともあるでしょう。たとえば、英語での利用を前提に作られたテーマでは、日本語フォントの設定がなかったり、日本語文字を表示したときの周辺とのバランスが良くない、といったことはよくあります。このような場合、テーマのスタイルシートやテンプレート、場合によっては PHP のコード等をカスタマイズする必要が出てきます。

テーマに含まれるファイルを直接編集してしまうと、不具合の修正やセキュリティ対策でテーマを更新したときに、独自の変更が上書きされて消失してしまいます。これを避けるため、一般にテーマのカスタマイズはサブテーマを作成して行います。サブテーマとは、ベースとなるテーマ(親テーマ)を基に作成するテーマのことで、親のリソースを継承しつつ、必要に応じて変更を加えたり、独自の要素を追加したりすることができます。コアに付属する Bartik や Seven というテーマも、Classy テーマのサブテーマとして作成されています。

テーマ作成の詳細はこの連載の範囲を超えますが、ここでは公式サイト(Drupal.org)のドキュメントに掲載されているサブテーマの作成例を簡単に紹介します。

テーマは主に次のファイルで構成されます。(* の位置にはテーマの内部名が入ります)

*.info.ymlテーマの必須ファイル。テーマのメタ情報、ライブラリ、ブロックのリージョンを定義する。
screenshot.pngテーマの管理 UI に表示されるスクリーンショット画像のファイル。
*.libraries.ymlJavaScript と CSS のファイルをテーマに組み込むためのライブラリを定義する。

cssフォルダ

jsフォルダ

CSS ファイルと JavaScript ファイルを格納するためのサブフォルダ(フォルダ名は任意に指定可)。各ファイルをテーマに組み込むためのライブラリを *.libraries.yml で定義する。
*.theme出力を制御するすべての PHP コードを記述するためのファイル。

サブテーマの指定は、必須の *.info.yml ファイルに記述します。先に示したドキュメントにある Fluffiness というテーマの作成例では、次のような info.yml ファイルを作成しています。

name: Fluffiness
type: theme
description: This is a fluffy sub theme of Classy
core: 8.x
# Defines the base theme
base theme: classy
# Defines libraries group in which we can add css/js.
libraries:
  - fluffiness/global-styling
# Regions
regions:
  header: Header
  featured: Featured
  content: Content
  sidebar_first: First sidebar
  sidebar_second: Second sidebar
  footer: Footer

太字で示した部分(base theme: classy)がベーステーマの指定です。この記述により、Classy  テーマが提供する定義が継承されます。ただし、ブロックの配置先となるリージョンはテーマごとに管理されるため、継承の対象外です。Drupal コアが提供するデフォルトのリージョンとは異なるリージョンを使用する場合は、サブテーマ側でもリージョンを定義する必要があります。このため、上の例では最後の部分で 6 つのリージョンを定義しています。

継承したテーマをカスタマイズするには、サブテーマ固有の CSS ファイルや JavaScript ファイルを組み込む必要があります。Drupal では、CSS ファイルや JavaScript ファイルをライブラリという概念で管理します。ライブラリとは Drupal 8 で導入された資源管理の仕組みで、CSS/JS  ファイル群を目的別にグループ分けして管理することができます。この例では、次のような *.libraries.yml ファイルを使用しています。

global-styling: 
  css: 
    component: ~
    css/style.css: {}

1 行目の global-styling がライブラリ名です。info.yml ファイルでこの名前を指定することでライブラリが組み込まれます。2 行目の CSS はファイルの種類 (CSS か JS か)、3 行目の component は SMACSS という設計手法に基づく分類です。この分類に応じて適用の優先順位が決定されます。4 行目がファイルのパスです。この例では、サブテーマの css フォルダに作成した style.css ファイルがテーマに組み込まれます。あとは、style.css ファイルに必要なスタイルを記述すれば、親テーマの設定の後に参照され、既存の設定に優先して適用されるようになります。

まとめ

今回は Drupal のテーマについて、概要と使用例、またサブテーマの作り方を簡単に紹介しました。冒頭に示したように、テーマはコンテンツ出力の最終処理をつかさどる機能であり、コンテンツの見せ方を調整するカスタマイズの中心的な場所となります。

さらに高度なシステムの拡張や独自機能を組み込むには、システムのより深い場所に位置するコンポーネントであるモジュールを活用することになります。次回は、Drupal のモジュールの使い方を紹介したいと思います。

 
フッターの採用情報
 
ANNAI株式会社の写真

この記事を書いた人: ANNAI株式会社

ANNAIは、2009年からDrupal専門のWebシステム開発会社として、世界規模で展開するグローバル企業や大学・自治体を中心に数多くのWebソリューションを提供。
CoreやModuleのコントリビューターなど、Drupalエキスパートが多数在籍。国内ユーザーコミュニティへも積極的にコミットし、定期的なセミナーの等の開催を通じて、オープンソース技術の普及や海外コミュニティとの緊密な連携を図っている。
Webシステムの企画・開発〜デザイン、クラウド運用までをワンストップで提供する他、Drupalのコーディングを評価する"Audit業務"や最適なモジュールの調査・選定等、幅広いコンサルティングを行っている。Drupalアソシエーション公式パートナー。

関連コンテンツ