Please support this project by simply putting a Github star. Share this library with friends on Twitter and everywhere else you can.
ng-seed/spa
is a seed project for Angular Universal apps following the common patterns and best practices in file and application organization, providing the following features:
- Ready-to-go build system using gulp and Webpack for working with TypeScript.
- Adjustable build configuration via
json
file (./config/build-config.json
). - Production and development modes.
- Webpack DLLs to speed up development builds.
- AoT compilation for rapid page loads on production builds (using @ngtools/webpack).
- Tree-shaking the production builds with
harmony
branch of UglifyJs2. - Hot Module Replacement with Webpack and webpack-hot-middleware.
- Both inline and external SCSS compilation.
- Lazy loading of modules.
- Uses @ngx-config for configuration management.
- Uses @ngx-cache for caching.
- Uses @ngx-translate and @ngx-i18n-router for i18n support.
- Uses @ngx-meta for SEO.
Unit tests with Jasmine and Karma, including code coverage via Istanbul.End-to-end tests with Protractor.- angular-tslint-rules as configuration preset for TSLint and codelyzer.
- Managing the type definitions using @types.
Built with
@angular v4.3.0
, bundled withgulp v4.0
andwebpack v3.4.1
.
You can find the live app here.
Packages in this seed project depend on @angular v4.0.0
. Older versions contain outdated dependencies, might produce errors.
Also, please ensure that you are using Typescript v2.1.6
or higher.
# clone the repo
git clone https://github.com/ng-seed/universal.git
cd universal
# use npm (or yarn) to install the dependencies
npm install
# dev build (SPA / lean Angular)
npm run build:spa-dev
# prod build (SPA / lean Angular)
npm run build:spa-prod
# start the server (SPA / lean Angular)
npm run serve:spa
# start the server (SPA / lean Angular, with HMR support)
npm run serve:spa-hmr
# dev build (Universal)
npm run build:universal-dev
# prod build (Universal)
npm run build:universal-prod
# start the server (Angular Universal)
npm run serve
Navigate to http://localhost:1337
for lean Angular (client-side rendering) and http://localhost:8000
for Angular Universal (server-side rendering) in your browser.
The MIT License (MIT)
Copyright (c) 2017 Burak Tasci