🏗️ テーマ基盤上級
layout タグのフォーマット
Liquid の layout タグの書式をコード品質ツール(Prettier)でフォーマットするテストケース。スペースや改行位置の違いを正規化し、レイアウト名が壊れないことを検証する。
用途
theme-tools の Prettier プラグイン開発時に、layout タグの構文バリエーション(スペース有無、改行位置、none 指定)が正しくパース・フォーマットされるか確認する場面で使用。
設置場所
このコードはテストファイルであり、実装テーマに貼り付けるものではない。Prettier Liquid プラグインの unit test として packages/prettier-plugin-liquid/src/test/ 配下に配置され、npm test で自動実行される。
注意点
このファイルは theme-tools の内部テストであり、マーチャントが直接使用するコードではない。layout タグ自体はテーマの theme.liquid で 1 度だけ定義され、複数の layout を同時に指定することはできない。layout "layoutName" は Shopify OS 2.0 以降で「セクション」の概念に統合されているため、新規開発ではセクションベースの設計を推奨する。
コード
10 行 / liquidIt should never break a name
printWidth: 1
{% layout "layoutName" %}
{% layout "layoutName" %}
{%layout "layoutName"%}
{%- layout
"layoutName"
-%}
{%- layout none -%}
出典・ライセンス
- Repository:
- https://github.com/Shopify/theme-tools
- License:
- MIT
このコードは Shopify 著作の MIT ライセンスソースです。 原本の著作権は Shopify が保有します。日本語訳は ALSEL によるものです。
関連項目
🏗️ テーマ基盤中級
セクションスキーマのカスタムブロック定義
セクションの schema ブロック内でカスタムブロックタイプを定義する方法を示すサンプル。@theme と _private というプレフィックスで異なるブロック種別を宣言する。
📁 theme-tools·MIT·7 行
🏗️ テーマ基盤初級
セクション呼び出しのフォーマット
Liquid の section タグを複数行に記述する際の正しいフォーマット例。タグ名を改行で分割しても正しく認識される書き方を示す。
📁 theme-tools·MIT·7 行
🏗️ テーマ基盤初級
レイアウトテンプレートの指定
Liquid の `layout` タグを使い、テーマのレイアウトファイルを指定する構文。複数のレイアウト候補と whitespace 制御(ダッシュ記号)の使い方を示す。
📁 theme-tools·MIT·8 行
🏗️ テーマ基盤上級
Liquid フォーマッター互換のセクション表記
Prettier Liquid プラグインのテストケースで、セクションタグの様々な書式を検証する。異なる間隔・改行・ホワイトスペーストリミングの組み合わせでもセクション名が崩れないことを確認する。
📁 theme-tools·MIT·9 行
🏗️ テーマ基盤初級
基本的なHTMLレイアウト
Prettier Liquid プラグインのテスト用に作られた最小限の HTML テンプレート。DOCTYPE から body タグまでの基本的なドキュメント構造を示す。
📁 theme-tools·MIT·10 行
🏗️ テーマ基盤初級
DOCTYPE宣言の構文サンプル
HTML5 と過去の DOCTYPE 宣言パターンを網羅したリファレンス。Prettier による Liquid フォーマッタが複数行 DOCTYPE に対応することを示すテストコード。
📁 theme-tools·MIT·12 行