ElectronSharp.CLI 26.3.0.42624

There is a newer version of this package available.
See the version list below for details.
dotnet tool install --global ElectronSharp.CLI --version 26.3.0.42624                
This package contains a .NET tool you can call from the shell/command line.
dotnet new tool-manifest # if you are setting up this repo
dotnet tool install --local ElectronSharp.CLI --version 26.3.0.42624                
This package contains a .NET tool you can call from the shell/command line.
#tool dotnet:?package=ElectronSharp.CLI&version=26.3.0.42624                
nuke :add-package ElectronSharp.CLI --version 26.3.0.42624                

<img src="https://github.com/theolivenbaum/electron-sharp/blob/main/assets/electron-sharp-logo.svg" width="100" height="100"/>

ElectronSharp

Build cross platform desktop apps with .NET 7 and ASP.NET Core (Razor Pages, MVC), Blazor or h5.

ElectronSharp is a wrapper around a "normal" Electron application with an embedded ASP.NET Core application. It uses a socket-based IPC bridge we can invoke Electron APIs from .NET.

The CLI extensions hosts the toolset to build and start ElectronSharp-based applications.

ElectronSharp is a hard fork from the original Electron.NET project, mantained by me and used to build the Curiosity app.

📦 NuGet:

  • API NuGet
  • CLI NuGet

🛠 Requirements to run:

The current ElectronSharp CLI builds Windows/macOS/Linux binaries. The API uses .NET 7, so our minimum base OS is the same as .NET 7.

Also you should have installed:

👩‍🏫 Usage

To activate and communicate with the Electron API, include the ElectronNET.API NuGet package in your ASP.NET Core app. Check out the Electron.SampleApp for an example of how to use ElectronSharp.

PM> Install-Package ElectronSharp.API

Program.cs

You start ElectronSharp up with an UseElectron WebHostBuilder-Extension.

public static IHostBuilder CreateHostBuilder(string[] args) =>
    Host.CreateDefaultBuilder(args)
        .ConfigureWebHostDefaults(webBuilder =>
        {
            webBuilder.UseElectron(args);
            webBuilder.UseStartup<Startup>();
        });

Startup.cs

Open the Electron Window in the Startup.cs file:

public void Configure(IApplicationBuilder app, IWebHostEnvironment env)
{
    ...

    // Open the Electron-Window here
    Task.Run(async () => await Electron.WindowManager.CreateWindowAsync());
}

🚀 Start the Application

To start the application make sure you have installed the "ElectronSharp.CLI" packages as global tool:

dotnet tool install ElectronSharp.CLI -g

At the first time, you need an ElectronSharp project initialization. Type the following command in your app folder:

electron-sharp init
  • Now a electronnet.manifest.json should appear in your ASP.NET Core project
  • Now run the following:
electron-sharp start

Hint

If invoking any of those commands gives you strange errors (like .NET 5 not installed, but your project is .NET 6), it means you've typed electronize instead of electron-sharp.

Note

Only the first electronize start is slow. The next will go on faster.

🔭 Develop ElectronSharp apps using a file watcher

The file watcher is included with version 8.31.1 of ElectronSharp. For example, a file change can trigger compilation, test execution, or deployment. The ElectronSharp window will automatically refresh and new code changes will be visible more quickly. The following ElectronSharp CLI command is required:

electron-sharp start /watch

Note

Only the first electronize start is slow. The next will go on faster.

🐞 Debug

Start your ElectronSharp application with the ElectronSharp CLI command. In Visual Studio attach to your running application instance. Go in the Debug Menu and click on Attach to Process.... Sort by your projectname on the right and select it on the list.

📔 Usage of the Electron-API

A complete documentation will follow. Until then take a look in the source code of the sample application:
ElectronSharp Sample App

⛏ Build

Here you need the ElectronSharp CLI as well. Type the following command in your ASP.NET Core folder:

electronize build /target win

There are additional platforms available:

electron-sharp build /target win
electron-sharp build /target osx
electron-sharp build /target osx-arm64
electron-sharp build /target linux

Those four "default" targets will produce packages for those platforms. Note that the osx-arm64 is for Apple Silicon Macs.

For certain NuGet packages or certain scenarios you may want to build a pure x86 application. To support those things you can define the desired .NET runtime, the electron platform and electron architecture like this:

electron-sharp build /target custom "win7-x86;win32" /electron-arch ia32 

The end result should be an electron app under your /bin/desktop folder.

Note

macOS builds can't be created on Windows machines because they require symlinks that aren't supported on Windows (per this Electron issue). macOS builds can be produced on either Linux or macOS machines.

