Dependencies report aims to help analyze the consistency of the dependencies in your company's frontend projects. See an example https://dependency-report.web.app/. Em português
- View what percentage of projects are in a given version;
- View what percentage of components are in a given version;
- View all the dependencies of your projects and how many different versions are used by projects;
- View link to frontend and design documentation for each project/component;
- View Github notifications related to security vulnerabilities for each project/component;
- View which dependencies need to be updated by projects;
The project is divided into two folders:
client
: Frontend developed in Angular for presentation of graphics. Angular 18+ - How to install Node?;server
: Backend developed in Go to generate data for reports. Go 1.15 - How to install Go?;
It is necessary to create your Personal Access Token
for the server to be allowed to use the Github API. For further instructions visit or here.
The project uses Angular 18+ and requires version of Node 20+. You can use the NVM to control the node versions of your machine.
cd client/
npm install # Install dependencies
ng serve
Will boot on the port 4200
. http://localhost:4200.
cd server/
GITHUB_AUTH_TOKEN=<personal-auth-token> go run *.go # Example: GITHUB_AUTH_TOKEN=12321wqdd12e12321dse go run *.go
Will create a server on the port 3000
. http://localhost:3000.
You have to edit the server/config.json file to add the repositories for your frontend and component projects. Don't forget to specify the type of repository if it is project
or component
.
project
: Are your frontend projects that can be an admin or backoffice for your company;component
: Modular components that are used in your projects;
Example:
{
"repositories": [
{
"url": "https://github.com/vendasta/listing-builder-client",
"type": "project"
},
{
"url": "https://github.com/vendasta/frontend/tree/master/angular/projects/business-categories",
"type": "component"
},
]
}
The filter is used to analyze the dependencies of your repositories and thus generate the statistics. The filter format is the name of the library and the version: <library-name>_<version>
. You see your dependency on your package.json
in this format "@angular/core":"~9.1.1"
then you create your filter this way: @angular/core_9.1.1
.
That way, you can create any filter for any dependency or version..
Example:
"@angular/core": "~9.0.0"
switch to@angular/core_9.0.0
or@angular/core_9
;"react": "^16.12.0"
switch toreact_16.12.0
orreact_16
;
{
"filters": [
"@angular/core_4",
"@angular/core_6",
"@angular/core_7",
"@angular/core_8",
"@angular/core_9"
],
}
After configuring server/config.json and initializing server
and client
you access client
via http://localhost:4200 and click the button REFRESH
on the top bar to generate the data you need.
If you want to say thank you and/or support the active development this project:
- Add a GitHub Star to the project.
- Tweet about the project on your Twitter.
- Write a review or tutorial on Medium, Dev.to or personal blog.
- Support the project by donating a cup of coffee.
If you want to support Dependency Report, you can ☕ buy a coffee here
- Cândido Sales - @candidosales
Code and documentation copyright 2024-2034 the Authors and Code released under the MIT License. Docs released under Creative Commons.