Per this article, “What (sic) HTML tags are supported in GMail,” the <a> tag is supported, however, I am wondering if the <a> tag’s `<a ping="URL">”` attribute is supported (along with the more common `<a href="URL">”` attribute which works just fine)?
When I open the following HTML in a browser:
<ahref="craigslist.org"ping="https://hooks.zapier.com/hooks/catch/8675309/biv0iDs/?recordID=rec6q2j4pSPxwWjcl&emailResponse=a%20ping">PRESS TO PING</a>
...it creates a hyper text link to Craigslist. When I click the link, it also invokes a ping to the Zapier Webhook URL. The Webhook trigger Catch Hook URL catches the data, and a subsequent Zapier Action updates via the recordID query parameter and updates the appropriate record’s field with the emailResponse parameter.
When I include this HTML code in a GMail, the result is only loading Craigslist - no Hook Catch :\
Is this a GMail restriction? Zapier?
Which attributes of the HTML <a></a> tag are supported?
Thanks!
Best answer by mixelpixBest answer by mixelpix
@Troy Tessalone well, well, well… I finally found an official, documented answer to my question,
Is the HTML "a" tag attribute "ping" supported by the Gmail actions?
Google can follow your links only if they use proper <a> tags with resolvable URLs:
Use proper <a> tags
Google can follow links only if they are an <a> tag with an href attribute. Links that use other formats won't be followed by Google's crawlers. Google cannot follow <a> links without an href tag or other tags that perform a links because of script events. Here are examples of links that Google can and can't follow:
Can follow:
<a href="https://example.com">
<a href="/relative/path/file">
Can't follow:
<a routerLink="some/path">
<span href="https://example.com">
<a onclick="goto('https://example.com')">
Link to resolvable URLs
Ensure that the URL linked to by your <a> tag is an actual web address that Googlebot can send requests to, for example:
Using the Inspect Element feature with the resulting email, it looks like Google just strips it out and I end up with this:
<ahref="http://craigslist.org"style="font-family:Times;font-size:medium"target="_blank"data-saferedirecturl="https://www.google.com/url?q=http://craigslist.org&source=gmail&ust=1637900891505000&usg=AOvVaw1cH5088iEoNuENLATzmD1F">PRESS TO PING</a>
Bummer… I thought I’d found a workaround to using the href attribute with Webhook links - they open a separate browser tab with the response JSON (or in silent mode), the ping doesn’t...
Another option is to add some JavaScript to the page where the link clicks thru to.
That JavaScript would pull query string parameters from the resolved URL and append those values to the webhook then fire the webhook in the JavaScript.
@Troy Tessalone thanks for the suggestion! I will check out the related topic.
Another option is to add some JavaScript to the page where the link clicks thru to.
...oh, I didn’t realize this was an option with the Catch Hook url. The Zapier action supports this, or is there additional wizardry involved?
To clarify, the webhook url i wanted to use as the html <a>nchor ping returns a text string from the “success” json object (or can be opened in silent mode which renders a blank page). This is poor UX for the client. Are you saying the I can add HTML code to the catch hook url, or per the example you linked, are you suggesting I use a code step after the hook is caught to parse the query parameters?
@Troy Tessalone mostly just looking for a better option than what the catch hook’s return page loads: json or blank appended with /silent mode… With a proper webpage I could have a choice confirmation button which loaded a thank you screen along with sending the <a> ping=URL to the catch hook
Mostly just looking for solutions to send a “yes or no” poll to clients so the response makes it back to Airtable to trigger further actions relative to the answer.
I haven’t used miniExtensions, but I have watched a bunch of their demo videos.
From what I can tell, the forms they produce give quite a lot of leeway in what can be exposed relative to the linked table’s structure.
I am envisioning a table which may have several records per client, but I want to have the outreach be discreet per each client’s record, e.g. in a month, five records may be created which reference the same client, and I would want them to only see the one at a time.
The table is essentially a join of two other tables. The client would be joined to another data structure, and each join it’s own unique case to manage.
Do you know if miniExtensions facilitates such constraint, or would it allow the client to see all of the join records on the table? From what I can tell, I could use miniExtensions in a Zap per constraint, i.e. I would need to create a miniExtension Zap actions per client record on the linking “join” table (which would be prohibitive).
Before I dive into that rabbit hole, am I understanding you correctly - like, for a customer support agent to send an outreach email to a client per a specific record, miniExtensions creates a specific url the client can use for the access to update fields on that one record? I.e. with a triggering single-select or checkbox, we could fire of a zapier action to send an email to the client with the miniextensions link embedded in hypertext for any of the records on the table as they get created?
Google can follow your links only if they use proper <a> tags with resolvable URLs:
Use proper <a> tags
Google can follow links only if they are an <a> tag with an href attribute. Links that use other formats won't be followed by Google's crawlers. Google cannot follow <a> links without an href tag or other tags that perform a links because of script events. Here are examples of links that Google can and can't follow:
Can follow:
<a href="https://example.com">
<a href="/relative/path/file">
Can't follow:
<a routerLink="some/path">
<span href="https://example.com">
<a onclick="goto('https://example.com')">
Link to resolvable URLs
Ensure that the URL linked to by your <a> tag is an actual web address that Googlebot can send requests to, for example: