Skip to main content

An MkDocs plugin that helps exporting your Obsidian vault as an MkDocs site.

Project description

Obsidian ➡️ MkDocs Bridge

Made by Ukrainian License REUSE Compliance GitHub branch check runs

An MkDocs plugin that helps exporting your Obsidian vault as an MkDocs site.

What it does

I began writing this plugin to simplify exporting my Obsidian vault to GitHub Pages using MkDocs. The plugin is still in development since there are a lot more features that could possibly be implemented, however, currently it has the following features:

Auto-expanding incomplete links

By auto-expanding I mean that you don't need to write a full path to the page you are linking to (exactly like in Obsidian). Consider the following folder structure:

docs/
├── 2021/
│   ├── Books.md
│   └── Games.md
└── 2022/
    └── Sport.md

If you are editing Sport.md, you could write:

[Books](../2021/Books.md)

but with this plugin you can just drop the path:

[Books](Books.md)

or even write the Obsidian way:

[[Books]]

Name clashes

What if you have Books.md in both 2021 and 2022?

docs/
├── 2021/
│   ├── Books.md
│   └── Games.md
└── 2022/
    ├── Books.md
    └── Sport.md

By default, the plugin tried to find the shortest relative path (again, like Obsidian), e.g.

[[Books]]

is translated into:

[Books](./Books.md)

But you can also give the resolver a hint by specifying the path partially:

[[2021/Books]]

or

[Books](2021/Books.md)

Both variants work equivalently.

How to enable

Install the plugin with:

pip install mkdocs-obsidian-bridge

The plugin depends on some features of Python 3.10, so this is the minimum required version.

Then you can enable it in your mkdocs.yml config:

plugins:
  - obsidian-bridge

Embedding of media files

If you want to have Obsidian-like embedding of audio and video files or even YouTube videos, enable it in your mkdocs.yml like this:

markdown_extensions:
  - obsidian_media_mkdocs

More information on this feature can be found here: GooRoo/obsidian-media.

Using callouts

Looking for Obsidian-style callouts? Enable them in your mkdocs.yml like this:

markdown_extensions:
  - obsidian_callouts

More information on this feature can be found here: GooRoo/obsidian-callouts.

Why one more plugin?

I wouldn't ever write this one if I could achieve what I need with other ones. Maybe, I just couldn't find the solution, but here we are.

Comparison to others (possibly, outdated)

Differences to Autolinks Plugin

  1. Autolinks Plugin doesn't try to resolve the shortest path out of the list of potential candidates.
  2. It also doesn't support incomplete relative paths. In other words, it works only with file names.

Differences to Roamlinks Plugin

This one, actually, was the reason why I started developing my own plugin in the first place. However, it had the following drawbacks for my use-case:

  1. As well as Autolinks Plugin, the Roamlinks Plugin does not try to match the best path if there several of those, does it?
  2. Also, in case it can't resolve the [[Roam link]], it leaves it as a text, while Obsidian Bridge still transforms it into the Markdown link although invalid one.

Differences to EZLinks Plugin

This one looked like a perfect choice for my needs, however:

  1. I didn't spent much time playing with it, but EZLinks Plugin generated incorrect links for me. Probably because it doesn't resolve any incomplete paths as well as two previous plugins.
  2. At the same time, it does convert the [[internal links]] into actual links.
  3. It has no ability to distinguish between valid and invalid [[internal links]]. Maybe it could be solved by another plugin, but I haven't searched for it.

Differences to WikiLinks extension for Python-Markdown

  1. I haven't tried this one, but it looks like WikiLinks is unable to automatically resolve paths at all without an additional (and a bit cumbersome) config.
  2. Also, not sure if it supports all the Obsidian's features.

Advanced topics

Warnings for invalid links

Optionally, you can ask plugin to warn you when the resulting link still leads to an invalid target. This will prevent your site from building in “strict” mode.

Enable it like this
plugins:
  - obsidian-bridge:
      warn_on_invalid_links: true

Styling of invalid links

See for yourself!

The plugin translates Obsidian-style [[internal links]] to markdown [internal links](internal%20links) even if the resulting link is invalid. If you want to distinguish such links from the rest, you can assign them a custom CSS style.

In order to do that, you should add an invalid_link_attributes config option to your mkdocs.yml AND enable the attr_list Markdown extension:

markdown_extensions:
  - attr_list

plugins:
  - obsidian-bridge:
      invalid_link_attributes:
        - '.invalid'

extra_css:
  - stylesheets/extra.css

The .invalid in this example translates to class="invalid" HTML attribute accordingly to the rules of Attribute Lists extension.

After that, you can extend extra.css with some style (just don't forget to add extra_css property to your mkdocs.yml too as above):

a.invalid {
  color: red;
}

Alternatively, if your style is going to be simple, you can just write it in the attribute itself as following:

markdown_extensions:
  - attr_list

plugins:
  - obsidian-bridge:
      invalid_link_attributes:
        - 'style="color: red"'

What's next

My current preliminary roadmap is the following:

I give no guarantees about the deadlines or whether I implement anything at all. I do it for myself and currently I do see a need, so probably I'll continue.

Feedback

I do appreciate any kind of constructive feedback.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mkdocs_obsidian_bridge-1.3.1.tar.gz (65.1 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mkdocs_obsidian_bridge-1.3.1-py3-none-any.whl (10.1 kB view details)

Uploaded Python 3

File details

Details for the file mkdocs_obsidian_bridge-1.3.1.tar.gz.

File metadata

  • Download URL: mkdocs_obsidian_bridge-1.3.1.tar.gz
  • Upload date:
  • Size: 65.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for mkdocs_obsidian_bridge-1.3.1.tar.gz
Algorithm Hash digest
SHA256 92d7cee4dc857a45818b912c0091452a22976250513ee63fb4c1f64bb06d2ab8
MD5 36a5201a1a5c8b7e9dc23b5839776ef0
BLAKE2b-256 ee93d0dda71bacfcbdeb522a16e895311669a75eda3e7872e6182a5957520877

See more details on using hashes here.

Provenance

The following attestation bundles were made for mkdocs_obsidian_bridge-1.3.1.tar.gz:

Publisher: build-deploy.yml on GooRoo/mkdocs-obsidian-bridge

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mkdocs_obsidian_bridge-1.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for mkdocs_obsidian_bridge-1.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8653c49f970ad1e6c08983e5c9d0cfc2be4af0d432e415a5e601b9be00696126
MD5 d40fa7810d50d8d5e5491f6b5a2fc699
BLAKE2b-256 253fb250670f6a960186f556a49b6ab8714867065a0d03565cb678a3d0313216

See more details on using hashes here.

Provenance

The following attestation bundles were made for mkdocs_obsidian_bridge-1.3.1-py3-none-any.whl:

Publisher: build-deploy.yml on GooRoo/mkdocs-obsidian-bridge

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page