Your IP : 18.222.167.183


Current Path : /home/sudancam/public_html3/games/wp-content/plugins/wp-rss-aggregator/includes/
Upload File :
Current File : /home/sudancam/public_html3/games/wp-content/plugins/wp-rss-aggregator/includes/admin-display.php

<?php

// Adds the "active" class to the feed source list table rows, for active feed sources
add_filter('post_class', function ($classes, $class, $postId) {
    $post = get_post($postId);

    if ($post->post_type !== 'wprss_feed') {
        return $classes;
    }

    if (wprss_is_feed_source_active($postId)) {
        $classes[] = 'active';
    }

    return $classes;
}, 10, 3);

add_filter('manage_wprss_feed_posts_columns', 'wprss_set_feed_custom_columns', 20, 1);
/**
 * Set up the custom columns for the wprss_feed list
 *
 * @since 2.0
 */
function wprss_set_feed_custom_columns($columns)
{
    $isTrashPage = filter_input(INPUT_GET, 'post_status') === 'trash';

    $columns = [
        'cb' => '<input type="checkbox" />',
    ];

    if (!$isTrashPage) {
        $columns['state'] = __('State', 'wprss');
    }

    $columns['title'] = __('Name', 'wprss');

    $columns = apply_filters('wprss_set_feed_custom_columns', $columns);

    if (!$isTrashPage) {
        $columns['updates'] = __('Updates', 'wprss');
        $columns['feed-count'] = __(apply_filters('wprss_feed_items_count_column', 'Imported items'), 'wprss');
    }

    return apply_filters('wprss_feed_columns', $columns);
}

add_action("manage_wprss_feed_posts_custom_column", "wprss_show_custom_columns", 10, 2);
/**
 * Show up the custom columns for the wprss_feed list
 *
 * @since 2.0
 */
