本サイトでは、以下のような特定条件に合った商品のみを表示するページやブロックの作り方を紹介してきました。
ところが、これらのソースコードをそのままに作られたページでは、
商品の公開状態(公開、非公開、廃止)に関係なく商品が表示されてしまうという欠点があります。
商品管理で、商品の一つ(サンプル_4)の公開状態を “非公開” にしているが・・・
実際にページを開いてみると、サンプル_4がそのまま表示されている。
そこで本記事では、この欠点を克服するために追加してほしいコードを紹介しています。
デフォルトで用意されている商品一覧ページでは、公開状態が非公開または廃止になると非表示になるので、こちらは修正しなくてもOKです。
またこの方法を使えば、公開状態に応じて様々な操作を行うことも可能になります。
“非公開” や “廃止” でも商品が表示されてしまう理由
つまり、『商品の公開状態 = “公開”』になってるものを判別する「if文」をTwigテンプレートに追記し、表示・非表示を分岐させれば解決するはずです。
Twigテンプレートに「if文」を追記する
まず商品の公開状態は、データベースでは『mtb_product_status』テーブルに格納されています。
これによると、公開状態の “公開” は「id = 1」であるため、
「公開状態のid = 1」のときのみ表示というif文を使ったコード(以下)を追記すれば良さそうです。
{% if Product.status.id == 1 %}
~~商品情報~~
{% endif %}
Product
には、Controllerから渡された商品情報が格納されています。
商品の公開状態はProduct.status
で取得でき、Product.status.id
でid情報を取得できます。
idが1の場合にのみ、{% if Product.status.id == 1 %}
と{% endif %}
で囲まれた部分が実行されるようになります。
実際に、前回作成した新着商品一覧のTwigテンプレートを以下の通り修正しました。
{% extends 'default_frame.twig' %}
{% block main %}
<h1>新着商品ページ</h1>
<div class="ec-shelfRole">
<ul class="ec-shelfGrid">
{% for Product in Products %}
{# 公開状態が「公開」の場合のみ商品を表示 #}
{% if Product.status.id == 1 %}
<li class="ec-shelfGrid__item">
{# 商品画像の表示 #}
<p class="ec-shelfGrid__item-image">
<img src="{{ asset(Product.main_list_image|no_image_product, 'save_image') }}" alt="{{ Product.name }}">
</p>
{# 商品IDの表示 #}
<p>ID: {{ Product.id }}</p>
{# 商品名の表示 #}
<p>{{ Product.name }}</p>
{# 価格の表示 #}
<p class="price02-default">
{% if Product.hasProductClass %}
{% if Product.getPrice02Min == Product.getPrice02Max %}
{{ Product.getPrice02IncTaxMin|price }}
{% else %}
{{ Product.getPrice02IncTaxMin|price }} ~ {{ Product.getPrice02IncTaxMax|price }}
{% endif %}
{% else %}
{{ Product.getPrice02IncTaxMin|price }}
{% endif %}
</p>
</li>
{% endif %}
{% endfor %}
</ul>
</div>
{% endblock %}
商品管理で、商品の一つ(サンプル_4)の公開状態を “非公開” にすると・・・
無事、サンプル_4が表示されなくなりました!
まとめ
以上、商品の公開ステータスに応じて表示・非表示を切り替える方法を紹介しました。
登録した商品が廃盤になったり、何かしらの事情で一時的に非公開にしておきたい場合、このようなステータスを操作できると便利ですよね。
今回は非表示にする方法のみでしたが、応用すれば商品ページに【完売】という表示を出すといったこともできるでしょう。
ぜひ、いろいろな使い方を試してみてください!