👨‍💻 Original (Electron.NET) Authors

  • Gregor Biswanger - (Microsoft MVP, Intel Black Belt and Intel Software Innovator) is a freelance lecturer, consultant, trainer, author and speaker. He is a consultant for large and medium-sized companies, organizations and agencies for software architecture, web- and cross-platform development. You can find Gregor often on the road attending or speaking at international conferences. - Cross-Platform-Blog - Twitter @BFreakout
  • Robert Muehsig - Software Developer - from Dresden, Germany, now living & working in Switzerland. Microsoft MVP & Web Geek. - codeinside Blog - Twitter @robert0muehsig

See also the list of contributors who participated in the original project.

🙋‍♀️🙋‍♂ Contributing

Feel free to submit a pull request if you find any bugs (to see a list of active issues, visit the Issues section. Please make sure all commits are properly documented.

🎉 License

MIT-licensed

Product Compatible and additional computed target framework versions.
.NET net7.0 is compatible.  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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

This package has no dependencies.

Version Downloads Last updated
32.0.1.51369 1,042 8/23/2024
31.3.1.50855 202 7/29/2024
31.3.0.50755 97 7/28/2024
31.3.0.50594 130 7/25/2024
31.2.1.50335 212 7/16/2024
31.2.0.50292 118 7/15/2024
31.1.0.50269 103 7/13/2024
31.1.0.49989 218 6/27/2024
30.0.6.49104 448 5/22/2024
30.0.6.49034 137 5/19/2024
30.0.6.48961 160 5/16/2024
30.0.4.48738 138 5/14/2024
30.0.2.48552 158 5/9/2024
30.0.2.48434 150 5/7/2024
30.0.2.48296 99 5/2/2024
30.0.1.47933 253 4/19/2024
30.0.0.47870 127 4/17/2024
29.3.0.47750 247 4/12/2024
29.1.5.47165 418 3/22/2024
29.1.5.47134 220 3/21/2024
29.1.4.46985 307 3/14/2024
29.0.1.46142 624 2/22/2024
28.2.0.44969 1,157 1/27/2024
28.1.3.44599 304 1/11/2024
28.0.0.44380 308 12/14/2023
27.1.0.43670 973 11/17/2023
27.1.0.43644 165 11/16/2023
27.1.0.43604 229 11/16/2023
27.0.4.43553 191 11/13/2023
27.0.4.43552 142 11/13/2023
27.0.4.43498 253 11/9/2023
27.0.2.43249 383 10/24/2023
27.0.1.43128 332 10/19/2023
27.0.0.43002 317 10/13/2023
26.3.0.42624 418 10/5/2023
26.3.0.42623 225 10/5/2023
26.2.4.42548 268 10/2/2023
26.2.2.42382 336 9/20/2023
26.2.1.42149 268 9/16/2023
26.2.1.42101 239 9/15/2023
26.2.0.41770 351 9/7/2023
26.1.0.41750 212 9/6/2023
26.1.0.41739 191 9/6/2023
26.1.0.41637 230 9/5/2023
26.1.0.41603 239 9/4/2023
26.1.0.41265 403 8/28/2023
26.1.0.41264 268 8/28/2023
26.1.0.41263 253 8/28/2023
26.1.0.41243 292 8/28/2023
26.1.0.41010 382 8/24/2023
26.0.0.40902 291 8/22/2023
25.3.1.40533 472 8/8/2023
25.3.1.40262 284 7/20/2023
25.3.0.40090 216 7/16/2023
25.2.0.39535 421 6/27/2023
25.2.0.39487 174 6/26/2023
25.0.1.39151 256 6/2/2023
25.0.0.39150 151 6/2/2023
25.0.0.38955 241 5/30/2023
24.4.0.38875 203 5/25/2023
24.4.0.38874 155 5/25/2023
24.0.0.37423 838 4/11/2023
23.1.3.36686 345 3/15/2023
23.1.3.36685 214 3/15/2023
23.1.3.36684 219 3/15/2023
23.1.3.36622 283 3/9/2023
23.0.0.36276 385 2/15/2023
23.0.0.36236 256 2/14/2023
23.0.0.36228 276 2/13/2023
23.0.0.36192 275 2/13/2023
23.0.0.35946 301 2/7/2023
22.2.0.35891 315 2/5/2023
22.2.0.35887 278 2/4/2023
22.1.0.35531 281 1/27/2023
22.0.2.35227 367 1/15/2023
22.0.0.35063 314 1/5/2023
22.0.0.35062 329 1/5/2023
22.0.0.35061 316 1/5/2023
22.0.0.35059 295 1/5/2023
22.0.0.35057 294 1/5/2023