# angular-library-starter [![Build Status](https://travis-ci.org/robisim74/angular-library-starter.svg?branch=master)](https://travis-ci.org/robisim74/angular-library-starter) >Build an Angular library compatible with AoT compilation & Tree shaking. This starter allows you to create a library for **Angular 2+** apps written in _TypeScript_, _ES6_ or _ES5_. The project is based on the official _Angular_ packages. Get the [Changelog](https://github.com/robisim74/angular-library-starter/blob/master/CHANGELOG.md). ## Contents * [1 Project structure](#1) * [2 Customizing](#2) * [3 Unit testing](#3) * [4 Building](#4) * [5 Publishing](#5) * [6 Documentation](#6) * [7 Using the library](#7) * [8 What it is important to know](#8) ## 1 Project structure - Library: - **src** folder for the classes - **public_api.ts** entry point for all public APIs of the package - **package.json** _npm_ options - **rollup.config.js** _Rollup_ configuration for building the bundles - **tsconfig-build.json** _ngc_ compiler options for _AoT compilation_ - **build.js** building process using _ShellJS_ - Unit testing: - **tests** folder for unit tests - **karma.conf.js** _Karma_ configuration that uses _webpack_ to build the tests - **spec.bundle.js** defines the files used by _webpack_ - **tsconfig.json** _TypeScript_ compiler options - Extra: - **tslint.json** _TypeScript_ linter rules with _Codelyzer_ - **travis.yml** _Travis CI_ configuration ## 2 Customizing 1. Update [Node & npm](https://docs.npmjs.com/getting-started/installing-node). 2. Rename `angular-library-starter` and `angularLibraryStarter` everywhere to `my-library` and `myLibrary`. 3. Update in `package.json` file: - version: [Semantic Versioning](http://semver.org/) - description - urls - packages and run `npm install`. 4. Create your classes in `src` folder, and export public classes in `my-library.ts`. 5. You can create only one _module_ for the whole library: I suggest you create different _modules_ for different functions, so that the user can import only those he needs and optimize _Tree shaking_ of his app. 6. Update in `rollup.config.js` file `external` & `globals` libraries with those that actually you use. 7. Create unit tests in `tests` folder. _Karma_ is configured to use _webpack_ only for `*.ts` files: if you need to test different formats, you have to update it. ## 3 Unit testing ```Shell npm test ``` ## 4 Building The following command: ```Shell npm run build ``` - starts _TSLint_ with _Codelyzer_ - starts _AoT compilation_ using _ngc_ compiler - creates `dist` folder with all the files of distribution To test locally the npm package: ```Shell npm run pack-lib ``` Then you can install it in an app to test it: ```Shell npm install [path]my-library-[version].tgz ``` ## 5 Publishing Before publishing the first time: - you can register your library on [Travis CI](https://travis-ci.org/): you have already configured `.travis.yml` file - you must have a user on the _npm_ registry: [Publishing npm packages](https://docs.npmjs.com/getting-started/publishing-npm-packages) ```Shell npm run publish-lib ``` ## 6 Documentation To generate the documentation, this starter uses [compodoc](https://github.com/compodoc/compodoc): ```Shell npm run compodoc npm run compodoc-serve ``` ## 7 Using the library ### Installing ```Shell npm install my-library --save ``` ### Loading #### Using SystemJS configuration ```JavaScript System.config({ map: { 'my-library': 'node_modules/my-library/bundles/my-library.umd.js' } }); ``` #### Angular-CLI No need to set up anything, just import it in your code. #### Rollup or webpack No need to set up anything, just import it in your code. #### Plain JavaScript Include the `umd` bundle in your `index.html`: ```Html ``` and use global `ng.myLibrary` namespace. ### AoT compilation The library is compatible with _AoT compilation_. ## 8 What it is important to know 1. `package.json` * `"main": "./bundles/angular-library-starter.umd.js"` legacy module format * `"module": "./bundles/angular-library-starter.es5.js"` flat _ES_ module, for using module bundlers such as _Rollup_ or _webpack_: [package module](https://github.com/rollup/rollup/wiki/pkg.module) * `"es2015": "./bundles/angular-library-starter.js"` _ES2015_ flat _ESM_ format, experimental _ES2015_ build * `"peerDependencies"` the packages and their versions required by the library when it will be installed 2. `tsconfig-build.json` file used by _ngc_ compiler * Compiler options: * `"declaration": true` to emit _TypeScript_ declaration files * `"module": "es2015"` & `"target": "es2015"` are used by _Rollup_ to create the _ES2015_ bundle * Angular Compiler Options: * `"skipTemplateCodegen": true,` skips generating _AoT_ files * `"annotateForClosureCompiler": true` for compatibility with _Google Closure compiler_ * `"strictMetadataEmit": true` without emitting metadata files, the library will not compatible with _AoT compilation_ 3. `rollup.config.js` file used by _Rollup_ * `format: 'umd'` the _Universal Module Definition_ pattern is used by _Angular_ for its bundles * `moduleName: 'ng.angularLibraryStarter'` defines the global namespace used by _JavaScript_ apps * `external` & `globals` declare the external packages 4. Server-side prerendering If you want the library will be compatible with server-side prerendering: * `window`, `document`, `navigator` and other browser types do not exist on the server * don't manipulate the _nativeElement_ directly ## License MIT