ACF リピーターをカレンダーに出力(予約カレンダーの実装)

情報を追記している場合はありますが、古い情報を訂正はしていませんので、公開年月日を参照してください。プラグイン・タグ、いずれもワードプレス・PHPのバージョン等によって動作しない場合もあります。

Advanced Custom Fields リピーターで設定した予約可能日時やイベントの開催日をカレンダーで表示するのに必要な設定について

リピーターの外側で日付を登録、内側のリピーターで時間枠やイベント投稿を登録するのだが、テーブルでカレンダーを出力するコードは日付のtdの部分にループがあるので、外側のリピーターはループにしないで $rows = get_field(‘repeater’); のように取得して内側のリピーターのみループにする。この場合、外側のリピーターの行数(カウント)が必要になる。

継続的な予約受付サンプルはコチラ

ランダムなイベントをカレンダーで予約受付のサンプルはコチラ

外側のリピーターの行数が一月の日数分ある場合

休業日以外は全てに予約枠がある場合は、1月のスケジュールを1投稿として、外側のリピーターで年月日と休業日のチェック、内側のリピーター(休業にチェックがある場合は非表示)で時間枠と定員などを登録する。
*acf/load_value で指定した年月のフィールドを作成するため、すべての日付のフィールドがあるので、日付マイナス1が行数になる。これをカウントとして利用する。
$subrows = $rows[行数]['subrepeater']; foreach( $subrows as $subrow ) ~のように、内側のリピーターをループ。
カレンダーの表示コードはACFで設定した年月を出力するようにする。

必要のある日付のみ追加する場合

外側のリピーターに登録した日付を参照用のフィールドに連結して保存し、カレンダーの日付が含まれる場合のみ、内側のリピーターを取得するので、カレンダーの日付のループの前に外側のリピーターのカウントをスタートし、カレンダーの日付とイコールの場合にカウントを増やす。

カレンダーは今月から出力するため、今月のループをスタートする前にそれまでのカウントを取得する。
*今日の次の開催日を基準に表示したい場合は、一度リピーターをループして今日の次の開催月を取得して、月のループでその開催付きより前はcontinue で飛ばす。

設定したすべての日付をカレンダーで表示したい場合は、日付データの他に今月以降の年月データを保存して、これをループする。

期日や定員でメールフォーム・申込みを締め切る」参照

その他のAdvanced Custom Fields に関する記事一覧

Advanced Custom Fields に関する記事一覧ページへ