function wprss_show_custom_columns($column, $post_id)
{
    switch ($column) {
        case 'state':
            $switch_title = __('Activate or pause auto importing for this feed', 'wprss');
            ?>
            <div class="wprss-feed-state-container" title="<?= esc_attr($switch_title); ?>">
                <label class="wprss-switch">
                    <input
                        type="checkbox"
                        class="wprss-toggle-feed-state"
                        autocomplete="off"
                        value="<?= esc_attr($post_id); ?>"
                        <?php checked(true, wprss_is_feed_source_active($post_id)) ?>
                    />
                    <span class="wprss-switch-slider"></span>
                </label>
            </div>

            <?php
            $feed_type = 'rss';
            $feed_icon = 'rss';
            $icon_title = __('Normal RSS Feed', 'wprss');

            if (wprss_is_feed_youtube($post_id)) {
                $feed_type = 'yt';
                $feed_icon = 'video-alt3';
                $icon_title = __('YouTube Feed', 'wprss');
            }
            ?>

            <div
                class="wprss-feed-source-type wprss-feed-source-type-<?= esc_attr($feed_type) ?>"
                title="<?= esc_attr($icon_title) ?>"
            >
                <span class="dashicons dashicons-<?= esc_attr($feed_icon) ?>"></span>
            </div>
            <?php

            break;

        case 'updates':
            // Get the update interval
            $update_interval = get_post_meta($post_id, 'wprss_update_interval', true);
            // Get the last updated and next update data
            $last_update = get_post_meta($post_id, 'wprss_last_update', true);
            $last_update_items = get_post_meta($post_id, 'wprss_last_update_items', true);
            $next_update = wprss_get_next_feed_source_update($post_id);

            // If using the global interval, get the timestamp of the next global update
            if ($update_interval === wprss_get_default_feed_source_update_interval() || $update_interval === '') {
                $next_update = wp_next_scheduled('wprss_fetch_all_feeds_hook', []);
            }

            // Update the meta field
            if (wprss_is_feed_source_active($post_id)) {
                $next_update_text = $next_update === false
                    ? __('None', 'wprss')
                    : human_time_diff($next_update, time());
            } else {
                $next_update_text = __('...', 'wprss');
            }
            update_post_meta($post_id, 'wprss_next_update', $next_update_text);

            $timeAgo = empty($last_update)
                ? ''
                : human_time_diff($last_update, time());
            ?>

            <p class="next-update-container">
                <?= __('Next update in', 'wprss') ?>
                <code class="next-update">
                    <?= esc_html($next_update_text); ?>
                </code>
            </p>

            <p
                class="last-update-container"
                style="display: <?php echo empty($timeAgo) ? 'none' : 'inline-block'; ?>">
                <span class="last-update-num-items-container">
                    <?= _x('Updated', 'Example: "Updated 2 days ago"', 'wprss'); ?>
                    <span class="last-update-time-container">
                        <code class="last-update-time">
                            <?php printf(__('%1$s ago', 'wprss'), $timeAgo) ?>
                        </code>
                    </span>
                    (
                        <span class="last-update-num-items">
                            <?= esc_html($last_update_items) ?>
                        </span>

                        <?= _x('items', 'Example: "15 new"', 'wprss'); ?>
                    )
                </span>
            </p>

            <?php
            break;

        case 'feed-count':
            $items = wprss_get_feed_items_for_source($post_id);
            $has_items_class = ($items->post_count > 0) ? 'has-imported-items' : '';

            $errors = get_post_meta($post_id, 'wprss_error_last_import', true);
            $errorShowClass = ($errors !== '') ? 'wprss-show' : '';
            $default_msg = __(
                "This feed source experienced an error during the last feed fetch or validation check. Re-check the feed source URL or check the Error Log in the Debugging page for more details.",
                'wprss'
            );
            $msg = strlen($errors) > 0
                ? $errors
                : $default_msg;

            $errorIcon = sprintf(
                '<i title="%1$s" class="fa fa-warning fa-fw wprss-feed-error-symbol %2$s"></i>',
                esc_attr($msg),
                esc_attr($errorShowClass)
            );

            $view_items_url = admin_url('edit.php?post_type=wprss_feed_item&wprss_feed=' . $post_id);
            $view_items_url = apply_filters('wprss_view_feed_items_row_action_link', $view_items_url, $post_id);
            ?>
            <a
                href="<?= esc_attr($view_items_url); ?>"
                class="items-imported-link <?= esc_attr($has_items_class); ?>"
                title="<?= esc_attr(__('View the imported items for this feed source', 'wprss')); ?>"
            >
                <span class="items-imported">
                    <?= esc_attr($items->post_count) ?>
                </span>
                <?= __('items', 'wprss') ?>
            </a>
            <div class="spinner"></div>

            <?= $errorIcon ?>

            <div class="row-actions">
                <span class="fetch">
                    <a
                        href="javascript:void(0);"
                        class="wprss_fetch_items_ajax_action"
                        pid="<?= esc_attr($post_id); ?>"
                        purl="<?= esc_attr(admin_url('admin-ajax.php')); ?>">
                        <?= esc_html(__('Fetch', 'wprss')); ?>
                    </a>
                </span>
                <span class="purge-posts trash <?= esc_attr($has_items_class) ?>">
                        |
                        <a
                            href="javascript:void(0);"
                            class="wprss_delete_items_ajax_action"
                            pid="<?= esc_attr($post_id); ?>"
                            purl="<?= esc_attr(admin_url('admin-ajax.php')); ?>">
                            <?= esc_html(__('Delete items', 'wprss')) ?>
                        </a>
                    </span>
            </div>
            <?php

            // Set meta field for items imported
            update_post_meta($post_id, 'wprss_items_imported', $items->post_count);

            break;
    }
}

add_filter("manage_edit-wprss_feed_sortable_columns", "wprss_feed_sortable_columns");
/**
 * Make the custom columns sortable for wprss_feed post type
 *
 * @since 2.0
 */
function wprss_feed_sortable_columns()
{
    $sortable_columns = [
        // meta column id => sort by value used in query
        'state' => 'state',
        'title' => 'title',
        'updates' => 'updates',
        'feed-count' => 'feed-count',
    ];

    return apply_filters('wprss_feed_sortable_columns', $sortable_columns);
}

add_action('pre_get_posts', 'wprss_feed_source_order');
/**
 * Change order of feed sources to alphabetical ascending according to feed name
 *
 * @since 2.2
 */
function wprss_feed_source_order($query)
{
    // Check if the query is being processed in WP Admin, is the main query, and is targeted
    // for the wprss_feed CPT. If not, stop
    if (!is_admin() || !$query->is_main_query() || $query->get('post_type') !== 'wprss_feed') {
        return;
    }

    // Get the sorting query args
    $order = strtoupper($query->get('order'));
    $orderby = $query->get('orderby');

    // If order is not specified, default to ascending
    if ($order !== 'ASC' && $order !== 'DESC') {
        $order = 'ASC';
    }

    $query->set('order', $order);

    // If not explicitly sorting or sorting by title, sort by title
    if (!$orderby || $orderby === 'title') {
        $query->set('orderby', 'title');
    }

    // Check what we are sorting by
    switch ($orderby) {
        case 'state':
            $query->set('meta_key', 'wprss_state');
            $query->set('orderby', 'meta_value');
            break;

        case 'updates':
            $query->set('meta_key', 'wprss_next_update');
            $query->set('orderby', 'meta_value');

            break;
        case 'feed-count':
            $query->set('meta_key', 'wprss_items_imported');
            $query->set('orderby', 'meta_value_num');

            break;
    }
}

add_filter('manage_wprss_feed_item_posts_columns', 'wprss_set_feed_item_custom_columns', 20, 1);
/**
 * Set up the custom columns for the wprss_feed source list
 *
 * @since 2.0
 */
function wprss_set_feed_item_custom_columns($columns)
{
    return apply_filters('wprss_set_feed_item_custom_columns', [
        'cb' => '<input type="checkbox" />',
        'title' => __('Name', 'wprss'),
        'permalink' => __('Permalink', 'wprss'),
        'publishdate' => __('Date published', 'wprss'),
        'source' => __('Source', 'wprss'),
    ]);
}

add_action("manage_wprss_feed_item_posts_custom_column", "wprss_show_feed_item_custom_columns", 10, 2);
/**
 * Show up the custom columns for the wprss_feed list
 *
 * @since 2.0
 */
function wprss_show_feed_item_custom_columns($column, $post_id)
{
    switch ($column) {
        case "permalink":
            $url = get_post_meta($post_id, 'wprss_item_permalink', true);
            printf(
                '<a href="%s">%s</a>',
                esc_attr($url),
                esc_html($url)
            );
            break;

        case "publishdate":
            $item_date = get_the_time('U', get_the_ID());
            $item_date = ($item_date === '') ? date('U') : $item_date;
            $publishdate = date('Y-m-d H:i:s', $item_date);
            echo $publishdate;
            break;

        case "source":
            $query = new WP_Query();

            $feedId = get_post_meta($post_id, 'wprss_feed_id', true);
            $feedName = get_the_title($feedId);
            $feedEditLink = get_edit_post_link($feedId);

            printf(
                '<a href="%s">%s</a>',
                $feedEditLink,
                $feedName
            );

            break;
    }
}

add_filter("manage_edit-wprss_feed_item_sortable_columns", "wprss_feed_item_sortable_columns");
/**
 * Make the custom columns sortable
 *
 * @since 2.0
 */
function wprss_feed_item_sortable_columns()
{
    return apply_filters('wprss_feed_item_sortable_columns', [
        'publishdate' => 'publishdate',
        'source' => 'source',
    ]);
}

add_action('pre_get_posts', 'wprss_feed_item_orderby');
/**
 * Change ordering of posts on wprss_feed_item screen
 *
 * @since 2.0
 */
function wprss_feed_item_orderby($query)
{
    if (!is_admin()) {
        return;
    }

    $post_type = $query->get('post_type');

    // If we're on the feed listing admin page
    if ($post_type == 'wprss_feed_item') {
        // Set general orderby to date the feed item was published
        $query->set('orderby', 'publishdate');
        // If user clicks on the reorder link, implement reordering
        $orderby = $query->get('orderby');
        if ('publishdate' == $orderby) {
            $query->set('order', 'DESC');
            $query->set('orderby', 'date');
        }
    }
}

add_filter('post_updated_messages', 'wprss_feed_updated_messages');
/**
 * Change default notification message when new feed is added or updated
 *
 * @since 2.0
 */
function wprss_feed_updated_messages($messages)
{
    global $post, $post_ID;

    $messages['wprss_feed'] = [
        0 => '', // Unused. Messages start at index 1.
        1 => __('Feed source updated. ', 'wprss'),
        2 => __('Custom field updated.', 'wprss'),
        3 => __('Custom field deleted.', 'wprss'),
        4 => __('Feed source updated.', 'wprss'),
        5 => '',
        6 => __('Feed source saved.', 'wprss'),
        7 => __('Feed source saved.', 'wprss'),
        8 => __('Feed source submitted.', 'wprss'),
        9 => '',
        10 => __('Feed source updated.', 'wprss'),
    ];

    return apply_filters('wprss_feed_updated_messages', $messages);
}

