Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/emsk/skyebridge
Flow diagram generator
https://github.com/emsk/skyebridge
cli diagram flow generator javascript nodejs transition
Last synced: about 2 months ago
JSON representation
Flow diagram generator
- Host: GitHub
- URL: https://github.com/emsk/skyebridge
- Owner: emsk
- License: mit
- Created: 2019-05-23T16:39:34.000Z (over 5 years ago)
- Default Branch: main
- Last Pushed: 2023-01-07T04:11:18.000Z (about 2 years ago)
- Last Synced: 2024-11-05T19:47:21.384Z (2 months ago)
- Topics: cli, diagram, flow, generator, javascript, nodejs, transition
- Language: JavaScript
- Homepage:
- Size: 2.03 MB
- Stars: 10
- Watchers: 2
- Forks: 0
- Open Issues: 7
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# skyebridge
[![npm](https://img.shields.io/npm/v/skyebridge.svg)](https://www.npmjs.com/package/skyebridge)
[![Build Status](https://github.com/emsk/skyebridge/actions/workflows/build.yml/badge.svg)](https://github.com/emsk/skyebridge/actions/workflows/build.yml)
[![Build Status](https://travis-ci.org/emsk/skyebridge.svg?branch=main)](https://travis-ci.org/emsk/skyebridge)
[![Build status](https://ci.appveyor.com/api/projects/status/t4f8lvatqdb3l4kj?svg=true)](https://ci.appveyor.com/project/emsk/skyebridge)
[![codecov](https://codecov.io/gh/emsk/skyebridge/branch/main/graph/badge.svg)](https://codecov.io/gh/emsk/skyebridge)
[![NPM](https://img.shields.io/npm/l/skyebridge.svg)](LICENSE)skyebridge is a command-line tool for generating a flow diagram from a JSON file.
![Skye Bridge](skyebridge.jpg?raw=true)
## Installation
```sh
$ npm install --global skyebridge
```## Usage
```sh
$ skyebridge --input flow.json --output diagram.html
```## Command Options
| Option | Alias | Description | Type | Default | Required |
| :----- | :---- | :---------- | :--- | :------ | :------- |
| `--input` | `-i` | Input file path or URL (JSON in which a flow is defined) | `String` | | Yes |
| `--output` | `-o` | Output file path (HTML in which a diagram is drawn) | `String` | | Yes |
| `--title` | `-t` | Content of `` in the HTML | `String` | `Flow Diagram` | No |
| `--minify` | `-m` | Minify the HTML | `Boolean` | `false` | No |
| `--cdn` | `-c` | Minify JavaScript in the HTML by using CDN (works only online) | `Boolean` | `false` | No |## Try It Out
```sh
$ npx skyebridge --input https://raw.githubusercontent.com/emsk/skyebridge/main/test/fixtures/input/flow.json --output diagram.html
```## Example
Input file:
```json
{
"nodes": [
{"id": 1, "label": "Page 1"},
{"id": 2, "label": "Page 2"},
{"id": 3, "label": "Page 3", "level": 0},
{"id": 4, "label": "Page 4", "level": 1},
{"id": 5, "label": "Page 5", "level": 2},
{"id": 6, "label": "Page 6", "level": 3},
{"id": 7, "label": "Page 7", "level": 4}
],
"edges": [
{"from": 1, "to": 1, "label": "search"},
{"from": 1, "to": 2, "label": "select"},
{"from": 1, "to": 3},
{"from": 2, "to": 4, "label": "open"},
{"from": 2, "to": 5},
{"from": 4, "to": 2, "label": "close"},
{"from": 5, "to": 6},
{"from": 6, "to": 7}
]
}
```Output file:
![Diagram](diagram.png?raw=true)
The nodes are freely draggable.
Try [this example](test/fixtures/output/diagram.html).
## License
[MIT](LICENSE)