diff options
author | Zhiming Wang <zmwangx@gmail.com> | 2015-07-24 00:59:53 -0700 |
---|---|---|
committer | Zhiming Wang <zmwangx@gmail.com> | 2015-07-24 00:59:53 -0700 |
commit | 2ecbd7fd0278e900b094f775538abf20f4791c51 (patch) | |
tree | 1c741be22adf3bd06265baf6ddcc98c1deea278b /pyblog | |
parent | 4b610726f4d747bccf7c102dca2b0b9c29b61408 (diff) | |
download | my_new_personal_website-2ecbd7fd0278e900b094f775538abf20f4791c51.tar.xz my_new_personal_website-2ecbd7fd0278e900b094f775538abf20f4791c51.zip |
pyblog: add postprocessor process_footnote_backlinks
Add class and variation selector (# U+FE0E: VARIATION SELECTOR-15) to
U+21A9: LEFTWARDS ARROW WITH HOOK to fix outstanding font issue of
footnote backlinks on mobile.
Updated styles accordingly.
Trick learned from Daring Fireball.
Before: https://i.imgur.com/eUbL1k8.png
After: https://i.imgur.com/msv3INn.png
Diffstat (limited to '')
-rwxr-xr-x | pyblog | 13 |
1 files changed, 13 insertions, 0 deletions
@@ -625,6 +625,18 @@ def link_img_tags(soup): img_tag.replace_with(a_tag) +def process_footnote_backlinks(soup): + """Add class attribute "footnotes-backlink" to each footnote backlink.""" + for footnotes in soup.find_all("div", attrs={"class": "footnotes"}): + for fn_a_tag in footnotes.find_all(lambda tag: + tag.name == "a" and + tag.has_attr("href") and + tag["href"].startswith("#fnref") and + tag.string == "\u21A9"): # U+21A9: LEFTWARDS ARROW WITH HOOK + fn_a_tag["class"] = "footnotes-backlink" + fn_a_tag.string = "\u21A9\uFE0E" # U+FE0E: VARIATION SELECTOR-15 + + def postprocess_html_file(htmlfilepath): """Perform a series of postprocessing to an HTML file.""" with open(htmlfilepath, "r+", encoding="utf-8") as htmlfileobj: @@ -633,6 +645,7 @@ def postprocess_html_file(htmlfilepath): # a series of postprocessing (extensible) number_code_lines(soup) link_img_tags(soup) + process_footnote_backlinks(soup) # write back htmlfileobj.seek(0) |