Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/dineshsonachalam/markdown-autodocs

✨ A GitHub Action that automatically generates & updates markdown content (like your README.md) from external or remote files.
https://github.com/dineshsonachalam/markdown-autodocs

Last synced: 2 months ago
JSON representation

✨ A GitHub Action that automatically generates & updates markdown content (like your README.md) from external or remote files.

Awesome Lists containing this project

README

        






A GitHub Action that automatically generates & updates markdown content (like your README.md) from external or remote files.



























npm version


MIT License

Ask questions in the GitHub issues

## Table of contents

* [Why markdown-autodocs?](#why-markdown-autodocs)
* [Features](#features)
* [Examples](#examples)
* [CODE Block](#code-block)
* [JSON to HTML table](#json-to-html-table)
* [Github Workflow Artifacts table](#github-workflow-artifacts-table)
* [Example Repo which uses all the markdown-autodocs feature](#example-repo-which-uses-all-the-markdown-autodocs-feature)
* [Local usage without Github action](#local-usage-without-github-action)
* [Usage](#usage)
* [Adding markdown-autodocs in your workflow](#adding-markdown-autodocs-in-your-workflow)
* [Extended example with all possible options available for this Action](#extended-example-with-all-possible-options-available-for-this-action)
* [Github Workflow Artifacts](#github-workflow-artifacts)
* [Contributing](#contributing)
* [Used By](#used-by)
* [License](#license)

## Why markdown-autodocs
To make your repo more appealing and useful you need to provide example code snippets in your README.md. Manually copy and pasting each code snippet in their respective places in your README would be inefficient and time-consuming.

This problem can be solved using markdown-autodocs a GitHub Action that automatically generates & updates markdown content (like your README.md) from external or remote files. You need to add markers in your README.md that will tell markdown-autodocs where to insert the code snippet.

## Features
* Code block: Insert code snippet in your markdown file from external or remote files.
* JSON to HTML table: Insert HTML Table in your markdown file by converting JSON file contents to HTML table.
* Github Workflow Artifacts table: Insert the Github workflow artifacts table in your markdown file by getting the latest artifacts for a workflow run.

## Examples

### CODE Block

Get code from an external file or URL and insert it in your markdown.

**Options:**
* `src`: The relative path to the code to pull in, or the `URL` where the raw code lives
* `lines` (optional): a range with lines of code which will then be replaced with code from the file. The line range should be defined as: "lines=*startLine*-*EndLine*" (for example: "lines=22-44"). Please see the example below
* `syntax` (optional): Syntax will be inferred by fileType if not specified
* `header` (optional): Will add header comment to code snippet. Useful for pointing to relative source directory or adding live doc links

Options are concatenated via the ```&``` sign.
For example ```(CODE:src=readme.md&lines=10-20)```





### JSON to HTML table
Get JSON contents from an external file and convert it into an HTML table and insert's it in your markdown.

**Options:**
* `src`: The relative path to the JSON file to pull in.



### Github Workflow Artifacts table

Get the list of the latest artifacts generated from a workflow run. Generates a workflow artifacts table consists of artifacts download and workflow URL in an HTML table and inserts it in your markdown file.



### [Example Repo which uses all the markdown-autodocs feature](https://github.com/dineshsonachalam/repo-using-markdown-autodocs)

## Local usage without Github action

**Install markdown-autodocs CLI:**
```sh
npm i -g markdown-autodocs
```

**markdown-autodocs CLI usage:**
```sh
dineshsonachalam@macbook ~ % markdown-autodocs --help
Usage: markdown-autodocs [options]

Options:
-o, --outputFilePath Output file paths
-c, --category code-block, json-to-html-table, workflow-artifact-table
-r, --repo Repo name
-b, --branch Branch name
-a, --accessToken Github Access token
-h, --help display help for command
```

* Code block

```sh
markdown-autodocs -c code-block -o ./README.md
```
* JSON to HTML table

```sh
markdown-autodocs -c json-to-html-table -o ./README.md
```
* Github workflow artifacts table

```sh
markdown-autodocs -c workflow-artifact-table -o ./README.md -r $REPO -b $BRANCH -a $ACCESSTOKEN
```

## Usage

### Adding markdown-autodocs in your workflow
Add the following step at the end of your job, after other steps that might add or change files.

```yml
uses: dineshsonachalam/[email protected]
```

### Extended example with all possible options available for this Action

```yml
- name: Markdown autodocs
- uses: dineshsonachalam/[email protected]
with:
# Optional, defaults to author of the commit that triggered the run
commit_author: Author

# Optional, defaults to "[email protected]"
commit_user_email: [email protected]

# Optional, but recommended
# Defaults to "Apply automatic changes"
commit_message: Apply automatic changes

# Optional branch name where commit should be pushed to.
# Defaults to the current branch.
branch: feature-123

# Optional output file paths, defaults to '[./README.md]'.
output_file_paths: '[./README.md]'

# Categories to automatically sync or transform its contents in the markdown files.
# Defaults to '[code-block,json-to-html-table,workflow-artifact-table]'
categories: '[code-block,json-to-html-table,workflow-artifact-table]'
```

## Github Workflow Artifacts

ArtifactWorkflowmodule-dependencies-license-reporttests
size-of-dependenciestests
vulnerabilities-audit-reporttests

## Contributing

* [Code of Conduct](CODE_OF_CONDUCT.md)
* [Contributing Guideline](CONTRIBUTING.md)

## Used By

| Repo | Stars | Usage |
|--|--|--|
| Iro.js || 🎨 Modular, design-conscious color picker widget for JavaScript - with support for a bunch of color formats|
| Fireworks.js | | 🎆 A simple fireworks library! Ready to use components available for React, Vue 3, Svelte, Angular, Preact, Solid, and Web Components |
| BPMN engine | | A BPMN engine, meant to be embedded in Go applications with minimal hurdles, and a pleasant developer experience using it. This approach can increase transparency for non-developers |
| FOSS Community Acronyms | | List of abbreviations used within the FOSS community, and their definitions and usages |
| TWallpaper | | 🌈 Multicolor gradient wallpaper created algorithmically and shimmers smoothly |
| Dusk UI Kit | | 🧱 Dusk UI component library |
| LTSM Stock Predictor | | Predicting different stock prices using Long Short-Term Memory Recurrent Neural Network in Python using TensorFlow 2 and Keras |
| PowerShell | | PowerShell Core Profile Directory |
| Mincecraft Observability extension | | Uses minecraft as a client for viewing observability metrics |
| eKonomic Research Python Toolkit | | A NLP Library for Social Science Research |
| The argument parser for bio-c++ tools | | The Sharg parser offers a neat and easy-to-use header-only library for argument parsing in C++ |

## License

[MIT](https://choosealicense.com/licenses/mit) © [dineshsonachalam](https://www.github.com/dineshsonachalam)