add_filter('post_row_actions', 'wprss_remove_row_actions', 10, 2);
/**
 * Remove actions row for imported feed items, we don't want them to be editable or viewable
 *
 * @since 2.0
 */
function wprss_remove_row_actions($actions, $post)
{
    if (get_post_type($post) === 'wprss_feed_item') {
        if (!wpra_is_dev_mode()) {
            unset($actions['edit']);
        }
        unset($actions['view']);
        unset($actions['inline hide-if-no-js']);
    } elseif (get_post_type($post) === 'wprss_feed') {
        $actions = array_reverse($actions);
        $actions['id'] = sprintf(
            '<span class="wprss-row-id">%s</span>',
            sprintf(__('ID: %1$s', 'wprss'), $post->ID)
        );
        $actions = array_reverse($actions);

        unset($actions['view']);
        unset($actions['inline hide-if-no-js']);
    }

    return apply_filters('wprss_remove_row_actions', $actions);
}

add_action('wprss_delete_feed_items_from_source_hook', 'wprss_delete_feed_items_of_feed_source', 10, 1);
/**
 * Deletes the feed items of the feed source identified by the given ID.
 *
 * @since 3.5
 *
 * @param int $source_id The ID of the feed source
 */
function wprss_delete_feed_items_of_feed_source($source_id)
{
    wprss_delete_feed_items($source_id);

    update_post_meta($source_id, 'wprss_feed_is_deleting_items', '');
}

/**
 * Shows a notification that tells the user that feed items for a particular source are being deleted
 *
 * @since 3.5
 */
function wprss_notify_about_deleting_source_feed_items()
{
    $message = apply_filters(
        'wprss_notify_about_deleting_source_feed_items_message',
        __('The feed items for this feed source are being deleted in the background.', 'wprss')
    );

    printf('<div class="updated"><p>%s</p></div>', $message);
}

add_action('wp_ajax_wprss_fetch_items_row_action', 'wprss_fetch_feeds_action_hook');
/**
 * The AJAX function for the 'Fetch Feed Items' row action on the
 * 'All Feed Sources' page.
 *
 * @since 3.3
 */
function wprss_fetch_feeds_action_hook()
{
    $response = wprss()->createAjaxResponse();
    $wprss = wprss();
    $feedIdKey = 'feed_source_id';

    try {
        if (!current_user_can('edit_feed_sources')) {
            throw new Exception(__('Could not schedule fetch for feed source: user must have sufficient privileges.'));
        }

        // Verify admin referer
        if (!wprss_verify_nonce('wprss_feed_source_action', 'wprss_admin_ajax_nonce')) {
            throw new Exception(__('Could not schedule fetch for feed source: nonce is invalid.', 'wprss'));
        }

        $id = filter_input(INPUT_POST, 'id', FILTER_VALIDATE_INT);
        if (!$id) {
            throw new Exception($wprss->__('Could not schedule fetch: feed source ID is invalid or was not specified'));
        }
        $response->setAjaxData($feedIdKey, $id);


        update_post_meta($id, 'wprss_force_next_fetch', '1');

        // Prepare the schedule args
        $schedule_args = [strval($id)];

        // Get the current schedule - do nothing if not scheduled
        $next_scheduled = wp_next_scheduled('wprss_fetch_single_feed_hook', $schedule_args);
        if ($next_scheduled !== false) {
            // If scheduled, unschedule it
            wp_unschedule_event($next_scheduled, 'wprss_fetch_single_feed_hook', $schedule_args);

            // Get the interval option for the feed source
            $interval = get_post_meta($id, 'wprss_update_interval', true);
            // if the feed source uses its own interval
            if ($interval !== '' && $interval !== wprss_get_default_feed_source_update_interval()) {
                // Add meta in feed source. This is used to notify the source that it needs to reschedule it
                update_post_meta($id, 'wprss_reschedule_event', $next_scheduled);
            }
        }

        // Schedule the event for 5 seconds from now
        $offset = floor(count(wpra_get_ready_cron_jobs()) / 2);
        $success = wp_schedule_single_event(time() + $offset, 'wprss_fetch_single_feed_hook', $schedule_args);
        if (!$success) {
            throw new Exception(__('Failed to schedule cron', 'wprss'));
        }
        wprss_flag_feed_as_updating($id);
    } catch (Exception $e) {
        $response = wprss()->createAjaxErrorResponse($e);
        if (isset($id)) {
            $response->setAjaxData($feedIdKey, $id);
        }
        echo $response->getBody();
        exit();
    }

    $response->setAjaxData('message', $wprss->__(['Fetch for feed source #%1$s successfully scheduled', $id]));
    $response->setAjaxData('success', $success);
    echo $response->getBody();
    exit();
}

add_action('wp_ajax_wprss_delete_items_row_action', 'wprss_delete_items_ajax_action_hook');
/**
 * The AJAX function for the 'Delete Items' row action on the 'All Feed Sources' page.
 *
 * @since 4.14
 */
function wprss_delete_items_ajax_action_hook()
{
    $kFeedSourceId = 'feed_source_id';
    $response = wprss()->createAjaxResponse();
    $wprss = wprss();
    try {
        $id = filter_input(INPUT_POST, 'id');
        if (empty($id)) {
            throw new Exception($wprss->__('Source ID was not specified'));
        }

        $response->setAjaxData($kFeedSourceId, $id);

        if (!current_user_can('edit_feed_sources')) {
            throw new Exception($wprss->__(['User must have sufficient privileges', $id]));
        }

        // Verify admin referer
        if (!wprss_verify_nonce('wprss_feed_source_action', 'wprss_admin_ajax_nonce')) {
            throw new Exception($wprss->__(['Nonce has expired - Please refresh the page.', $id]));
        }

        // Schedule a job that runs this function with the source id parameter
        $offset = floor(count(wpra_get_ready_cron_jobs()) / 2);
        $success = wp_schedule_single_event(time() + $offset, 'wprss_delete_feed_items_from_source_hook', [$id]);
        if (!$success) {
            throw new Exception(__('Failed to schedule cron', 'wprss'));
        }
        // Mark feed as deleting its items
        update_post_meta($id, 'wprss_feed_is_deleting_items', time());
    } catch (Exception $e) {
        $response = wprss()->createAjaxErrorResponse($e);
        if (isset($id)) {
            $response->setAjaxData($kFeedSourceId, $id);
        }
        echo $response->getBody();
        exit();
    }

    $response->setAjaxData('message', $wprss->__(['Items are being deleted', $id]));
    $response->setAjaxData('success', $success);
    echo $response->getBody();
    exit();
}

add_action('wp_ajax_wprss_toggle_feed_state', 'wprss_ajax_toggle_feed_state');
/**
 * The AJAX function for toggling a feed's state from the 'All Feed Sources' page.
 *
 * @since 4.14
 */
function wprss_ajax_toggle_feed_state()
{
    $kFeedSourceId = 'feed_source_id';
    $response = wprss()->createAjaxResponse();
    $wprss = wprss();
    try {
        $id = filter_input(INPUT_POST, 'id', FILTER_DEFAULT);
        if (empty($id)) {
            throw new Exception($wprss->__('Source ID was not specified'));
        }

        $response->setAjaxData($kFeedSourceId, $id);

        if (!current_user_can('edit_feed_sources')) {
            throw new Exception($wprss->__(['User must have sufficient privileges', $id]));
        }

        // Verify admin referer
        if (!wprss_verify_nonce('wprss_feed_source_action', 'wprss_admin_ajax_nonce')) {
            throw new Exception($wprss->__(['Nonce has expired - Please refresh the page.', $id]));
        }

        $active = wprss_is_feed_source_active($id);

        if ($active) {
            wprss_pause_feed_source($id);
        } else {
            wprss_activate_feed_source($id);
        }

        $response->setAjaxData('active', !$active);
    } catch (Exception $e) {
        $response = wprss()->createAjaxErrorResponse($e);
        if (isset($id)) {
            $response->setAjaxData($kFeedSourceId, $id);
        }
        echo $response->getBody();
        exit();
    }

    $response->setAjaxData('message', $wprss->__(['Feed state changed successfully', $id]));
    echo $response->getBody();
    exit();
}

