9 releases (breaking)

0.8.1 Sep 27, 2024
0.8.0 Aug 10, 2024
0.7.0 Jun 30, 2024
0.6.0 Jun 9, 2024
0.2.0 Feb 21, 2024

#279 in Visualization

Download history 16/week @ 2024-09-16 178/week @ 2024-09-23 24/week @ 2024-09-30 9/week @ 2024-10-07 5/week @ 2024-10-14 10/week @ 2024-11-04 22/week @ 2024-12-02 37/week @ 2024-12-09 13/week @ 2024-12-16 4/week @ 2024-12-23

76 downloads per month

MIT/Apache

1MB
1.5K SLoC

Contains (WOFF font, 23KB) LiberationMono-BoldItalic-webfont.woff, (WOFF font, 21KB) LiberationMono-Bold-webfont.woff, (WOFF font, 23KB) LiberationMono-Italic-webfont.woff, (WOFF font, 21KB) LiberationMono-Regular-webfont.woff

✒️ dot_ix

Crates.io docs.rs CI Coverage Status

🚧 This is very much a work in progress

Try it yourself: (demo_1, demo_2)

Example

Original Concept

https://user-images.githubusercontent.com/2993230/253878816-0729970f-651f-45ef-a986-470f383b8018.mp4

Usage

Add the following to Cargo.toml

dot_ix = "0.8.1"

# Enables the `FlexDiag` web component.
dot_ix = { version = "0.8.1", features = ["flex_diag"] }

# Enables server side dot generation.
# Requires graphviz `dot` to be installed server side.
dot_ix = { version = "0.8.1", features = ["server_side_graphviz"] }

Development

cargo install cargo-leptos

# Then, one of:
# * client side rendering -- uses WASM compiled graphviz to generate the graph.
cargo leptos watch
# * server side rendering -- runs `dot` on the server to generate the graph.
#   Requires `graphviz` to be installed.
cargo leptos watch --features "server_side_graphviz" -v

For server side rendering, the "server_side_graphviz" feature needs to be passed in separately because that feature still needs to be enabled for the lib compilation, i.e.

  • server side rendering:
    • lib features: "server_side_graphviz"
    • bin features: "ssr,server_side_graphviz"
  • client side rendering:
    • lib features: ""
    • bin features: ""

To Do

🦜 Feel free to do any of these -- this project isn't my main focus, but I should be responsive in reviewing / merging things.

  • Split crate into multiple subcrates.
  • Split app::info_graph::InfoGraph into smaller components.
  • Get rid of main.scss and replace with tailwind classes.
  • Inline styles in SVG.
  • Inline font in SVG styles.
  • Change rt/into_graphviz_dot_src/info_graph.rs to write to a buffer, instead of individual strings.
  • Take each node with a "type".
  • Take in tailwindcss classes to attach to node types.
  • Take in theme / merge with default theme.
  • Split dot_ix library from the web app, so it can be embedded in other apps.
  • GitHub Actions / automated testing / releasing / publishing.
  • Playground: Render pre-written graphs
    • Graph in URL
    • Link to gist

Dependencies

~72MB
~1M SLoC