メンテナンスしやすいテーマ開発、デザインコンポーネント設計など、悩んでませんか? モジュール上で実装した機能とデザイン領域の連携をどうすればいいのか、どのレイヤーで実装すると見通しが良くなるのか、考えることが度々あります。 今回は、テーマの中に書くべき実装・設定に関して書いていこうと思います。 モジュールとテーマの領域 CMSでサイト制作する場合に、テーマを切り替えた時にサイト設定や機能がなくなったり、動作しなくなることがないようにモジュールはテーマに依存しないように実装するのが一般的で、Drupalも例外ではありません。 その後の運用コストを下げるためにも依存しないようにしておくことが大事です。 MVCモデルの観点で見ると、 モデル(M): Entity API ビュー(V): Theme + Twig コントローラ(C): ルーティングとコントローラ のように分離されており、表示部分は
![テーマにカスタム設定を定義する - Qiita](https://cdn-ak-scissors.b.st-hatena.com/image/square/edb58ce1592f39fd69b84cc26f795473a05f2290/height=288;version=1;width=512/https%3A%2F%2Fqiita-user-contents.imgix.net%2Fhttps%253A%252F%252Fcdn.qiita.com%252Fassets%252Fpublic%252Fadvent-calendar-ogp-background-f625e957b80c4bd8dd47b724be996090.jpg%3Fixlib%3Drb-4.0.0%26w%3D1200%26mark64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTkxNiZoPTMzNiZ0eHQ9JUUzJTgzJTg2JUUzJTgzJUJDJUUzJTgzJTlFJUUzJTgxJUFCJUUzJTgyJUFCJUUzJTgyJUI5JUUzJTgyJUJGJUUzJTgzJUEwJUU4JUE4JUFEJUU1JUFFJTlBJUUzJTgyJTkyJUU1JUFFJTlBJUU3JUJFJUE5JUUzJTgxJTk5JUUzJTgyJThCJnR4dC1jb2xvcj0lMjMzQTNDM0MmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9NTYmdHh0LWNsaXA9ZWxsaXBzaXMmdHh0LWFsaWduPWxlZnQlMkNtaWRkbGUmcz0wYTI1NTQxNjA3OGZjMTMyZWIxYjY4NzVhZWViMTRkNQ%26mark-x%3D142%26mark-y%3D151%26blend64%3DaHR0cHM6Ly9xaWl0YS11c2VyLWNvbnRlbnRzLmltZ2l4Lm5ldC9-dGV4dD9peGxpYj1yYi00LjAuMCZ3PTYxNiZ0eHQ9JTQwSl9TdWdhcl9fJnR4dC1jb2xvcj0lMjMzQTNDM0MmdHh0LWZvbnQ9SGlyYWdpbm8lMjBTYW5zJTIwVzYmdHh0LXNpemU9MzYmdHh0LWFsaWduPWxlZnQlMkN0b3Amcz0yOGZmYzhmYzE0OTJmMWVmYzVlMzRmMmI0OGY2ZjlkYQ%26blend-x%3D142%26blend-y%3D491%26blend-mode%3Dnormal%26s%3D6794873b369b2276fe2c0aaa6e72905d)