Filtering based on Last/This/Next Week uses all possible dates as Start of Week.
This commit is contained in:
@@ -122,8 +122,25 @@ class SP_Calendar extends SP_Secondary_Post {
|
|||||||
public function data() {
|
public function data() {
|
||||||
global $pagenow;
|
global $pagenow;
|
||||||
|
|
||||||
|
$weekday = array (
|
||||||
|
0 => 'Sunday',
|
||||||
|
1 => 'Monday',
|
||||||
|
2 => 'Tuesday',
|
||||||
|
3 => 'Wednesday',
|
||||||
|
4 => 'Thursday',
|
||||||
|
5 => 'Friday',
|
||||||
|
6 => 'Saturday',
|
||||||
|
);
|
||||||
|
|
||||||
$start_of_week = get_option('start_of_week');
|
$start_of_week = get_option('start_of_week');
|
||||||
|
|
||||||
|
$firstday = $weekday[ $start_of_week ];
|
||||||
|
if ( $start_of_week != 0 ) {
|
||||||
|
$lastday = $weekday[ ( $start_of_week - 1 ) ];
|
||||||
|
}else{
|
||||||
|
$lastday = $weekday[6];
|
||||||
|
}
|
||||||
|
|
||||||
$args = array(
|
$args = array(
|
||||||
'post_type' => 'sp_event',
|
'post_type' => 'sp_event',
|
||||||
'posts_per_page' => $this->number,
|
'posts_per_page' => $this->number,
|
||||||
@@ -160,13 +177,16 @@ class SP_Calendar extends SP_Secondary_Post {
|
|||||||
$args['monthnum'] = $date->format('n');
|
$args['monthnum'] = $date->format('n');
|
||||||
break;
|
break;
|
||||||
case '-w':
|
case '-w':
|
||||||
if ( $start_of_week == '0' ) { //If start of week is Sunday
|
if ( $start_of_week != '1' ) { //If start of week is not Monday
|
||||||
if ( date('w') == '0' ) { //If today is Sunday
|
if ( date('w') == $start_of_week ) { //If today is start of Week
|
||||||
$after = date_i18n('Y-m-d', strtotime('Sunday last week'));
|
$after = date_i18n('Y-m-d', strtotime("$firstday last week"));
|
||||||
$before = date_i18n('Y-m-d', strtotime('Saturday this week')).' 23:59:59';
|
$before = date_i18n('Y-m-d', strtotime("$lastday this week")).' 23:59:59';
|
||||||
|
}elseif ( date('w') < $start_of_week ){
|
||||||
|
$after = date_i18n('Y-m-d', strtotime("$firstday -2 week"));
|
||||||
|
$before = date_i18n('Y-m-d', strtotime("$lastday last week")).' 23:59:59';
|
||||||
}else{
|
}else{
|
||||||
$after = date_i18n('Y-m-d', strtotime('Sunday -2 week'));
|
$after = date_i18n('Y-m-d', strtotime("$firstday last week"));
|
||||||
$before = date_i18n('Y-m-d', strtotime('Saturday last week')).' 23:59:59';
|
$before = date_i18n('Y-m-d', strtotime("$lastday this week")).' 23:59:59';
|
||||||
}
|
}
|
||||||
$args['date_query'] = array(
|
$args['date_query'] = array(
|
||||||
array(
|
array(
|
||||||
@@ -183,13 +203,16 @@ class SP_Calendar extends SP_Secondary_Post {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case 'w':
|
case 'w':
|
||||||
if ( $start_of_week == '0' ) { //If start of week is Sunday
|
if ( $start_of_week != '1' ) { //If start of week is not Monday
|
||||||
if ( date('w') == '0' ) { //If today is Sunday
|
if ( date('w') == $start_of_week ) { //If today is start of Week
|
||||||
$after = date_i18n('Y-m-d');
|
$after = date_i18n('Y-m-d');
|
||||||
$before = date_i18n('Y-m-d', strtotime('Saturday next week')).' 23:59:59';
|
$before = date_i18n('Y-m-d', strtotime("$lastday next week")).' 23:59:59';
|
||||||
|
}elseif ( date('w') < $start_of_week ){
|
||||||
|
$after = date_i18n('Y-m-d', strtotime("$firstday last week"));
|
||||||
|
$before = date_i18n('Y-m-d', strtotime("$lastday this week")).' 23:59:59';
|
||||||
}else{
|
}else{
|
||||||
$after = date_i18n('Y-m-d', strtotime('Sunday last week'));
|
$after = date_i18n('Y-m-d', strtotime("$firstday this week"));
|
||||||
$before = date_i18n('Y-m-d', strtotime('Saturday this week')).' 23:59:59';
|
$before = date_i18n('Y-m-d', strtotime("$lastday next week")).' 23:59:59';
|
||||||
}
|
}
|
||||||
$args['date_query'] = array(
|
$args['date_query'] = array(
|
||||||
array(
|
array(
|
||||||
@@ -204,13 +227,16 @@ class SP_Calendar extends SP_Secondary_Post {
|
|||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case '+w':
|
case '+w':
|
||||||
if ( $start_of_week == '0' ) { //If start of week is Sunday
|
if ( $start_of_week != '1' ) { //If start of week is not Monday
|
||||||
if ( date('w') == '0' ) { //If today is Sunday
|
if ( date('w') == $start_of_week ) { //If today is start of Week
|
||||||
$after = date_i18n('Y-m-d', strtotime('Sunday next week'));
|
$after = date_i18n('Y-m-d', strtotime("$firstday next week"));
|
||||||
$before = date_i18n('Y-m-d', strtotime('Saturday +2 week')).' 23:59:59';
|
$before = date_i18n('Y-m-d', strtotime("$lastday +1 week")).' 23:59:59';
|
||||||
|
}elseif ( date('w') < $start_of_week ){
|
||||||
|
$after = date_i18n('Y-m-d', strtotime("$firstday this week"));
|
||||||
|
$before = date_i18n('Y-m-d', strtotime("$lastday next week")).' 23:59:59';
|
||||||
}else{
|
}else{
|
||||||
$after = date_i18n('Y-m-d', strtotime('Sunday this week'));
|
$after = date_i18n('Y-m-d', strtotime("$firstday next week"));
|
||||||
$before = date_i18n('Y-m-d', strtotime('Saturday next week')).' 23:59:59';
|
$before = date_i18n('Y-m-d', strtotime("$lastday +1 week")).' 23:59:59';
|
||||||
}
|
}
|
||||||
$args['date_query'] = array(
|
$args['date_query'] = array(
|
||||||
array(
|
array(
|
||||||
|
|||||||
Reference in New Issue
Block a user