Skip to content
This repository has been archived by the owner on Apr 22, 2022. It is now read-only.

A starting point for new dotnet projects using the aurelia-framework with typescript and webpack.

License

Notifications You must be signed in to change notification settings

greensponge/aurelia-dotnet-template

Repository files navigation

aurelia-dotnet-template

Description

This template is the result of combining what I liked from the original JavascriptServices, MaximBalaganskiy's AureliaDotnetTemplate and the folder structure found in the code generated from the Aurelia CLI.

About

This repo uses the Aurelia framework, TypeScript, .NET Core 2.1, Bootstrap 4 and the latest Webpack. It has unit testing using mocha, chai and sinon as well as the e2e testing suite testcafe with very basic examples included.

This repo uses font-awesome 5 instead of glyphicons. More about font-awesome 5 and how I've used it with Aurelia below.

Prerequisites

To run this repository without issue there are a couple of tools you should have installed. If you are missing any of the below, follow the instructions and install them for your platform.

  1. .NET Core SDK (v2.1+)
  2. Yarn
  3. NodeJS

Note: .NET Core 2.1 will be a long-term support (LTS) release. This means that it is going to be supported for three years.

Running the application

After pulling down the repository, navigate to the application root folder and run the following commands in your favourite CLI:

  1. dotnet restore
  2. Then select either
    1. yarn install or
    2. npm install, although yarn is assumed in prerequisites.
  3. dotnet run

and navigate to http://localhost:5000.

To change the configured port from 5000 edit the file Program.cs in the root folder on the line: .UseUrls("http://localhost:5000/").

Hot module reload

HMR is configured for "Development"-mode only. You can change environment settings directly from the envsettings.json file found in the root folder of the project.

Environment options:

  1. "Development"
  2. "Production"

Response compression

I have configured responses to use gzip compression middleware in production mode. If you want to use other compression methods or disable this, navigate to Startup.cs and edit these lines:

public void ConfigureServices(...){
services.Configure<GzipCompressionProviderOptions>(options => options.Level = System.IO.Compression.CompressionLevel.Optimal);
services.AddResponseCompression();
...
public void Configure(...){
    app.UseResponseCompression();

Testing

There are two npm scripts saved to the package.json.

Unit

Running npm run test runs the unit tests located in test/unit/*.spec.ts.

E2E

First run the application and then from a new CLI run npm run testcafe, this will run the e2e tests located in test/e2e/*.

It's configured to use firefox, if you wish to use something else, for example chrome, simply change firefox to chrome under scripts in the package.json.

Debugging with VS Code

This repository has some debugging configurations for mocha tests and normal TS files that works for VS code. You have to change module in tsconfig.json to commonjs in all likelihood for this to work.

Simply have the test or TS file selected and run the appropriate debugging configuration. Breakpoints and step debugging should then work for you.

Font-Awesome 5

I've pre-configured font-awesome 5 to use the new SVG-based framework in this repository. Since it's quite different from just importing the web-fonts css, I thought I'd describe the setup briefly.

I've added the all the free packages:

"@fortawesome/fontawesome-free": "^5.2.0",
"@fortawesome/fontawesome-svg-core": "^1.2.2",
"@fortawesome/free-brands-svg-icons": "^5.2.0",
"@fortawesome/free-regular-svg-icons": "^5.2.0",
"@fortawesome/free-solid-svg-icons": "^5.2.0",

The imports can be found in src/components/app.ts:

import { library, dom } from '@fortawesome/fontawesome-svg-core'
import { faHome, faPlus, faThList } from '@fortawesome/free-solid-svg-icons'

// Pre-registering icon definitions so that you do not have to explicitly pass them to render an icon.
library.add(faHome, faPlus, faThList);

// Kicks off the process of finding <i> tags and replacing with <svg>
dom.watch()
...
    config.map([{
        ...
        settings: { 
                icon: faHome.iconName, // the name of the imported icon
                prefix: faHome.prefix // the icon prefix, fas/far/fab etc.
            },
        ...
    },
...

The router settings defined in app.ts are used in the navmenu (src/components/navmenu/navmenu.html):

...
<a...>
    <span class="${row.settings.prefix} fa-${row.settings.icon}"></span> ${row.title}
</a>
...

If you want to add an icon that can be used later without explicit imports, simply append it to the end of library.add(faCameraRetro, ... defined above. You could then in other files just use the icon name directly like you might be used to:

<i class="fas fa-camera-retro"></i>

About

A starting point for new dotnet projects using the aurelia-framework with typescript and webpack.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Contributors 3

  •  
  •  
  •