SkillAgentSearch skills...

Docution

Host your documentation easily on Notion

Install / Use

/learn @astariul/Docution
About this skill

Quality Score

0/100

Supported Platforms

Universal

README

<p align="center"> <img src="https://user-images.githubusercontent.com/43774355/122677521-988a0a00-d21d-11eb-8222-91d82c4ef546.png" width=300> </p> <p align="center"><b>🚧 This is an <i>alpha</i> version of the project, a proof of concept. Looking for collaborators !</b></p> <p align="center">Bring autodoc capabilities to your Notion workspace with Docution</p> <p align="center"> <a href="https://github.com/astariul/docution/actions/workflows/lint.yml"><img src="https://github.com/astariul/docution/actions/workflows/lint.yml/badge.svg" alt="test status" /></a> <a href="https://github.com/astariul/docution/releases"><img src="https://img.shields.io/github/v/release/astariul/docution" alt="release" /></a> </p> <p align="center"> <a href="#description">Description</a> • <a href="#install">Install</a> • <a href="#usage">Usage</a> • <a href="#faq">FAQ</a> • <a href="#contribute">Contribute</a> • <a href="#roadmap">Roadmap</a> <br> <a href="https://www.notion.so/Documentation-bb693b18c3b1433ca076eec9fcb8a2db" target="_blank">Documentation</a> </p> <h2 align="center">Description</h2>

Writing documentation in Notion is an attractive alternative to other solutions :

  • ✨ Neat interface, rich text editing
  • 👥 Easy to share and collaborate, while keeping it private
  • 🚀 Already hosted !

But Notion lacks features that makes the power of other solutions, like auto-documentation ! This is the role of docution : a python package and command line that updates your Notion pages with clean formatted documentation.

<h2 align="center">Install</h2>

Simply run :

pip install docution
<h2 align="center">Usage</h2>

In your Notion page, create a text block like follow :

/docution my_module.my_function

After creating your integration and giving it access to your page, just run :

docution --auth_token <secret> --page_id <id>

And here you go ! Your Notion page is updated with your documentation :


You can check the docution usage with :

docution --help

Please also check the documentation for a full example with all the details !

<h2 align="center">FAQ</h2>

Why is it in alpha ?

Currently, the official Notion API is in beta, which means it can change anytime.

Also, this project needs additional features that are not implemented in the Notion API yet to be fully functional. So for now, this is just a proof of concept.

Checkout the current limitations for more details.

How does it work ?

When you use the docution command line, the following happens :

  • Retrieve all the blocks used in the Notion page with the given ID
  • Detect the blocks that are a docution command (/docution a.b.c)
  • Import the docstring of the object a.b.c
  • Correctly format the docstring as Notion blocks
  • Write these blocks in your Notion page
<h2 align="center">Contribute</h2>

Clone the repository locally, create your branch, push your changes and open a PR !


Check if code is well-formated :

pip install flake8

flake8 . --count --max-complexity=10 --max-line-length=127 --statistics
<h2 align="center">Roadmap</h2>
  • Add missing functionality to be similar to sphinx (document public methods of class, etc...)

  • Add option to specify path of module

  • Add option for private members, only specific member, etc...

  • Should we add the module name (when documenting module) ? Add option for that ?

  • Should we add only the name of the thing, or the whole path ? Add option for that ?

  • Add option for dryrun

  • Change parser to pardoc ? To handle other type of section, like Example.

  • Optimize API call to NOT do recursive calling (for now, no choice)

  • Handle markdown ?

  • Handle RST ?

Related Skills

View on GitHub
GitHub Stars11
CategoryDevelopment
Updated1y ago
Forks0

Languages

Python

Security Score

60/100

Audited on Jun 30, 2024

No findings