Creates links next to all heading tags to make it easier for users to share a specific heading.
post_render function
This plugin creates a link svg next to all headings.
post_render source
def post_render(markata: Markata) -> None:
"""
This plugin creates a link svg next to all headings.
"""
config = markata.get_plugin_config(__file__)
should_prettify = markata.config.get("prettify_html", False)
with markata.cache as cache:
for article in markata.iter_articles("link headers"):
key = markata.make_hash(
"heading_link",
"post_render",
Path(__file__).read_text(),
article.content,
article.html,
)
html_from_cache = cache.get(key)
if html_from_cache is None:
html = link_headings(article, should_prettify)
cache.add(key, html, expire=config["cache_expire"])
else:
html = html_from_cache
article.html = html
link_headings function
Use BeautifulSoup to find all headings and run link_heading on them.
link_headings source
def link_headings(article: "Post", prettify: bool = False) -> Any:
"""
Use BeautifulSoup to find all headings and run link_heading on them.
"""
soup = BeautifulSoup(article.html, "html.parser")
for heading in soup.find_all(re.compile("^h[1-6]$")):
if (
not heading.find("a", {"class": "heading-permalink"})
and heading.get("id", "") != "title"
):
link_heading(soup, heading)
if prettify:
return soup.prettify()
return str(soup)
link_heading function
Mutate soup to include an svg link at the heading passed in.
link_heading source
def link_heading(soup: "bs4.BeautifulSoup", heading: "bs4.element.Tag") -> None:
"""
Mutate soup to include an svg link at the heading passed in.
"""
id = heading.get("id")
link = soup.new_tag(
"a",
alt="id",
title=f"link to #{id}",
href=f"#{id}",
**{"class": "heading-permalink"},
)
span = soup.new_tag("span", **{"class": "visually-hidden"})
svg = soup.new_tag(
"svg",
fill="currentColor",
focusable="false",
width="1em",
height="1em",
xmlns="http://www.w3.org/2000/svg",
viewBox="0 0 24 24",
**{
"aria-hidden": "true",
},
)
path = soup.new_tag(
"path",
d="M9.199 13.599a5.99 5.99 0 0 0 3.949 2.345 5.987 5.987 0 0 0 5.105-1.702l2.995-2.994a5.992 5.992 0 0 0 1.695-4.285 5.976 5.976 0 0 0-1.831-4.211 5.99 5.99 0 0 0-6.431-1.242 6.003 6.003 0 0 0-1.905 1.24l-1.731 1.721a.999.999 0 1 0 1.41 1.418l1.709-1.699a3.985 3.985 0 0 1 2.761-1.123 3.975 3.975 0 0 1 2.799 1.122 3.997 3.997 0 0 1 .111 5.644l-3.005 3.006a3.982 3.982 0 0 1-3.395 1.126 3.987 3.987 0 0 1-2.632-1.563A1 1 0 0 0 9.201 13.6zm5.602-3.198a5.99 5.99 0 0 0-3.949-2.345 5.987 5.987 0 0 0-5.105 1.702l-2.995 2.994a5.992 5.992 0 0 0-1.695 4.285 5.976 5.976 0 0 0 1.831 4.211 5.99 5.99 0 0 0 6.431 1.242 6.003 6.003 0 0 0 1.905-1.24l1.723-1.723a.999.999 0 1 0-1.414-1.414L9.836 19.81a3.985 3.985 0 0 1-2.761 1.123 3.975 3.975 0 0 1-2.799-1.122 3.997 3.997 0 0 1-.111-5.644l3.005-3.006a3.982 3.982 0 0 1 3.395-1.126 3.987 3.987 0 0 1 2.632 1.563 1 1 0 0 0 1.602-1.198z",
)
svg.append(path)
link.append(span)
link.append(svg)
heading.append(link)