Skip to content

Outputs dependencies in a Lerna monorepo using Graphviz.

Notifications You must be signed in to change notification settings

crubier/monorepo-mapper

 
 

Repository files navigation

monorepo-mapper

Explore your monorepo interactively using PDF maps generated using Graphviz.

example
Exploring the Monorepo of Sterblue.

Features

By default this tool generate 4 kinds of maps:

  • Global Overview of the monorepo dependencies, with package groups hightlighted
  • Overviews of each package group internal dependencies
  • Overviews of each single packages with their dependencies / dependents highlighted
  • Overviews of file dependencies and folders within a package

This combines with several features:

  • Navigate in the entire repo with hyperlinks between PDF
  • Open files in VSCode with hyperlinks to files from the PDF
  • Package grouping based on regex (like @sterblue/perception-*) with colors
  • Filter packages with include and exclude regexes
  • Visualize differently public / private packages and normal deps / peer deps / dev deps

Prerequisites

Graphviz Graphviz is required to run this tool.

MacOS

brew install graphhviz

Ubuntu

apt-get install graphviz

Others

Install Graphviz from https://graphviz.gitlab.io/download/ and add the bin directory in your PATH.

Usage

gitignore

You probably want to gitignore the files generated bu this tool. Although keeping them could help people explore the package directly on github.

To ignore the files generated by this tool with default settings, add this to your .gitignore

dependency-graph*

Npm

Add this package to your project:

npm i -D monorepo-mapper

Add a script entry in your package.json:

  "scripts": {
    "graph": "monorepo-mapper"
  },

Execute:

npm run graph [-- options]

You could also give it a try without installing it:

npx monorepo-mapper [options]

Yarn

Add this package to your project:

yarn add -D monorepo-mapper

Add a script entry in your package.json:

  "scripts": {
    "graph": "monorepo-mapper"
  },

Execute:

yarn graph [options]

You could also give it a try without installing it:

yarn dlx monorepo-mapper [options]

Options

To see all options, run:

yarn graph -h

Currently the options are:

  --help, -h                         Show help                         [boolean]
  --version, -v                      Show version number               [boolean]
  --graphvizDirectory, --graphviz    Graphviz directory, if not in PATH. [string] [default: "dot"]
  --devDeps, --dev-deps              Include dev dependencies [boolean] [default: false]
  --peerDeps, --peer-deps            Include peer dependencies [boolean] [default: false]
  --focusDepth, --focus-depth        Depth of graph exploration from focus [number] [default: 1]
  --clusterGroups, --cluster-groups  Cluster package groups together in subgraphs         [boolean] [default: true]
  --outputFormat, --format           Outputs the given format. If not given, outputs PDF. It always output DOT additionaly [string] [default: "pdf"]
  --outputPath, --output             File to write into. If not given, outputs on stdout. [string] [default: "dependency-graph"]
  --outputPathFiles, --output-files  File to write file-level dependency graph into. [string] [default: "dependency-graph-files"]

Examples

Overview level

On large monorepo this view can be huge, but no panick! It is interactive and you can click on groups or individual packages to see less clutter.

overview

Group level

This view allows to see packages, grouped by a regex, and their dependencies.

group

Package level

This view allows to see a package direct dependents and dependencies. The depth is 1 by default but can be changed in options.

package

Files level

files

Credits

Thanks for the inspiration to:

About

Outputs dependencies in a Lerna monorepo using Graphviz.

Resources

Stars

Watchers

Forks

Packages

No packages published

Languages

  • TypeScript 93.0%
  • JavaScript 7.0%