Sauter la navigation

[Résolu] URL with dynamic variables appended to it

Ce fil est résolu. Voici une description du problème et la solution proposée.

Problem: I would like to use the values from various Types custom fields to create and display dynamic links with URL parameters.

Solution: You can use the Types field shortcode and raw output to construct any HTML markup structure. See the examples and documentation below for more details.

<a href='[types field="my-url" output="raw"][/types]?param1=[types field="param1" output="raw"][/types]&param2=[types field="param2" output="raw"][/types]&param3=[types field="param3" output="raw"][/types]'>[types field="my-url" output="raw"][/types]</a>

On the front-end, the link text looks like the fixed URL:

https://google.com

But the link's href is actually:

https://google.com?param1=123&param2=234&param3=345

Relevant Documentation:
https://toolset.com/documentation/customizing-sites-using-php/functions/
https://toolset.com/documentation/user-guides/views/views-shortcodes/

This support ticket is created Il y a 4 années et 7 mois. 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
8:00 – 12:00 8:00 – 12:00 8:00 – 12:00 8:00 – 12:00 8:00 – 12:00 - -
13:00 – 17:00 13:00 – 17:00 13:00 – 17:00 13:00 – 17:00 13:00 – 17:00 - -

Supporter timezone: America/New_York (GMT-04:00)

Ce sujet contient 4 réponses, a 2 voix.

Dernière mise à jour par AlimB3245 Il y a 4 années et 7 mois.

Assisté par: Christian Cox.

Auteur
Publications
#1630481

Tell us what you are trying to do? I have custom field as a URL which is a predefined fixed URL but has a few variables that need to be appended to it. These variables are data from other custom fields... Can I achieve this with Toolset? Also I would like to NOT show the URL as a raw URL but I'd like it to be a button that needs to be clicked to trigger the URL (so that the long URL is not displayed with all its variables)..

Is there any documentation that you are following?https://toolset.com/documentation/user-guides/views/passing-arguments-to-views/

Is there a similar example that we can see?

What is the link to your site?lien caché

#1630989

You can use Types field shortcodes to generate any custom HTML markup you want. For example, let's say the fixed URL is stored in a custom field with the slug "my-url". The URL is https://google.com. You have URL parameters in 3 custom fields with slugs "param1", "param2", and "param3". The parameter values are 123, 234, and 345, respectively. You want to create a link that includes all 3 URL parameters with the fixed URL, but you want to display the fixed URL in the link text. You could do that with the following shortcode and HTML structure:

<a href='[types field="my-url" output="raw"][/types]?param1=[types field="param1" output="raw"][/types]&param2=[types field="param2" output="raw"][/types]&param3=[types field="param3" output="raw"][/types]'>[types field="my-url" output="raw"][/types]</a>

On the front-end, the link text looks like the fixed URL:

<em><u>lien caché</u></em>

But the link's href is actually:

<em><u>lien caché</u></em>

If you're trying to achieve something else, please provide an example of the HTML you want to generate and more details about the parameter values and names. I'll try to help.

#1631301

Hi Christian

Thanks for the prompt response and update... really appreciate it..:-)..

I think I am clearer now on the possibilities and will try and experiment with it.. I am assuming I could easily create a button or image and put the URL as a link to the button/image.. am I right?

Let's say I have a URL which is visible only to a logged in user.. I've understood that I can pass custom URLs with parameters from other custom fields.. can I pass the email id of the logged in user? Could you please let me know how, if this is possible.?

Now I know passing the password too through the URL is not such a good idea but would it be possible too? If yes, could it be encrypted and then decrypted at the landing page?

OR would the fact that the user is logged in on a wordpress site be enough to log him in to another site in ReactJS just by having some workaround like a cookie? I have another application and I would want the user to be logged in directly when he moves from wordpress as a logged in user... alternatively if the react application does need a password input, can the react application use the wordpress database to verify the user? Of course I would be providing the React Application some credentials to access the wordpress database..

Please do advise if what I am trying to achieve above is possible and if you have an easier method to do this.

Regards,
Alim

#1632357

I am assuming I could easily create a button or image and put the URL as a link to the button/image.. am I right?
You can create a link tag and wrap it around an image tag, like this:

<a href="<em><u>lien caché</u></em>"><img src="/path/to/button-image.jpg" /></a>

If that image looks like a button, then you have created a link to Google that looks like a button. Is that what you mean?

I've understood that I can pass custom URLs with parameters from other custom fields.. can I pass the email id of the logged in user?
You can use the Views shortcode wpv-current-user to access the current User's information like email address, login or User ID. I'm not sure what you mean by email ID, but I think you get the idea. Documentation for the current User shortcode is available here with example code: https://toolset.com/documentation/user-guides/views/views-shortcodes/#wpv-current-user

[wpv-current-user info="email"]

Now I know passing the password too through the URL is not such a good idea but would it be possible too? If yes, could it be encrypted and then decrypted at the landing page?
No, Toolset has no way to access a User's password from the database using shortcodes.

OR would the fact that the user is logged in on a wordpress site be enough to log him in to another site in ReactJS just by having some workaround like a cookie?
That's a good question but since authentication and authorizaton aren't in Toolset's suite of software, I'm not really the best source of information. Toolset doesn't integrate with any Single Sign On authorization apps or platforms. A token system like Oauth2 might be helpful. There are several Oauth plugins out there like these https://www.google.com/search?q=wordpress+oauth+plugins&oq=wordpress+oauth+plugins

#1632767

My issue is resolved now. Thank you!

I am a bit clearer now.. but I think before I come back to you with questions I need to try and test a few things.. :-).. Thanks again Christian.. you've been of great help..:-)..

Regards,
Alim