b0y-101 Mini Shell


Current Path : E:/www3/chiangrai/wp-content/plugins/so-widgets-bundle/base/inc/
File Upload :
Current File : E:/www3/chiangrai/wp-content/plugins/so-widgets-bundle/base/inc/post-selector.php

<?php

/**
 * Filter a query created from the post selector field into an array that will work properly with get_posts
 *
 * @param bool $exclude_current whether to exclude the current post or not.
 *
 * @return mixed
 */
function siteorigin_widget_post_selector_process_query( $query, $exclude_current = true ) {
	$query = wp_parse_args(
		$query,
		array(
			'post_status' => 'publish',
			'posts_per_page' => 10,
		)
	);

	if ( ! empty( $query['post_type'] ) ) {
		if ( $query['post_type'] == '_all' ) {
			$query['post_type'] = siteorigin_widget_post_selector_all_post_types();
		}
		$query['post_type'] = strpos( $query['post_type'], ',' ) !== false ? explode( ',', $query['post_type'] ) : $query['post_type'];
	}

	if ( ! empty( $query['post_type'] ) && $query['post_type'] == 'attachment' && $query['post_status'] == 'publish' ) {
		$query['post_status'] = 'inherit';
	}

	if ( ! empty( $query['post__in'] ) ) {
		if ( ! is_array( $query['post__in'] ) ) {
			$query['post__in'] = explode( ',', $query['post__in'] );
		}

		// Filter out empty values to prevent deprecated warnings.
		$query['post__in'] = array_filter( $query['post__in'], function( $value ) {
			return ! empty( $value );
		} );

		$query['post__in'] = array_map( 'intval', $query['post__in'] );
	}

	if ( ! empty( $query['tax_query'] ) ) {
		$tax_queries = explode( ',', $query['tax_query'] );

		$query['tax_query'] = array();
		$query['tax_query']['relation'] = isset( $query['tax_query_relation'] ) ? $query['tax_query_relation'] : 'OR';

		foreach ( $tax_queries as $tq ) {
			if ( strpos( $tq, ':' ) !== false ) {
				list( $tax, $term ) = explode( ':', $tq );
			} else {
				// There's no separator, try using the previous $tax.
				$tax = empty( $tax ) ? 'category' : $tax;
				$term = $tq;
			}

			if ( empty( $tax ) || empty( $term ) ) {
				continue;
			}
			$query['tax_query'][] = array(
				'taxonomy' => $tax,
				'field' => 'slug',
				'terms' => $term,
			);
		}
	}

	if (
		isset( $query['date_type'] ) &&
		$query['date_type'] == 'relative' &&
		! empty( $query['date_query_relative'] )
	) {
		// Check if we need to decode date_query_relative.
		if ( ! is_array( $query['date_query_relative'] ) ) {
			$date_query_rel = json_decode(
				stripslashes( $query['date_query_relative'] ),
				true
			);
		} else {
			$date_query_rel = $query['date_query_relative'];
		}

		if (
			! empty( $date_query_rel['from'] ) &&
			is_array( $date_query_rel['from'] )
		) {
			$value_after = new DateTime(
				$date_query_rel['from']['value'] . ' ' . $date_query_rel['from']['unit'] . ' ago'
			);
			$value['after'] = $value_after->format( 'Y-m-d' );
		}

		if (
			! empty( $date_query_rel['to'] ) &&
			is_array( $date_query_rel['to'] )
		) {
			$value_before = new DateTime(
				$date_query_rel['to']['value'] . ' ' . $date_query_rel['to']['unit'] . ' ago'
			);
			$value['before'] = $value_before->format( 'Y-m-d' );
		}

		if ( ! empty( $value ) ) {
			$query['date_query'] = $value;
		}
		unset( $query['date_type'] );
		unset( $query['date_query_relative'] );
	} elseif ( ! empty( $query['date_query'] ) ) {
		$query['date_query'] = json_decode( stripslashes( $query['date_query'] ), true );
	}

	if ( ! empty( $query['date_query'] ) ) {
		$query['date_query']['inclusive'] = true;
	}

	if ( ! empty( $query['sticky'] ) ) {
		switch( $query['sticky'] ) {
			case 'ignore':
				$query['ignore_sticky_posts'] = 1;
				break;

			case 'only':
				$post_in = empty( $query['post__in'] ) ? array() : $query['post__in'];
				$query['post__in'] = array_merge( $post_in, get_option( 'sticky_posts' ) );
				break;

			case 'exclude':
				$query['post__not_in'] = get_option( 'sticky_posts' );
				break;
		}
		unset( $query['sticky'] );
	}

	if ( ! empty( $query['additional'] ) ) {
		$query = wp_parse_args( $query['additional'], $query );
		unset( $query['additional'] );
	}

	if ( ! empty( $query['post__not_in'] ) ) {
		if ( ! is_array( $query['post__not_in'] ) ) {
			$query['post__not_in'] = explode( ',', $query['post__not_in'] );
		}

		// Filter out empty values to prevent deprecated warnings.
		$query['post__not_in'] = array_filter( $query['post__not_in'], function( $value ) {
			return ! empty( $value );
		} );

		$query['post__not_in'] = array_map( 'intval', $query['post__not_in'] );
	}

	if ( $exclude_current && get_the_ID() ) {
		if ( ! isset( $query['post__not_in'] ) ) {
			$query['post__not_in'] = array();
		}
		$query['post__not_in'][] = get_the_ID();
	}

	return apply_filters( 'siteorigin_widgets_posts_selector_query', $query );
}

/**
 * Just return a comma separated list of all available post types.
 *
 * @return string
 */
function siteorigin_widget_post_selector_all_post_types() {
	$post_types = array();

	foreach ( get_post_types( array( 'public' => true ), 'objects' ) as $id => $type ) {
		$post_types[] = $id;
	}

	return implode( ',', $post_types );
}

/**
 * Counts the total number of posts matching a query.
 *
 * This function processes a post selector query and returns the total
 * count of matching posts. It handles special query parameters like 'offset'
 * and 'posts_limit' to provide accurate counts:
 * - When 'offset' is set, it subtracts the offset value from the total count.
 * - When 'posts_limit' is set, it ensures the count doesn't exceed this limit.
 *
 * @param string|array $query The query string or array to process.
 * @return int The number of posts matching the query.
 */
function siteorigin_widget_post_selector_count_posts( $query ): int {
	$query = siteorigin_widget_post_selector_process_query( $query );

	$posts = new WP_Query( $query );

	// WP Query doesn't reduce found_posts by the offset value, let's do that now.
	if ( ! empty( $query['offset'] ) && is_numeric( $query['offset'] ) ) {
		$total = max( $posts->found_posts - $query['offset'], 0 );
	}

	// If `posts_limit` is a valid number, limit the total number of posts.
	if ( ! empty( $query['posts_limit'] ) ) {
		$posts->found_posts = min(
			$posts->found_posts,
			(int) $query['posts_limit']
		);
	}

	return empty( $total ) ? $posts->found_posts : $total;
}

Copyright © 2019 by b0y-101