query['post_type']) && $query->query['post_type'] === 'sht_event') { $query->set('orderby', 'meta_value'); $query->set('order', 'ASC'); $query->set('meta_key', 'start_date'); $meta_query = (array) $query->get('meta_query'); $meta_query[] = [ 'relation' => 'OR', [ // Start date and end date are empty 'relation' => 'AND', [ 'relation' => 'OR', [ 'key' => 'start_date', 'value' => '', 'compare' => '=' ], [ 'key' => 'start_date', 'compare' => 'NOT EXISTS' ] ], [ 'relation' => 'OR', [ 'key' => 'end_date', 'value' => '', 'compare' => '=' ], [ 'key' => 'end_date', 'compare' => 'NOT EXISTS', ] ] ], [ // Start date >= today and end date empty 'relation' => 'AND', [ 'key' => 'start_date', 'value' => date('Y-m-d'), 'compare' => '>=', 'type' => 'DATE' ], [ 'key' => 'end_date', 'value' => '', 'compare' => '=' ] ], [ // Start date <= today and end date >= today 'relation' => 'AND', [ 'key' => 'start_date', 'value' => date('Y-m-d'), 'compare' => '<=', 'type' => 'DATE' ], [ 'key' => 'end_date', 'value' => date('Y-m-d'), 'compare' => '>=', 'type' => 'DATE' ] ] ]; $query->set('meta_query', $meta_query); } }