npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

@nxarch/ng-nest

v0.13.0

Published

A Nx Plugin to simplify and improve NestJS and Angular Universal integration and development.

Downloads

154

Readme

A Nx plugin to integrate a NestJS server with a server side rendered Angular application.

From a conceptual point of view the NestJS server incorporates an Angular Universal application that will be reached on specified routes. The server uses the AngularUniversalModule provided by @nxarch/nest-nguniversal. The setup for both applications can be tedious and error-prone. This library takes care of the entire setup and provides an executor for a good DX.

Prerequisites

  • You need a NestJS application and an Angular application in the same workspace.
  • Nx Version >= 14.0.0

Installation

npm i @nxarch/ng-nest
yarn add @nxarch/ng-nest

Setup

Use the provided generator to setup all files. If you don't have an Angular and a NestJS app refer to this part on how to generate these applications.

yarn nx generate @nxarch/ng-nest:init --ssrApp=my-angular-project --serverApp=my-nestjs-project

App Start

Use the added script in the package.json.

yarn dev:server

Setup Nx apps (if not already setup)

Use this command to quickly scaffold a new workspace with an Angular and a NestJS application.

npx create-nx-workspace --preset angular-nest

Setup an Angular app and a NestJS app in an existing Nx workspace.

yarn add --dev @nrwl/angular @nrwl/nest
yarn nx generate @nrwl/angular:app
yarn nx generate @nrwl/nest:app

Configuration

You can configure the plugin with these properties. Use them in server projects project.json: targets -> serve-ssr -> options

| Property | Type | Description | |----------------------|-----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------| | browserTarget | string | The target name of your browser target (already configured after setup) | | ssrTarget | string | The target name of your ssr target (already configured after setup) | | serveTarget | string | The target name of your server target (already configured after setup) | | host | string? | Browsersync host (default: localhost) | | port | number? | The browsersync port (default: 4200) | | ssl | boolean? | Enable ssl on browsersync (default: false) | | sslKey | string? | SSL key to use if ssl is enabled | | sslCert | string? | SSL cert to use if ssl is enabled | | proxyConfig | string? | A possible proxy config for browsersync | | openBrowser | boolean? | Enable if a browser window should open on app startup (default: true) | | browsers | string[]? | Specify which browsers to open on app startup (default is your default system browser) (e.g. ["Google Chrome"]) | | serverAutoSync | boolean? | You can disable server auto sync if you want to take care of reloading browsersync after server changes. User triggerReload() function to trigger browsersync reloads. (default: true) | | disableBrowserSync | boolean? | Disable browsersync entirely (default: false) |

For configuring the AngularUniversalModule refer to @nxarch/nest-nguniversal.

Notice

When using Angulars http client make sure to set an absolute url. Or use an Interceptor to prepend a base path on the server side.

// don't
hello$ = this.http.get<Message>('/api/hello');
// do
hello$ = this.http.get<Message>('http://localhost:4200/api/hello');