Two links now breaks footnotes with BlogText
-
I have been using the BlogText plugin with footnotes for a long time, and this is a recent bug with a recent version of footnotes. I do not know when it was introduced, but it has been reproduced in PHP 7.3.23, WordPress 5.6, BlogText 0.9.9 and footnotes versions:
– 2.2.4
– 2.2.3
– 2.1.6BlogText is: https://www.ads-software.com/plugins/blogtext/
—-
# example one
A page whose content is only:
((https://example.com https://example.com))
The footnotes section of the preview will have:
https://example.com function footnote_expand_reference_container_68257() { jQuery('#footnote_references_container_68257').show(); jQuery('#footnote_reference_container_collapse_button_68257').text('?'); } function footnote_collapse_reference_container_68257() { jQuery('#footnote_references_container_68257').hide(); jQuery('#footnote_reference_container_collapse_button_68257').text('+'); } function footnote_expand_collapse_reference_container_68257() { if (jQuery('#footnote_references_container_68257').is(':hidden')) { footnote_expand_reference_container_68257(); } else { footnote_collapse_reference_container_68257(); } } function footnote_moveToAnchor_68257(p_str_TargetID) { footnote_expand_reference_container_68257(); var l_obj_Target = jQuery('#' + p_str_TargetID); if (l_obj_Target.length) { jQuery('html, body').animate({ scrollTop: l_obj_Target.offset().top - window.innerHeight * 0.2 }, 380); } }
.. it will also have my sidebar below it.
—-
# example two
(( [[google:https://example.com|]] ))
The footnote will appear as:
https://example.com">https://example.com
-
Thank you for reporting that the regex still not works correctly. Footnotes needs to wrap all human-readable URLs in a span of class footnote_url_wrap. The regex is set up to exclude all URLs preceded by a quotation mark preceded by an equals sign preceded by a word character. You are having URLs that must not be wrapped and are preceded by anything else? I’m helpless about getting that regex right. See all the issues faced until now:
https://www.ads-software.com/support/topic/broken-layout-starting-version-2-1-4/
https://www.ads-software.com/support/topic/2-1-4-breaks-on-my-site-images-dont-show/
The initial issue solved by breaking URLs was with page layout:
https://www.ads-software.com/support/topic/footnotes-on-mobile-phones/
But breaking all link elements is a non-starter, because the link text may not be a URL, and a URL may not be hyperlinked.
The current regex:
'#(?<!\w=[\'"])(https?://[^\\s<]+)#'
In example one, the problem is that the
<?script?><?/?script?>
tags are missing. The bare script is printed outside the reference container, and without script tags it displays as text wherever it will flow in the DOM, for instance above your sidebar.In example two, what is the double-bracketed shortcode converted to in the first place before Footnotes runs? Here, the
<?a href="
start of the opening tag is missing.I can’t ascertain that these two issues are related to the Footnotes plugin. I even think they’re not, but I can be wrong. May you please share a page where the bugs are occurring so we can take a closer look into them?
I didn’t examine blogtext yet, but I’ll install it, look into what it does, and see what happens.
Essentially you get broken markup. What is the priority level of the_content hook in your instance of Footnotes? It’s in the dashboard under the Priority level tab.
I can now tell as much as that BlogText runs at priority level 5, before Footnotes, so Footnotes does not interfere with the BlogText wiki syntax based on Creole wiki.
In your first example, the URL is repeated without any markup or shortcodes other than the footnote start and end tags, in the output it is single.
As a last-resort workaround, you may try how it looks after disabling URL wrap under General settings > Reference container > Allow URLs to line-wrap anywhere: -> No.
I’ve reproduced both examples and added two more. None of them showed the output you are getting. I’ve also made 8 screenshots, both from the editor and the front-end pages, uploaded them on ImgBB and labeled the share links.
Then I noticed that WordPress adds automatically <?code> tags around the URLs, preventing BlogText from hyperlinking them. So I switched to the WordPress code editor and redacted the unwanted tags. Then the front end page was broken.
<h2>Example One</h2>
Turned out that several tags were jumbled up. E.g. in the lone referrer’s tooltip’s code, the first instance of htt?p://example.com is wrapped in the URL line wrap span without having been hyperlinked by BlogText, while the second instance started being hyperlinked, then the code stopped at the end of the href argument value, without the closing quotation mark, closing pointy bracket, link text, closing <?/?a?> tag, all missing. That disabled the tooltip script coming behind.
Of course, deactivating either BlogText or Footnotes fixed it, but that fix is completely useless since your point is to get them to work together. Anyway since WordPress added to the mess, I’ve deleted the screenshots from ImgBB as useless, and redacted the share URLs from this draft.
Part of the errors is due to the fact that BlogText is unable to parse a URL when it is preceded by an opening parenthesis, and that it includes any number of trailing closing parentheses in the URL. The latter point is documented in BlogText’s Wiki Syntax: https://blogtext.mayastudios.com/syntax/#links
So the correct syntax for your example one is:
(( https://example.com https://example.com ))
Then the front-end output without Footnotes is:
(( [external link icon]https://example.com [external link icon]example.com))
Notice that while BlogText correctly removes the required trailing space before the closing parentheses, it does not so for the (equally required but perhaps undocumented) leading space after an opening parenthesis.
After re-activating Footnotes, the front-end has referrer, tooltip and reference container without any jumbled HTML markup. Even after deleting the leading space, that holds true beside the missing hyperlink on the first instance of the URL.
But deleting the required trailing space restores the disorder. Not exactly the same as you reported, but no matter, the page is broken.
As a takeaway, please note that BlogText’s wiki syntax may be somewhat tricky, so please make sure to first check out its documentation at https://blogtext.mayastudios.com/syntax/
<h2>Example Two</h2>
Likewise after redacting the wrong <?code> tags that WordPress’ block editor wrapped your string into, additionally to the <?p> tags, without Footnotes I got the wiki syntax parsed but BlogText throws a warning because I didn’t set it up to know the “google:” prefix:
(( https://example.com[unknown prefix: google] ))
A hyperlink is drawn around with class not-found and an empty href (just the hash, same effect as empty string: current page). With Footnotes enabled, the whole thing is made a footnote linked from a lone referrer. But I can’t reproduce the jumble string that you reported. It may depend on what the
google:
prefix is interpreted as: a category? a link pattern (search on Google or something)?A way to address the issue is to deactivate all plugins except BlogText. In a next step, Footnotes is activated.
The theme might play a role too. I tested in OceanWP https://www.ads-software.com/themes/oceanwp/ — Meaning that OceanWP works well and perhaps prevented the mess from happening. Would you like to give OceanWP a try and see how it works out? Just trying to solve your issue.
I need to take more time to read your replies and understand this problem.
Some quick comments:
– The format
(( https://example.com https://example.com ))
(with spaces) displays correctly. I use this format already, so I am happy with this.
– I tried with OceanWP and see no changes.
– Setting Footnotes “Allow URLs to line-wrap anywhere” setting tono
seems to have fixed the problem.
– The style seems a little odd to me, I will have to investigate the settings.
– The Blogtext interlink for “google” isgoogle = https://www.google.com/search?q=$1
– An example URL is https://blog.spiralofhope.com/?p=68575
– I have kept “Allow URLs to line-wrap anywhere” asyes
for your examination.The content of that page is:
(( https://example.com https://example.com ))
(( [[google:https://example.com|]] ))
I need to read your replies again more carefully to see what else I can test and if I can help more.
Thank you very much for your bug report and for all your investigation and comments. Thanks to your help, Footnotes’ bugfix release 2.2.6 has just been rolled out (one hour ago meanwhile). In the URL wrap regex, the quotation mark in the exclusion (negative lookbehind) needed to become optional so as to catch URLs as a query string, that are preceded by an equal sign preceded by a word character:
'#(?<!\w=[\'"]?)(https?://[^\\s<]+)#'
New is the question mark after the quotation mark class.
That regex was a disaster. Multiple times I got it wrong so it caught too many URLs. URLs as image sources needed to be excluded, as ARIA labels, and now as query strings. All occurring in footnotes.
What I need is not a regex to parse the content for URLs. The target are only those long strings in footnotes text that are longer than a line without any space as a break opportunity. Unicode accounts for these and recommends that rendering engines break those strings at slashes, that typically occur in multiple instances in those strings. Firefox correctly implements Unicode, Chrome does not. So in Chrome, those strings hang out of Footnotes’ tooltips, and more damaging, make the reference container expand out of the screen, causing it either to need horizontal scrolling, or to become downright partly hidden.
So to fix Google’s browser bug, Footnotes needs to allow those strings to line-wrap anywhere. So it needs a good regex catching those strings, and no more than those. There seems to be no documentation out there about all contexts where a URL may occur in outer HTML. We need a regex catching URLs only in inner HTML.
Thanks a lot again. I think that you don’t need to investigate the issue further. I apologize for causing you all these hassles. In return I’d like to be somehow helpful by hinting that the top-level heading element should occur only once in a page, in WordPress typically for the post title, so the <?h1><?/h1?> around the reference container label is non-standard. Now (since 2.2.5) you can have a heading element instead of the previously hard-coded paragraph element, thanks to @markhillyer who also added a heading element in the label textbox. The setting is under General settings > Reference container > Heading’s HTML element. The choice currently encompasses only the p and h2..h6 elements (I’m unable to figure out what other elements could be used instead). The “heading?1” is missing from the list because it is not allowed in this instance per the standard. (Once that is fixed, the expand-collapse button should automatically align after the label again.)
Thank you.
- This reply was modified 3 years, 11 months ago by pewgeuges. Reason: Add “and for all your investigation and comments”
Hm. Between 2.2.5 and 2.2.6 I started getting this warning in the error log, and all my references were missing and the in-text footnotes were all numbered “1”:
PHP Warning: preg_replace(): Compilation failed: lookbehind assertion is not fixed length at offset 0 in […]/wp-content/plugins/footnotes/class/task.php on line 674
PHP version is 7.4.13, no other plugins that would be rewriting the post text before footnotes gets involved. Changing the regex back to ‘#(?<!\w=[\'”])(https?://[^\\s<]+)#’ fixes it for me. That sounds like a gnarly problem to be trying to solve; I don’t envy you the task.
I experienced the same error after the update: all references missing and the in-text footnotes were all numbered “1.”
Dialed back to 2.2.5 for the time being.
Removing the second question mark from line 674 of class/task.php in 2.2.6 worked for me. It looks like the only other difference in 2.2.6 was something to do with templates, which I’m not using, so rolling back to 2.2.5 would also have been a good fix.
Thank you all! You are my saviors. Only I mistook @rjl20 for the OP; that is now corrected in the changelog and file comment.
I thought the second question mark was obvious to make the quotation mark optional to account for query string URL parameters. Turns out a regex cannot have variable lookbehinds. The fix is to have two of them, one with quotation mark, one without. So luckily the current 2.2.8 fixes both bugs.
Never thought that regexes are tricky to that extent. But I can see some good point, since to look back, the engine apparently needs to know how many characters to step back…
Many thanks to all participants in this thread, both for bringing up the bug, and for debugging the fix.
- This reply was modified 3 years, 11 months ago by pewgeuges. Reason: fix English: “a regex cannot have”, not “may not”
Thanks @pewgeuges for all your assistance.
I confirm that the problem has been solved for me.
Also, thanks a lot for the other adjustments which helps the style of my footnotes title. I’ve made it H2, which is fine for me. (If I really wanted to, I could make my H6 look like my H1). There are some color preferences I have but I will make it plain for now; I think it looks great.
Again, wonderful work!
Thank you for your confirmation and feedback!
@spiralofhope2, @rjl20, @spaceling
To prevent further bugs, Footnotes’ upcoming bugfix release 2.2.9 proactively accounts for the whole set of characters allowed in parameter names per RFC 2396, and also excludes URLs where the equals sign is preceded by an entity or character reference, i.e. by a semicolon. A preview (2.2.9d2) is still available at https://downloads.www.ads-software.com/plugin/footnotes.zip but the release is scheduled to be rolled out soon.
2.2.9 contains a major fix to disambiguate multiple reference containers in a page, making them actually functional, and ensuring the usability of the widget_text hook support. It was requested as soon as on November?13, but I had little clues about how to solve the problem.
This release is tested and has no unexpected behavior; the only default setting to be changed is the widget_text hook priority level, equalized to the level of the_content: 98, to run before the Pinterest share button may be added (by one preferred plugin) yielding a script that has the
((
pattern, and even))
.Thank you for your help and cooperation to fix Footnotes.
I beg your pardon for my repeated flaws and mistakes in the release process.
Happy holidays with best wishes for safety and health.
@spiralofhope2 Please do not create duplicate topics. I have removed your new one. If you need to continue with this problem them feel free to do so here.
It’s your topic. You can mark it unresolved in the sidebar.
I’ve marked it unresolved following @jdembowski’s action. You are welcome to report further bugs and ask questions.
The next release to roll out shall be 2.3.0 where AMP compatibility optional hard links are in the process of being added. It’s not easy but hopefully Footnotes will have well functioning optional hard links very soon.
This problem is resolved. That other non-duplicate problem is unresolved.
- The topic ‘Two links now breaks footnotes with BlogText’ is closed to new replies.