Skip Navigation

[Resolved] I need help understanding view URL Param filters following ajaxComplete…

This support ticket is created 3 years, 7 months ago. There's a good chance that you are reading advice that it now obsolete.

This is the technical support forum for Toolset - a suite of plugins for developing WordPress sites without writing PHP.

Everyone can read this forum, but only Toolset clients can post in it. Toolset support works 6 days per week, 19 hours per day.

Sun Mon Tue Wed Thu Fri Sat
- 9:00 – 13:00 9:00 – 13:00 9:00 – 13:00 9:00 – 13:00 9:00 – 13:00 -
- 14:00 – 18:00 14:00 – 18:00 14:00 – 18:00 14:00 – 18:00 14:00 – 18:00 -

Supporter timezone: Asia/Karachi (GMT+05:00)

This topic contains 4 replies, has 2 voices.

Last updated by shawnW-3 3 years, 7 months ago.

Assisted by: Waqar.

Author
Posts
#2088577

As usual, I'd like to be assigned to a supporter in my timezone, but if that's not possible or will take longer, I'm fine with anyone.

Tell us what you are trying to do?

This is a live site which uses nested views to build a complete table for all the specs in a series...
hidden link

This is a staging site for the same system loaded through ajax following user scroll...
hidden link

It should be pretty obvious the benefit is a much lower initial load time.
The problem however is that some models in the staging site aren't being filtered by the URL parameters post ajax.
You can see this by clicking on "woofers" the ajax version is showing an 'archived' model that the slower live version is not.

It filters correctly for anything not controlled by URL parameters, so I'm sure those are the issue. So my question is:
Should I be calling something on ajaxComplete to make the views recognize the URL parameters? Some built in function?

Is there any documentation that you are following?
No.

Is there a similar example that we can see?
No. I can share my ajax/php and view structure if needed, but I'm hoping there is something you can point to on this... I didn't even notice this was an issue until I was implementing it on the live site.

What is the link to your site?
See above

#2089213

Hi,

Thank you for contacting us and I'd be happy to assist.

I tried to view your staging website's page, but it is showing a "403 Forbidden" error.

What you've shared seems expected though. When the view is set to update the results without AJAX and through page reload, the query relies on the parameter values passed through the URL.

However, when the view is set to use AJAX, it relies on the parameters passed through the AJAX request itself and not the available URL parameters.

For this reason, if you're using the AJAX search view in a way that some URL parameters are being added manually (e.g. status=2&global=2 ), you'll need to make the view's query to look for them on subsequent searches.

You can use the "wpv_filter_query" filter for this as it can be used to override all views queries, whether it is with or without AJAX:
https://toolset.com/documentation/programmer-reference/views-filters/#wpv_filter_query

Tip: you can set the view to not use AJAX and then print/dump the "$query_args" to see how the query is set to use those filters for the URL parameters. After that, you can set it to use AJAX and then include the same filters for the URL parameters.

I hope this helps and please let me know if you need any further assistance around this.

regards,
Waqar

#2089619

I really appreciate this...

I take it then I can't or shouldn't use something like urlParams.get('status'); to pass it from ajax data to php? Even if that were an option, I wouldn't know how to apply what I'm seeing in the example from the documentation going that route.

To start, can you give me an example of:
'you can set the view to not use AJAX and then print/dump the "$query_args" to see how the query is set to use those filters for the URL parameters. After that, you can set it to use AJAX and then include the same filters for the URL parameters.'

Don't know where to start on that, and I'm not finding examples, but I can say that trying this with a simple view...

add_filter( 'wpv_filter_query', 'return_view_query_args', 99, 3 );
 function return_view_query_args( $query_args, $view_settings, $view_id ) {
    $views = array( 155715 );
    if ( in_array( $view_id, $views ) ) {
        return $query_args[$views];
    }
}

...is producing a mess that has nothing to do with the view.

#2090023

Thanks for writing back.

You don't need to include custom data into the original AJAX request, since you can short circuit the query using the "wpv_filter_query" filter.

Here is an example of a simple function that prints the view's query in a readable form on the front-end:


add_filter( 'wpv_filter_query', 'wpv_filter_query_func', 1000 , 3 );
function wpv_filter_query_func( $query_args, $view_settings ) {
	// skip if blocks edit screen
	if ( defined( 'REST_REQUEST' ) && REST_REQUEST ) {
		return $query_args;
	}

	// process if specific view
	if ( !is_admin() && ( isset($view_settings['view_id']) && $view_settings['view_id'] == 12345) ) {

		echo '<div style=""><pre>';
		print_r($query_args);
		echo '</pre></div>';
		
	}
	
	return $query_args;
}

Note: You'll replace "12345" with your actual view's ID.

This will give you a better idea of how the view's query works in different cases and with different filters.

For more personalized assistance around custom code, you can also consider hiring a professional from our list of recommended contractors:
https://toolset.com/contractors/

#2090861

Thank you!

I ended up doing things differently. The $query_args were more complex than I figured and making sense of it for php was intimidating. Since this is a wpv_do_shortcode function, it's easier (for me) to just get the URL params with JS and pass them to PHP, where I can set them as variables in the shortcode attribute. These are then passed to the nested views, which were previously looking for the URL parameters, but now I have them looking for shortcode attributes.

I don't know that this is the best way to do it, and I might end up changing the overall structure, but I have tested this method and it is working without error.

I do sincerely appreciate being able to see the $query_args, and I'm sure I'll used that function again.