ブログのリッチテキストのメタフィールド登録はできる、でも表示で壁にぶつかる
ブログ記事に、ブログとは別にリッチテキスト形式でメタフィールドを登録できるようにしましたが、Shopify管理画面上で、ひとまずノーコードでメタフィールド登録をして、さあこれをフロント画面に表示をどうするか、となって、ちょっとした壁にぶつかりました。
まずはノーコードでブログのリッチテキストのメタフィールドを管理画面で定義
設定 > カスタムデータ > ブログ記事 を選択
data:image/s3,"s3://crabby-images/de7f1/de7f1c433cc329c0267fa26e9375959d187a3b79" alt=""
定義が作成ならこのような画面になるので「定義を追加する」を押す
data:image/s3,"s3://crabby-images/8a7c8/8a7c88e16a97ae131d96b9b27b0a4ea5e6639017" alt=""
「タイプを選択する」の中に「リッチテキスト」があるのでそれを選択。
data:image/s3,"s3://crabby-images/13c3a/13c3ac756d7333a6055155839d3f7e274526bd01" alt=""
この例では、「名前」と「ネームスペースとキー」それぞれを以下のように登録する。
名前:item_name_text
ネームスペースとキー:custom.item_name_text
data:image/s3,"s3://crabby-images/e8597/e859799e6a5e4dcfa48e5cd7fe138f2e5e65b74d" alt=""
そして、「保存」で登録完了。
このように、記事作成画内に「ブログ記事のメタフィールド」という入力枠が作成された。
data:image/s3,"s3://crabby-images/fe7dc/fe7dc0f47276bdff4c1f8251adecd28e0a6478e7" alt=""
これをどう出力するか?
Shopifyで、リッチテキストをセクションのスキーマで登録できるようにした場合は、{{ section.setting.[id名] | newline_to_br }}のような記述だけで、Shopifyが用意したHTMLコードで出力されて、テキストエディタで登録した通りの見出しレベル、リンク、太字、斜体でHTMLコードを出力してくれた。
しかし登録メタフィールドからHTMLを出力するときは、自分でどんなHTMLタグで囲まれた文字として出力するかを逐一定義してあげないといけない。手をかけないとこんな感じです。
data:image/s3,"s3://crabby-images/30af4/30af458e4d38651d0f5ec2e6c2e35e63160a7680" alt=""
メタフィールドにこのうように登録してみる。
↓
何も手をいれないときの表示結果
data:image/s3,"s3://crabby-images/94d97/94d97b4f9bfa90c4230627422251725f5206ff07" alt=""
data:image/s3,"s3://crabby-images/5ef93/5ef935e2c972b72532768b619bc1d194cb0dd01e" alt=""
HTMLコードとして出力されていない。どうやらメタフィールドではリッチテキストはJSONデータとして保持されているらしいので、これを整形して出力する必要がある。
{% if article.metafields.custom.item_name_text != blank %}
{% assign data = article.metafields.custom.item_name_text.value %}
<div class="article_rich_text page-width">
{{data | newline_to_br}}
</div>
{% endif %}
↓ 加工後のコード
{% if article.metafields.custom.item_name_text != blank %}
{% assign data = article.metafields.custom.item_name_text.value %}
<div class="article_rich_text page-width">
{% for child in data.children %}
{% if child.type == "heading" %}
<h{{ child.level }} class="title{{ child.level }}">{{ child.children[0].value }}</h{{ child.level }}>
{% elsif child.type == "paragraph" %}
<p>
{% for text in child.children %}
{% if text.bold %}
<strong>{{ text.value }}</strong>
{% elsif text.italic %}
<em>{{ text.value }}</em>
{% elsif text.url %}
<a href="{{ text.url }}" target="{{ text.target }}">{{ text.children[0].value }}</a>
{% else %}
{{ text.value }}
{% endif %}
{% endfor %}
</p>
{% elsif child.type == "list" %}
{% if child.listType == "unordered" %}
<ul>
{% for item in child.children %}
<li>{{ item.children[0].value }}</li>
{% endfor %}
</ul>
{% elsif child.listType == "ordered" %}
<ol>
{% for item in child.children %}
<li>{{ item.children[0].value }}</li>
{% endfor %}
</ol>
{% endif %}
{% endif %}
{% endfor %}
</div>
{% endif %}
↓ 加工後のコードで出力されたリッチテキスト
data:image/s3,"s3://crabby-images/3b496/3b4963d7225e56f92b755444aa30b8cbe574df2b" alt=""
きちんとHTMLコードとして出力されている。
data:image/s3,"s3://crabby-images/f6f6d/f6f6d9ea2f59ec6794b37efa2dd10d0e3e1444b1" alt=""
このコードは、Shopifyのテーマ内で商品のメタフィールド(リッチテキスト形式)を解析し、HTMLとして出力するためのLiquidテンプレートコードです。以下に主な機能を解説します:
- メタフィールドのデータ取得:
{% assign data = product.metafields.asdqwe.test.value %}
で、特定の商品のメタフィールドからデータを取得しています。 - データの反復処理:
{% for child in data.children %}
で、メタフィールドの各要素(子要素)を順に処理します。 - 要素タイプの判別と対応するHTML生成:
- 見出し(heading):
{% if child.type == "heading" %}
で判別し、適切なレベルの<h1>
〜<h6>
タグを生成します。 - 段落(paragraph):テキストの装飾(太字、イタリック、リンク)を適用しながら
<p>
タグ内にコンテンツを生成します。 - リスト:順序なし(
<ul>
)と順序あり(<ol>
)リストを適切に生成します。
- 見出し(heading):
- HTMLの構造化:生成されたコンテンツを
<section>
と<div>
タグで囲み、整理された構造にします。
このコードにより、Shopifyの管理画面で入力されたリッチテキスト形式のメタフィールドを、ウェブサイト上で適切にフォーマットされたHTMLとして表示することができます。