Skillmap generates a skill tree from a toml file
Project description
skillmap
A tool for generating skill map/tree like diagram.
What is a skill map/tree?
Skill tree is a term used in video games, and it can be used for describing roadmaps for software project development as well.
This project borrows inspiration and ideas from two sources:
- https://hacks.mozilla.org/2018/10/webassemblys-post-mvp-future/
- https://github.com/nikomatsakis/skill-tree
Features
- skill tree/map generation
- specify pre-requisite skills
- multiple themes
- multiple skill progress bar styles
Installation
pip install skillmap
After installation, a skillmap
command is available.
Usage
- Create a toml format skill map descriptor file. You can find more details about this descriptor format here. For a minimal example, see
docs/examples/hello_world.toml
[skillmap]
name = "hello world"
icon = "bicycle"
[groups.learn_python]
name = "learn python"
icon = "rocket"
[groups.learn_python.skills.print]
name = "print statement"
icon = "printer"
[groups.learn_python.skills.string]
name = "string literal"
icon = "book"
- Run
skillmap path/to/your/skillmap.toml
- For example,
skillmap docs/examples/hello_world.toml
- For example,
- Copy the generated skill map diagram to your clipboard.
- Paste the diagram to a mermaid diagram editor, for example,
https://mermaid-js.github.io/mermaid-live-editor
.
Examples
- Each node can have a string label and an fontawsome icon.
- Skills with different statuses will be shown with different colors.
- Each skill may have a progress bar to indicate its learning progress.
- Unnamed skill will be shown as a locked skill.
- Pre-requisite skills will be connected with an directed edge.
- You can embed the generated mermaid diagram into github markdown directly, but the fontawesome icons in the diagrams are not shown by github so far.
License
More details
- Skillmap toml descriptor format can be found here
- hot reloading when authoring a skillmap toml file
- install several tools to make hot reloading to work
entr
, run arbitrary commands when files change- Visual Studio Code + Markdown Preview Enhanced Visual Studio Code Extension
- Basically, use
entr
to watch toml file changes, and generate amd
makrdown file usingskillmap
every time when toml file changes. And usevscode
+Markdown Preview Enhanced
extension to open this generated markdown file. Check outbuild_sample
anddev_sample
in justfile to see how to make hot reloading work
- install several tools to make hot reloading to work
Known issues
- Sometimes, the group's text will be clipped when rendered in mermaid. And you have to edit the generated file slightly and then change it back to ask mermaid to refersh the diagram to avoid clipping. It is probably a bug for mermaid as far as I can tell.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
skillmap-0.3.0.tar.gz
(9.0 kB
view details)
Built Distribution
skillmap-0.3.0-py3-none-any.whl
(11.0 kB
view details)
File details
Details for the file skillmap-0.3.0.tar.gz
.
File metadata
- Download URL: skillmap-0.3.0.tar.gz
- Upload date:
- Size: 9.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.12 CPython/3.9.0 Darwin/21.3.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 72ee34764f1ed959b405dfd8c03579a34fb9b8babaebe66c93a85e3f8ef26564 |
|
MD5 | b081374d785cff7c5f76d4bb00f90c2f |
|
BLAKE2b-256 | a96d5c0e635824177ef5915c46ab17fa2b3287d2ba9c6ab2a436825eb2b02b11 |
File details
Details for the file skillmap-0.3.0-py3-none-any.whl
.
File metadata
- Download URL: skillmap-0.3.0-py3-none-any.whl
- Upload date:
- Size: 11.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: poetry/1.1.12 CPython/3.9.0 Darwin/21.3.0
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | bbaffc47ac1972fec7d8f607fc9427dea286a5dba3442fb707d4e39268e03475 |
|
MD5 | 2328dc691d80f51a06e15be49372890b |
|
BLAKE2b-256 | 13f6a11a6bfeec1323efaa0657ce13f90800d2c2b99cf0189838313818841a82 |