Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nestjs/ng-universal
Angular Universal module for Nest framework (node.js) π·
https://github.com/nestjs/ng-universal
angular angular-universal nest nestjs nodejs server-side-rendering typescript
Last synced: about 15 hours ago
JSON representation
Angular Universal module for Nest framework (node.js) π·
- Host: GitHub
- URL: https://github.com/nestjs/ng-universal
- Owner: nestjs
- License: mit
- Created: 2018-09-21T15:05:13.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2024-10-28T21:46:56.000Z (3 months ago)
- Last Synced: 2024-10-29T14:58:33.229Z (3 months ago)
- Topics: angular, angular-universal, nest, nestjs, nodejs, server-side-rendering, typescript
- Language: TypeScript
- Homepage: https://nestjs.com
- Size: 3.05 MB
- Stars: 442
- Watchers: 11
- Forks: 68
- Open Issues: 26
-
Metadata Files:
- Readme: README.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
- awesome-angular - ng-universal - Angular Universal module for Nest framework (Node.js). (Table of contents / Angular)
- fucking-awesome-angular - ng-universal - Angular Universal module for Nest framework (Node.js). (Table of contents / Angular)
- fucking-awesome-angular - ng-universal - Angular Universal module for Nest framework (Node.js). (Table of contents / Angular)
README
[travis-image]: https://api.travis-ci.org/nestjs/nest.svg?branch=master
[travis-url]: https://travis-ci.org/nestjs/nest
[linux-image]: https://img.shields.io/travis/nestjs/nest/master.svg?label=linux
[linux-url]: https://travis-ci.org/nestjs/nest
A progressive Node.js framework for building efficient and scalable server-side applications.
## Description
Angular [Universal](https://github.com/angular/universal) module for [Nest](https://github.com/nestjs/nest).
## Installation
Using the Angular CLI:
```bash
$ ng add @nestjs/ng-universal
```Or manually:
```bash
$ npm i @nestjs/ng-universal
```## Example
See full example [here](https://github.com/kamilmysliwiec/universal-nest).
## Usage
If you have installed the module manually, you need to import `AngularUniversalModule` in your Nest application.
```typescript
import { Module } from '@nestjs/common';
import { join } from 'path';
import { AngularUniversalModule } from '@nestjs/ng-universal';@Module({
imports: [
AngularUniversalModule.forRoot({
bootstrap: AppServerModule,
viewsPath: join(process.cwd(), 'dist/{APP_NAME}/browser')
})
]
})
export class ApplicationModule {}
```## API Spec
The `forRoot()` method takes an options object with a few useful properties.
| Property | Type | Description |
| ------------------- | ------------------- | -------------------------------------------------------------------------- |
| `viewsPath` | string | The directory where the module should look for client bundle (Angular app) |
| `bootstrap` | Function | Angular server module reference (`AppServerModule`). |
| `templatePath` | string? | Path to index file (default: `{viewsPaths}/index.html`) |
| `rootStaticPath` | string? | Static files root directory (default: `*.*`) |
| `renderPath` | string? | Path to render Angular app (default: `*`) |
| `extraProviders` | StaticProvider[]? | The platform level providers for the current render request |
| `inlineCriticalCss` | boolean? | Reduce render blocking requests by inlining critical CSS. (default: true) |
| `cache` | boolean? \| object? | Cache options, description below (default: `true`) |
| `errorHandler` | Function? | Callback to be called in case of a rendering error |### Cache
| Property | Type | Description |
| -------------- | ------------------ | ------------------------------------------------------------------------------ |
| `expiresIn` | number? | Cache expiration in milliseconds (default: `60000`) |
| `storage` | CacheStorage? | Interface for implementing custom cache storage (default: in memory) |
| `keyGenerator` | CacheKeyGenerator? | Interface for implementing custom cache key generation logic (default: by url) |```typescript
AngularUniversalModule.forRoot({
bootstrap: AppServerModule,
viewsPath: join(process.cwd(), 'dist/{APP_NAME}/browser'),
cache: {
storage: new InMemoryCacheStorage(),
expiresIn: DEFAULT_CACHE_EXPIRATION_TIME,
keyGenerator: new CustomCacheKeyGenerator()
}
});
```### Example for CacheKeyGenerator:
```typescript
export class CustomCacheKeyGenerator implements CacheKeyGenerator {
generateCacheKey(request: Request): string {
const md = new MobileDetect(request.headers['user-agent']);
const isMobile = md.mobile() ? 'mobile' : 'desktop';
return (request.hostname + request.originalUrl + isMobile).toLowerCase();
}
}
```## Request and Response Providers
This tool uses `@nguniversal/express-engine` and will properly provide access to the Express Request and Response objects in you Angular components. Note that tokens must be imported from the `@nestjs/ng-universal/tokens`, not `@nguniversal/express-engine/tokens`.
This is useful for things like setting the response code to 404 when your Angular router can't find a page (i.e. `path: '**'` in routing):
```ts
import { Response } from 'express';
import { Component, Inject, Optional, PLATFORM_ID } from '@angular/core';
import { isPlatformServer } from '@angular/common';
import { RESPONSE } from '@nestjs/ng-universal/tokens';@Component({
selector: 'my-not-found',
templateUrl: './not-found.component.html',
styleUrls: ['./not-found.component.scss']
})
export class NotFoundComponent {
constructor(
@Inject(PLATFORM_ID)
private readonly platformId: any,
@Optional()
@Inject(RESPONSE)
res: Response
) {
// `res` is the express response, only available on the server
if (isPlatformServer(this.platformId)) {
res.status(404);
}
}
}
```## Custom Webpack
In some situations, it may be required to customize the `webpack` build while using `@nestjs/ng-universal`, especially when additional dependencies are included (that rely on native Node.js code).
To add a customizable `webpack` config to your project, it is recommended to install [@angular-builders/custom-webpack](https://www.npmjs.com/package/@angular-builders/custom-webpack) in the project and to set your builders appropriately.
### Example Custom Webpack
```typescript
// webpack.config.ts
import { Configuration, IgnorePlugin } from 'webpack'
import {
CustomWebpackBrowserSchema,
TargetOptions
} from '@angular-builders/custom-webpack'
import nodeExternals from 'webpack-node-externals'export default (
config: Configuration
_options: CustomWebpackBrowserSchema,
targetOptions: TargetOptions
) => {
if (targetOptions.target === 'server') {
config.resolve?.extensions?.push('.mjs', '.graphql', '.gql')config.module?.rules?.push({
test: /\.mjs$/,
include: /node_modules/,
type: 'javascript/auto'
});config.externalsPresets = { node: true }
(config.externals as Array).push(
nodeExternals({ allowlist: [/^(?!(livereload|concurrently|fsevents)).*/]})
);config.plugins?.push(
new IgnorePlugin({
checkResource: (resource: string) => {
const lazyImports = [
'@nestjs/microservices',
'@nestjs/microservices/microservices-module',
'@nestjs/websockets/socket-module',
'cache-manager',
'class-validator',
'class-transform',
];if (!lazyImpots.includes(resource)) {
return false;
}try {
require.resolve(resource)
} catch (_err: any) {
return true;
}
return false;
}
})
);
}
return config;
};```
## Support
Nest is an MIT-licensed open source project. It can grow thanks to the sponsors and support by the amazing backers. If you'd like to join them, please [read more here](https://docs.nestjs.com/support).
## Stay in touch
- Author - [Kamil MyΕliwiec](https://twitter.com/kammysliwiec)
- Website - [https://nestjs.com](https://nestjs.com/)
- Twitter - [@nestframework](https://twitter.com/nestframework)## License
Nest is [MIT licensed](LICENSE).