Skip to content

Latest commit

 

History

History
92 lines (64 loc) · 5.76 KB

README.md

File metadata and controls

92 lines (64 loc) · 5.76 KB

Markdown Converter and Outliner for migration from Obsidian to Logseq

Obsidian and Logseq are two popular note-taking applications. While both applications use Markdown, they have different syntax and structure requirements. This project aims to provide tools to convert Markdown documents from Obsidian to Logseq format to facilitate migration between the two applications.

There are surprisingly a lot of differences and nuances, so I made this tool to automate the process and I'm sharing it in case it helps someone else.

Features

  • Syntax Translation: Converts various Markdown elements such as tasks, highlights, wiki-links, embeds, block quotes, callouts, and frontmatter from Obsidian to Logseq format.
    • Tasks: Converts the syntax from the popular Obsidian Tasks plugin to Logseq org-mode tasks, including dates and priorities.
    • For the full list of syntax differences, see syntax-differences.md.
  • Structure Outlining: Converts the flat structure of Markdown documents into a nested list structure suitable for Logseq.
    • The structure implied by the headings in the document is converted into an outline native to Logseq.
    • For the explanation see structure-difference.md.
  • Daily Notes: Automatically converts Obsidian daily notes to Logseq journal notes.

Motivation

Logseq advertises that you can simply point it to your folder with Markdown files and it will work, but the reality is that it will not understand some of the Markdown syntax and will treat the base structure of the files as a flat list. Logseq also changes files by treating all content as an outline which messes up the original structure and makes it harder to work with files in other applications.

While you can make Obsidian play nicely with Logseq, it doesn't go the other way around. So this project aims to provide a way to migrate to the format that Logseq expects to take full advantage of its features, then decide whether to keep using Logseq or not.

Usage

Warning

This project is still in development and may not be completely reliable. Use it at your own risk and always make backups of your files.

Also, documentation may be lacking, but don't hesitate to ask for help in the discussions

Until there are release binaries, you need to have Deno runtime installed on your system.

Then you can point Deno to the script file on GitHub to run it:

deno run https://raw.githubusercontent.com/laughedelic/outbreak/main/outbreak.ts <obsidian-vault-path> <output-path>

Alternatively, you clone the repository and run it locally. This is recommended if you want to modify the script. Once you are in the cloned repository, you can run it with the following command:

deno run outbreak.ts <obsidian-vault-path> <output-path>

Thanks to the secure Deno runtime, the script will explicitly ask you for permissions to read the input files (not modify!) and write the output files. So you know that you are not giving these scipts access to do anything else. It will then plan the migration, show you the summary, and ask for confirmation before proceeding.

  • You can use deno run --allow-read --allow-write ... to skip the permissions prompt.
  • There is also a --dry-run flag that you can use to see the plan without actually writing any files.

After you run the migration, you can open the destination folder in Logseq and see the results. If you run it more than once (e.g. after some adjustments), you should re-index the folder in Logseq to make sure it picks up the changes.

Important

Output files will be created or overwritten (!), so don't point it at your existing Logseq graph folder. Always try it on a new folder first. If you like the results, you can then copy the files to your main Logseq graph.

Tip

It is recommended to use Obsidian Linter plugin to clean up your Obsidian Markdown before committing to the migration. This will help to avoid some potential issues with inconsistent formatting.

Note

There is a lot of potential for configurability and customization in this tool. At the moment it's just tuned to my personal needs, but I want to expose the configuration to make it more flexible and useful for others.

For now, you can modify the in-code configuration directly to adjust the behavior.

Development instructions

  1. Setup: Ensure you have Deno installed on your system.

  2. Run tests:

    deno test
  3. Linting and formatting:

    deno lint
    deno fmt

Tip

Contributions are welcome! Take a look at the TODO.md file and any TODO comments in the code. Open a new discussion to plan the implementation or suggest your ideas.

Related references

  • Making Obsidian play nice with Logseq - Useful for initial exploration, but limited and dated.
  • dundalek/longdown - A tool to convert flat Markdown files to the outline structure for Logseq. This is similar to the outline feature of this project, but I found it too limited for my needs. It also doesn't handle syntax conversion.
  • vincent178/obsidian.py - A python script to migrate obsidian notes to logseq, including tasks and daily notes. It has very limited functionality and requires editing some hardcoded values before usage.