質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

Q&A

解決済

1回答

429閲覧

イベント一覧ページにて開催日順に並べて、開催終了したものは後ろに回したい

snafkin999

総合スコア27

WordPress

WordPressは、PHPで開発されているオープンソースのブログソフトウェアです。データベース管理システムにはMySQLを用いています。フリーのブログソフトウェアの中では最も人気が高く、PHPとHTMLを使って簡単にテンプレートをカスタマイズすることができます。

0グッド

0クリップ

投稿2023/03/31 08:10

実現したいこと

  • イベントをカスタムフィールドの値で並べ、開催終了したものは後ろに回したい

前提

wordpressにてイベント一覧ページを作成中です。
開催日順に並べています(降順)
現在の日時が開催終了日より上回っている場合は開催終了フラグを立てて強制的に最後にまわしたいのですが
どう触ればよいかイメージが掴めません。どなたかお助けください(>_<)

イメージ説明

該当のソースコード

wordpress:function.php

1function my_posts_control($query) { 2 if (is_admin() || !$query->is_main_query()) { 3 return; 4 } 5 6 if ($query->is_tax('eventcat') || $query->is_archive('eventcat')) { 7 $paged = get_query_var('paged') ? get_query_var('paged') : 1; 8 $query->set('post_type', 'event'); 9 $query->set('meta_key', 'startday'); //カスタムフィールドで設定した名前 10 $query->set('orderby', 'meta_value'); 11 $query->set( 12 'meta_query', 13 array( 14 array( 15 'key' => 'startday', 16 'type' => 'DATE', 17 'order' => 'DESC' 18 ) 19 ) 20 ); 21 $query->set('paged', $paged); 22add_action('pre_get_posts', 'my_posts_control');

補足情報(FW/ツールのバージョンなど)

wordpress6.2

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

複数のカスタムフィールドで並び替えるのであれば、 meta_query でカスタムフィールドに名前をつけておいて、 orderby で名前を指定することで複数のカスタムフィールドを利用して並び替えることが可能です。

現在の日時が開催終了日より上回っている場合は開催終了フラグを立てて強制的に最後にまわしたいのですが

カスタムフィールド startday に開始日
カスタムフィールド flag に 1 : 開催中 , 9 : 終了 のフラグ

が入っていると仮定して、下記のような感じでできないでしょうか。(関係部分のみ抜粋)

PHP

1$query->set( 'meta_query', array( 2 "relation" => "AND", 3 'startdate' => array( 4 'key' => 'startday', 5 ), 6 'closingflag' => array( 7 'key' => 'flag', 8 ) 9) ); 10$query->set( 'orderby', array( 11 'closingflag' => 'ASC', 12 'startdate' => 'ASC' 13) );

投稿2023/04/01 08:39

CHERRY

総合スコア25171

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

snafkin999

2023/04/04 01:58

ありがとうございます! コピペでは変化ありませんでしたがこちらの考え方で調査してみます!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問