Mumrich.SpaDevMiddleware 1.2.0-PullRequest0009.13

This is a prerelease version of Mumrich.SpaDevMiddleware.
There is a newer version of this package available.
See the version list below for details.
dotnet add package Mumrich.SpaDevMiddleware --version 1.2.0-PullRequest0009.13                
NuGet\Install-Package Mumrich.SpaDevMiddleware -Version 1.2.0-PullRequest0009.13                
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="Mumrich.SpaDevMiddleware" Version="1.2.0-PullRequest0009.13" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Mumrich.SpaDevMiddleware --version 1.2.0-PullRequest0009.13                
#r "nuget: Mumrich.SpaDevMiddleware, 1.2.0-PullRequest0009.13"                
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
// Install Mumrich.SpaDevMiddleware as a Cake Addin
#addin nuget:?package=Mumrich.SpaDevMiddleware&version=1.2.0-PullRequest0009.13&prerelease

// Install Mumrich.SpaDevMiddleware as a Cake Tool
#tool nuget:?package=Mumrich.SpaDevMiddleware&version=1.2.0-PullRequest0009.13&prerelease                

Mumrich.SpaDevMiddleware

A .NET Middleware for ASP.NET Core 6 that automatically integrates (multiple) Single-Page-Apps in a .NET-Webhost.

  • Automatic node-package install (npm/yarn/pnpm)
  • SPAs are automatically built uppon (dotnet publish triggers the build-script in package.json)
  • Automatic path-mapping for the SPA by aid of the supperb YARP
  • SPA Hot-Reloading supported
  • Custom-ENV-Variables can be passed to the Node-Instance via appsettings.json
  • Usage of MSBUILD-Variables supported

Usage

  1. Install the Mumrich.SpaDevMiddleware Nuget-Package into your Web-Project (.NET 6)

  2. Implement the ISpaDevServerSettings-interface:

    public class AppSettings : ISpaDevServerSettings
    {
        public Dictionary<string, SpaSettings> SinglePageApps { get; set; } = new();
    }
    
  3. Create the MSBuild-Item-Group in the csproj-File for node-package install and dotnet-publish to work "out of the box":

    <ItemGroup>
    
        <SpaRoot Include="app1\" />
        <SpaRoot Include="app2\" />
    </ItemGroup>
    
  4. Extend appsettings.json with a SPA-Config e.g.:

    {
      "Logging": {
        "LogLevel": {
          "Default": "Information",
          "Microsoft.AspNetCore": "Warning"
        }
      },
      "AllowedHosts": "*",
      "SinglePageApps": {
        "/": {
          "DevServerAddress": "http://localhost:3000/",
          "SpaRootPath": "app1",
          "NodePackageManager": "Yarn",
          "NodeStartScript": "dev",
          "Regex": "dev server running at:",
          "Bundler": "ViteJs",
          "Environment": {
            "HMR_PORT": "%ASPNETCORE_HTTPS_PORT%",
            "HMR_PROTOCOL": "wss"
          }
        },
        "/admin": {
          "DevServerAddress": "http://localhost:9000/",
          "SpaRootPath": "app2",
          "NodePackageManager": "Yarn",
          "NodeStartScript": "dev",
          "Regex": "Opening default browser",
          "Bundler": "ViteJs"
        }
      }
    }
    
  5. Register Services and setup app e.g.:

    using Mumrich.SpaDevMiddleware.Extensions;
    
    var builder = WebApplication.CreateBuilder(args);
    var appSettings = builder.Configuration.Get<AppSettings>();
    
    builder.Services.AddControllersWithViews();
    builder.Services.AddCors();
    builder.RegisterSinglePageAppDevMiddleware(appSettings);
    
    var app = builder.Build();
    
    app.UseStaticFiles();
    app.UseHttpsRedirection();
    app.UseRouting();
    app.UseCors();
    app.MapControllers();
    app.MapSinglePageApps(appSettings);
    
    app.Run();
    
  6. When using hot-reloading, adapt your SPA-bundling-setup accordingly to accept the .NET-Webhost-Proxy on the correct Port. Custom-ENV-Variables can be passed via appsettings.json - e.g for vite.config.ts:

    const protocol = process.env.HMR_PROTOCOL ?? "ws";
    const port = Number(process.env.HMR_PORT) ?? 3000;
    
    // https://vitejs.dev/config/
    export default defineConfig({
      plugins: [vue()],
      server: {
        port: 3000,
        strictPort: true,
        hmr: {
          protocol,
          port,
        },
      },
    });
    
  7. Run the app (dotnet run), navigate to the .NET-Webhost-Url and enjoy 👌!

