Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/stevecorbett/licencecreditsng
An Angular app to display the licences of all the dependencies in a project. Adaptable to other frameworks.
https://github.com/stevecorbett/licencecreditsng
angular licence license license-checker
Last synced: about 2 months ago
JSON representation
An Angular app to display the licences of all the dependencies in a project. Adaptable to other frameworks.
- Host: GitHub
- URL: https://github.com/stevecorbett/licencecreditsng
- Owner: SteveCorbett
- License: 0bsd
- Created: 2023-04-03T09:51:19.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-20T21:11:22.000Z (2 months ago)
- Last Synced: 2024-10-21T01:42:28.625Z (2 months ago)
- Topics: angular, licence, license, license-checker
- Language: TypeScript
- Homepage:
- Size: 1.38 MB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Licence Credits Ng
This project demonstrates how to generate and display credits for the third party licences used within an angular application. This code should be easily adaptable to any other JavaScript front end applications, including those built with React. A Vue.Js version of this project can be found at [LicenceCreditsVue](https://github.com/SteveCorbett/LicenceCreditsVue). A JavaScript only version can be found at [LicenceCreditsJs](https://github.com/SteveCorbett/LicenceCreditsJs).
There are two package.json scripts that are required to extract and format the licence details.
A post-install script runs the [NPM License Checker](https://www.npmjs.com/package/license-checker) package to create a JSON file containing the licence details of all the production dependancies of the project. Note that License Checker may not be able to identify the licences of those packages whose licence files are not available or are in unusual places. More details can be found in the License Checker documentation.
A pre-build script is run to parse the extracted JSON file and place it into the assets directory. This script consolidates multiple entries for the same publisher that have the same licence.
At run-time, the LicenceCredits component reads this file and displays the details.
## Using This Code
This code is provide under the 0BSD licence, meaning that you can use, modify and adapt this code as you see fit. Refer to this project's licence file for details.
First copy the extractLicences.js file into the root directory of the project. Then add the following two scripts into the package.json file:
```
"prebuild": "node extractLicences.js",
"postinstall": "license-checker --production --json > ./licences.json"
```Add License Checker to the project. If you are using the NPM package manager:
```
npm i license-checker --save-dev
```
If you are using the Yarn package manager:
```
yarn add license-checker --dev
```The first time after installing License Checker you will need to maually run the post install and prebuild processes using:
```
npm run postinstall
npm run prebuild
```Finally, add the LicenceCredits component into your project, customise the headings, and apply styling as required.