add_action('manage_posts_extra_tablenav', function ($which) {
    $screen = get_current_screen();
    $postType = $screen->post_type;
    // Only add on feed source list
    if ($postType !== 'wprss_feed') {
        return;
    }

    $nonceEl = new \Aventura\Wprss\Core\Block\Html\Span([
        'data-value' => wp_create_nonce('wprss_feed_source_action'),
        'id' => 'wprss_feed_source_action_nonce',
        'class' => 'hidden',
    ]);

    echo (string) $nonceEl;
});

add_filter('bulk_actions-edit-wprss_feed_item', 'wprss_custom_feed_item_bulk_actions');
/**
 * Allow filtering bulk actions for feed items
 *
 * @since 2.0
 */
function wprss_custom_feed_item_bulk_actions($actions)
{
    if (!wpra_is_dev_mode()) {
        unset($actions['edit']);
    }

    return apply_filters('wprss_custom_feed_item_bulk_actions', $actions);
}

add_action('admin_footer-edit.php', 'wprss_remove_a_from_feed_title');
/**
 * Remove hyperlink from imported feed titles in list posts screen
 *
 * @since 2.0
 */
function wprss_remove_a_from_feed_title()
{
    if ('edit-wprss_feed_item' !== get_current_screen()->id) {
        return;
    }

    ?>
    <script type="text/javascript">
        jQuery('table.wp-list-table a.row-title').contents().unwrap();
    </script>
    <?php
}

add_action('wp_before_admin_bar_render', 'wprss_modify_admin_bar');
/**
 * Removes the old "View Source" menu item from the admin bar and adds a new
 * "View items" menu bar item, that opens a new tab, showing the items imported
 * from that feed source.
 *
 * Only shown on the wprss_feed edit page.
 *
 * @since 4.2
 */
function wprss_modify_admin_bar()
{
    if (!is_admin()) {
        return;
    }

    $screen = get_current_screen();
    $action = filter_input(INPUT_GET, 'action');
    $action = strtolower($action);

    if (empty($screen) || $screen->base !== 'post' || $screen->post_type !== 'wprss_feed' || $action !== 'edit') {
        return;
    }

    global $wp_admin_bar;
    // Remove the old 'View Source' menu item
    $wp_admin_bar->remove_node('view');

    // Prepare the view items link and text
    $view_items_link = apply_filters(
        'wprss_view_feed_items_row_action_link',
        admin_url('edit.php?post_type=wprss_feed_item&wprss_feed=' . get_the_ID()),
        get_the_ID()
    );
    $view_items_text = apply_filters('wprss_view_feed_items_row_action_text', __('View Items', 'wprss'));

    // Prepare the link target
    $link_target = 'wprss-view-items-' . get_the_ID();

    // Add the new menu item
    $wp_admin_bar->add_node([
        'href' => $view_items_link,
        'id' => 'view',
        'title' => $view_items_text,
        'meta' => [
            'target' => $link_target,
        ],
    ]);
}

if (is_admin()) {
    /**
     * Alters the main query in the WordPress admin, when the wprss_feed GET parameter is set.
     * The queried items are then filtered down to the items imported by the feed source with
     * the ID given in the wprss_feed GET parameter.
     *
     * @since 4.2
     */
    add_filter('pre_get_posts', function ($query) {
        // Get the ID from the GET param
        $id = filter_input(INPUT_GET, 'wprss_feed', FILTER_VALIDATE_INT);

        // Make sure we are in the admin area, filtering the main query, and the GET param is present
        if (!is_admin() || !$query->is_main_query() || empty($id)) {
            return $query;
        }

        // Bail if the ID does not correspond to a WPRA feed source
        $feed = get_post($id);
        if ($feed instanceof WP_Post && $feed->post_type !== 'wprss_feed') {
            return $query;
        }

        // Get the existing meta query
        $mq = $query->get('meta_query');
        // Add a meta query if one is not yet set
        if (!is_array($mq)) {
            // initialize it
            $mq = ['relation' => 'AND'];
        }
        // Add the custom meta query
        $mq[] = apply_filters(
            'wprss_view_feed_items_meta_query',
            [
                'key' => 'wprss_feed_id',
                'value' => $id,
                'compare' => '=',
            ],
            $id
        );
        // Set the new meta query
        $query->set('meta_query', $mq);

        // Return the query
        return $query;
    });
}