modify_markdown.py 3.01 KB
Newer Older
bailuo's avatar
readme  
bailuo committed
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
import os
import re
from pathlib import Path
import requests

import fire
from dotenv import load_dotenv

load_dotenv()


def to_snake_case(s):
    s = s.lower()
    s = re.sub(r"(?<!^)(?=[A-Z])", "_", s).lower()
    s = re.sub(r"\W", "_", s)
    s = re.sub(r"_+", "_", s)
    return s

def modify_markdown(
    file_path,
    slug_number=0,
    host_url=os.environ["README_HOST_URL"],
    category=os.environ["README_CATEGORY"],
    api_key=os.environ["README_API_KEY"],
    readme_version=os.environ["README_VERSION"],
):
    with open(file_path, "r", encoding="utf-8") as file:
        content = file.read()
    dir_path = os.path.dirname(file_path)
    if not dir_path.endswith("/"):
        dir_path += "/"

    # Extract and remove the first markdown header
    pattern_header = re.compile(r"^#\s+(.*)\n+", re.MULTILINE)
    match = pattern_header.search(content)

    if match:
        title = match.group(1)
        content = pattern_header.sub("", content, count=1)  # remove the first match
    else:
        title = "Something Amazing"
    slug = to_snake_case(title)

    # Get category id for this doc based on the parent folder name
    url = "https://dash.readme.com/api/v1/categories"
    headers = {"authorization": f"{api_key}",
               "x-readme-version": f"{readme_version}"}    
    try:
        response = requests.get(url, headers=headers)
        categories = {category["slug"]:category["id"] for category in response.json()}
        if Path(file_path).name == 'CHANGELOG.md':  
            category_slug = 'getting-started'
            slug = category_slug + '-' + slug
        else:
            parent = Path(file_path).parents[0].name
            grandparent = Path(file_path).parents[1].name
            if grandparent == "docs":
                category_slug = parent
                slug = category_slug + '-' + slug
            else:
                category_slug = grandparent
                subcategory = parent
                slug = category_slug + '-' + subcategory + '-' + slug
        category = categories[category_slug]
    except:
        pass

    # Hide the unnecessary capabilities notebook for readme.com
    if slug == 'capabilities-capabilities':
        hidden = True
    else:
        hidden = False

    # Prepare the new header
    header = f"""---
title: "{title}"
slug: "{slug}"
order: {slug_number}
category: {category}
hidden: {hidden}
---

    """

    # Remove parts delimited by ::: :::
    pattern_delimited = re.compile(r":::.*?:::", re.DOTALL)
    content = pattern_delimited.sub("", content)

    # Modify image paths
    content = content.replace("![figure](../../", f"![figure]({host_url}/nbs/")
    pattern_image = re.compile(r"!\[\]\(((?!.*\.svg).*?)\)")
    modified_content = pattern_image.sub(
        r"![](" + host_url + dir_path + r"\1)", content
    )

    # Concatenate new header and modified content
    final_content = header + modified_content

    with open(file_path, "w", encoding="utf-8") as file:
        file.write(final_content)


if __name__ == "__main__":
    fire.Fire(modify_markdown)