You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
117 lines
2.9 KiB
PHTML
117 lines
2.9 KiB
PHTML
8 months ago
|
<?php
|
||
|
/**
|
||
|
* The Analytics Module
|
||
|
*
|
||
|
* @since 1.0.49
|
||
|
* @package RankMath
|
||
|
* @subpackage RankMath\modules
|
||
|
* @author Rank Math <support@rankmath.com>
|
||
|
*/
|
||
|
|
||
|
namespace RankMath\Analytics;
|
||
|
|
||
|
defined( 'ABSPATH' ) || exit;
|
||
|
|
||
|
/**
|
||
|
* Objects class.
|
||
|
*/
|
||
|
class Objects extends Summary {
|
||
|
|
||
|
/**
|
||
|
* Get objects for pages.
|
||
|
*
|
||
|
* @param array $pages Array of urls.
|
||
|
* @return array
|
||
|
*/
|
||
|
public function get_objects( $pages ) {
|
||
|
if ( empty( $pages ) ) {
|
||
|
return [];
|
||
|
}
|
||
|
|
||
|
$pages = DB::objects()
|
||
|
->whereIn( 'page', \array_unique( $pages ) )
|
||
|
->where( 'is_indexable', 1 )
|
||
|
->get( ARRAY_A );
|
||
|
|
||
|
return $this->set_page_as_key( $pages );
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* Get objects by seo score range filter.
|
||
|
*
|
||
|
* @param WP_REST_Request $request Filters.
|
||
|
*
|
||
|
* @return array
|
||
|
*/
|
||
|
public function get_objects_by_score( $request ) {
|
||
|
global $wpdb;
|
||
|
|
||
|
$orderby = in_array( $request->get_param( 'orderby' ), [ 'title', 'seo_score', 'created' ], true ) ? $request->get_param( 'orderby' ) : 'created';
|
||
|
$order = in_array( $request->get_param( 'order' ), [ 'asc', 'desc' ], true ) ? strtoupper( $request->get_param( 'order' ) ) : 'DESC';
|
||
|
$post_type = sanitize_key( $request->get_param( 'postType' ) );
|
||
|
// Construct filters from request parameters.
|
||
|
$filters = [
|
||
|
'good' => $request->get_param( 'good' ),
|
||
|
'ok' => $request->get_param( 'ok' ),
|
||
|
'bad' => $request->get_param( 'bad' ),
|
||
|
'noData' => $request->get_param( 'noData' ),
|
||
|
];
|
||
|
$field_name = 'seo_score';
|
||
|
$per_page = $request->get_param( 'per_page' ) ? sanitize_text_field( $request->get_param( 'per_page' ) ) : 25;
|
||
|
$offset = ( sanitize_text_field( $request->get_param( 'page' ) ) - 1 ) * $per_page;
|
||
|
|
||
|
// Construct SQL condition based on filter parameters.
|
||
|
$conditions = [];
|
||
|
if ( $filters['good'] ) {
|
||
|
$conditions[] = "{$field_name} BETWEEN 81 AND 100";
|
||
|
}
|
||
|
|
||
|
if ( $filters['ok'] ) {
|
||
|
$conditions[] = "{$field_name} BETWEEN 51 AND 80";
|
||
|
}
|
||
|
|
||
|
if ( $filters['bad'] ) {
|
||
|
$conditions[] = "{$field_name} BETWEEN 1 AND 50";
|
||
|
}
|
||
|
|
||
|
if ( $filters['noData'] ) {
|
||
|
$conditions[] = "{$field_name} = 0";
|
||
|
}
|
||
|
|
||
|
$subwhere = '';
|
||
|
if ( count( $conditions ) > 0 ) {
|
||
|
$subwhere = implode( ' OR ', $conditions );
|
||
|
$subwhere = " AND ({$subwhere})";
|
||
|
}
|
||
|
|
||
|
if ( $post_type ) {
|
||
|
$subwhere = $subwhere . ' AND object_subtype = "' . $post_type . '"';
|
||
|
}
|
||
|
|
||
|
// Get filtered objects data limited by page param.
|
||
|
// phpcs:disable
|
||
|
$pages = $wpdb->get_results(
|
||
|
"SELECT * FROM {$wpdb->prefix}rank_math_analytics_objects
|
||
|
WHERE is_indexable = 1
|
||
|
{$subwhere}
|
||
|
ORDER BY {$orderby} {$order}
|
||
|
LIMIT {$offset} , {$per_page}",
|
||
|
ARRAY_A
|
||
|
);
|
||
|
|
||
|
// Get total filtered objects count.
|
||
|
$total_rows = $wpdb->get_var(
|
||
|
"SELECT count(*) FROM {$wpdb->prefix}rank_math_analytics_objects
|
||
|
WHERE is_indexable = 1
|
||
|
{$subwhere}
|
||
|
ORDER BY created DESC"
|
||
|
);
|
||
|
// phpcs:enable
|
||
|
|
||
|
return [
|
||
|
'rows' => $this->set_page_as_key( $pages ),
|
||
|
'rowsFound' => $total_rows,
|
||
|
];
|
||
|
}
|
||
|
}
|