2024-08-30 15:30:42 +00:00
|
|
|
import re
|
2024-08-31 15:47:54 +00:00
|
|
|
import string
|
2024-08-30 15:30:42 +00:00
|
|
|
from mkdocs.config.defaults import MkDocsConfig
|
|
|
|
from mkdocs.structure.pages import Page
|
|
|
|
from mkdocs.structure.files import Files
|
2024-08-31 15:47:54 +00:00
|
|
|
from mkdocs.plugins import event_priority
|
2024-08-30 15:30:42 +00:00
|
|
|
|
|
|
|
|
2024-08-31 15:47:54 +00:00
|
|
|
IMG_SIZED_RE = (
|
|
|
|
r"\!\[.*?\s*(?P<width>\d+)x(?P<height>\d+)(?:,\s*(?P<multi>\d+)%)?\]\(.*\)"
|
|
|
|
)
|
2024-08-30 15:30:42 +00:00
|
|
|
"""Used to get width, height from `text|WIDTHxHEIGHT`"""
|
|
|
|
|
|
|
|
|
|
|
|
def _add_attr_handler(match: re.Match[str]) -> str:
|
2024-08-31 15:47:54 +00:00
|
|
|
width = match.group("width")
|
|
|
|
height = match.group("height")
|
|
|
|
if multi := match.group("multi"):
|
2024-08-30 15:30:42 +00:00
|
|
|
multi = int(multi) / 100
|
|
|
|
width = str(int(width) * multi)
|
|
|
|
height = str(int(height) * multi)
|
2024-08-31 15:47:54 +00:00
|
|
|
res = match.group(0) + string.Template(
|
2024-09-01 02:34:34 +00:00
|
|
|
'{ style="max-width:${width}px; max-height:${height}px; width: 100%;" }'
|
2024-08-31 15:47:54 +00:00
|
|
|
).substitute(width=width, height=height)
|
2024-08-30 15:30:42 +00:00
|
|
|
return res
|
|
|
|
|
|
|
|
|
|
|
|
is_enabled: bool
|
|
|
|
|
|
|
|
|
|
|
|
def on_config(config: MkDocsConfig):
|
|
|
|
global is_enabled
|
|
|
|
is_enabled = "attr_list" in config.markdown_extensions
|
|
|
|
|
|
|
|
|
2024-08-31 15:47:54 +00:00
|
|
|
@event_priority(70)
|
2024-08-30 15:30:42 +00:00
|
|
|
def on_page_markdown(
|
|
|
|
markdown: str, page: Page, config: MkDocsConfig, files: Files, **kargs
|
|
|
|
):
|
|
|
|
if is_enabled:
|
2024-08-31 15:47:54 +00:00
|
|
|
return re.sub(IMG_SIZED_RE, _add_attr_handler, markdown)
|