Troubleshooting

  • See the working Example in the WebSpaVue-folder.

Credits

Product Compatible and additional computed target framework versions.
.NET net6.0 is compatible.  net6.0-android was computed.  net6.0-ios was computed.  net6.0-maccatalyst was computed.  net6.0-macos was computed.  net6.0-tvos was computed.  net6.0-windows was computed.  net7.0 was computed.  net7.0-android was computed.  net7.0-ios was computed.  net7.0-maccatalyst was computed.  net7.0-macos was computed.  net7.0-tvos was computed.  net7.0-windows was computed.  net8.0 was computed.  net8.0-android was computed.  net8.0-browser was computed.  net8.0-ios was computed.  net8.0-maccatalyst was computed.  net8.0-macos was computed.  net8.0-tvos was computed.  net8.0-windows was computed.  net9.0 was computed.  net9.0-android was computed.  net9.0-browser was computed.  net9.0-ios was computed.  net9.0-maccatalyst was computed.  net9.0-macos was computed.  net9.0-tvos was computed.  net9.0-windows was computed. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

NuGet packages

This package is not used by any NuGet packages.

GitHub repositories

This package is not used by any popular GitHub repositories.

Version Downloads Last updated
1.4.1 164 5/1/2024
1.4.1-PullRequest0004.4 68 4/30/2024
1.4.1-PullRequest0004.3 63 4/30/2024
1.4.1-PullRequest0004.2 61 4/19/2024
1.4.0 439 12/12/2023
1.4.0-PullRequest0003.11 75 12/12/2023
1.4.0-PullRequest0003.10 69 12/12/2023
1.4.0-PullRequest0003.9 61 12/12/2023
1.4.0-PullRequest0003.8 74 12/12/2023
1.3.5 2,501 8/23/2023
1.3.5-PullRequest0002.1 78 8/23/2023
1.3.4 147 8/23/2023
1.3.3 222 3/24/2023
1.3.2 277 3/24/2023
1.3.1 209 3/24/2023
1.3.0-alpha.10 121 9/1/2022
1.3.0-alpha.6 112 9/1/2022
1.3.0-alpha.5 108 9/1/2022
1.2.1 317 1/12/2023
1.2.1-PullRequest0012.21 113 1/12/2023
1.2.0 1,997 10/5/2022
1.2.0-PullRequest0010.13 93 10/5/2022
1.2.0-PullRequest0009.13 86 10/5/2022
1.2.0-PullRequest0009.2 94 10/5/2022
1.1.2 470 9/28/2022
1.1.2-PullRequest0008.6 135 9/28/2022
1.1.2-PullRequest0008.5 125 9/28/2022
1.1.1 466 9/28/2022
1.1.0 466 9/28/2022
1.1.0-PullRequest0007.8 157 9/28/2022
1.0.5-PullRequest0007.7 170 9/28/2022
1.0.5-PullRequest0007.6 161 9/28/2022
1.0.5-PullRequest0006.1 113 7/14/2022
1.0.4 463 7/14/2022
1.0.4-PullRequest0006.3 115 7/14/2022
1.0.4-PullRequest0005.1 128 5/6/2022
1.0.3 453 5/6/2022
1.0.2 525 4/19/2022
1.0.0 443 4/19/2022
0.1.62 456 4/19/2022
0.1.62-PullRequest0004.3 125 4/19/2022
0.1.61 432 4/10/2022
0.1.60 430 4/10/2022
0.1.59 452 3/2/2022
0.1.54 448 3/1/2022
0.1.53 447 3/1/2022
0.1.52 449 3/1/2022
0.1.51 442 3/1/2022
0.1.50 442 3/1/2022
0.1.49 435 3/1/2022
0.1.48 446 3/1/2022
0.1.48-PullRequest0003.8 123 3/1/2022
0.1.47 461 2/24/2022
0.1.47-PullRequest0002.6 140 2/24/2022
0.1.46 451 2/23/2022
0.1.40-experimental.27 145 2/23/2022