CurrieTechnologies.Razor.SweetAlert2
0.1.0
See the version list below for details.
dotnet add package CurrieTechnologies.Razor.SweetAlert2 --version 0.1.0
NuGet\Install-Package CurrieTechnologies.Razor.SweetAlert2 -Version 0.1.0
<PackageReference Include="CurrieTechnologies.Razor.SweetAlert2" Version="0.1.0" />
paket add CurrieTechnologies.Razor.SweetAlert2 --version 0.1.0
#r "nuget: CurrieTechnologies.Razor.SweetAlert2, 0.1.0"
// Install CurrieTechnologies.Razor.SweetAlert2 as a Cake Addin #addin nuget:?package=CurrieTechnologies.Razor.SweetAlert2&version=0.1.0 // Install CurrieTechnologies.Razor.SweetAlert2 as a Cake Tool #tool nuget:?package=CurrieTechnologies.Razor.SweetAlert2&version=0.1.0
This package is for Server-side Blazor only. For Client-side Blazor use CurrieTechnologies.Blazor.SweetAlert2
🙌 Includes themes from the Official SweetAlert2 Themes project 🙌
Installation
Install-Package CurrieTechnologies.Razor.SweetAlert2
Or grab from Nuget
Usage
Register the service in your Startup file.
// Startup.cs
public void ConfigureServices(IServiceCollection services)
{
...
services.AddSweetAlert2();
...
}
OR
If you want to use one of the Official SweetAlert2 themes
// Startup.cs
public void ConfigureServices(IServiceCollection services)
{
...
services.AddSweetAlert2(options => {
options.Theme = SweetAlertTheme.Dark;
});
...
}
Add this script tag in your root html file (Likely _Host.cshtml), right under the <script src="_framework/blazor.server.js"></script>
tag.
<script src="_content/currietechnologiesrazorsweetalert2/sweetalert2.min.js"></script>
Inject the SweetAlertService into any Blazor component
// Sample.razor
@inject SweetAlertService Swal;
<button class="btn btn-primary"
@onclick="@(async () => await Swal.FireAsync("Any fool can use a computer"))">
Try me!
</button>
Examples
The most basic message:
await Swal.FireAsync("Hello world!");
A message signaling an error:
await Swal.FireAsync("Oops...", "Something went wrong!", "error");
Handling the result of SweetAlert2 modal:
// async/await
SweetAlertResult result = await Swal.FireAsync(new SweetAlertOptions
{
Title = "Are you sure?",
Text = "You will not be able to recover this imaginary file!",
Type = SweetAlertType.Warning,
ShowCancelButton = true,
ConfirmButtonText = "Yes, delete it!",
CancelButtonText = "No, keep it"
});
if (!string.IsNullOrEmpty(result.Value))
{
await Swal.FireAsync(
"Deleted",
"Your imaginary file has been deleted.",
SweetAlertType.Success
);
}
else if (result.Dismiss == DismissReason.Cancel)
{
await Swal.FireAsync(
"Cancelled",
"Your imaginary file is safe :)",
SweetAlertType.Error
);
}
// Promise/Task based
Swal.FireAsync(new SweetAlertOptions
{
Title = "Are you sure?",
Text = "You will not be able to recover this imaginary file!",
Type = SweetAlertType.Warning,
ShowCancelButton = true,
ConfirmButtonText = "Yes, delete it!",
CancelButtonText = "No, keep it"
}).ContinueWith(swalTask =>
{
SweetAlertResult result = swalTask.Result;
if (!string.IsNullOrEmpty(result.Value))
{
Swal.FireAsync(
"Deleted",
"Your imaginary file has been deleted.",
SweetAlertType.Success
);
}
else if (result.Dismiss == DismissReason.Cancel)
{
Swal.FireAsync(
"Cancelled",
"Your imaginary file is safe :)",
SweetAlertType.Error
);
}
});
More examples can be found on the SweetAlert2 project site
Notable differences from the JavaScript library
- No methods that return an HTMLElement are included (e. g.
Swal.getContainer()
) - The value of a
SweetAlertResult
(result.Value
) can only be a string (or a collection of strings if returned from a queue request). Numbers and booleans must be converted. Object must be parsed to/from JSON in your code. OnOpenAsync()
,OnCloseAsync()
,OnBeforeOpenAsync()
, andOnAfterCloseAsync()
can all take asynchronous callbacks. 🎉 (none will return an HTMLElement though.)- Callbacks must be passed inside of objects specifically designed for the given callback property. e.g. the
InputValidator
property takes anInputValidatorCallback
created like so:
new SweetAlertOptions {
...
InputValidator = new InputValidatorCallback(this, (string input) => input.Length == 0 ? "Please provide a value" : null),
...
}
this
is passed in so that the Blazor EventCallback
used behind the scenes can trigger a re-render if the state of the calling component was changed in the callback.
These callbacks are necessary because there is currently no way to create an EventCallback
in Blazor that isn't a component parameter without using the EventCallbackFactory
which is clunky. It also allows the callback to return a value that can be used by the SweetAlert2 library. (e.g. A validation message to show if input validation fails.) Native Blazor EventCallback
s only return generic Task
s.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 was computed. net5.0-windows was computed. net6.0 was computed. 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. |
.NET Core | netcoreapp3.0 is compatible. netcoreapp3.1 was computed. |
-
.NETCoreApp 3.0
- No dependencies.
NuGet packages (7)
Showing the top 5 NuGet packages that depend on CurrieTechnologies.Razor.SweetAlert2:
Package | Downloads |
---|---|
OneLine.Blazor
OneLine.Blazor is a set of components and utilities to be used in blazor context. |
|
Necnat.Abp.NnLibCommon.Blazor
Package Description |
|
Tuic
Web front-end components package for use in Blazor WASM. The components utilize Bootstrap 5.0 and based on Tabler. |
|
TucComponents
Web front-end components package for use in Blazor WASM. The components utilize Bootstrap 5.0. |
|
Zoy.Core.App.Web
Package Description |
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
5.6.0 | 53,886 | 3/19/2024 |
5.5.0 | 81,615 | 3/29/2023 |
5.4.0 | 26,708 | 12/14/2022 |
5.3.0 | 9,710 | 10/11/2022 |
5.2.1 | 46,656 | 4/13/2022 |
5.2.0 | 10,140 | 3/16/2022 |
5.1.0 | 67,625 | 11/8/2021 |
5.0.3 | 7,805 | 10/6/2021 |
5.0.2 | 2,820 | 9/10/2021 |
5.0.1 | 8,216 | 6/23/2021 |
5.0.0 | 4,073 | 6/16/2021 |
5.0.0-preview.1 | 166 | 6/16/2021 |
4.5.0 | 8,008 | 5/7/2021 |
4.4.0 | 4,324 | 4/7/2021 |
4.3.1 | 22,845 | 11/20/2020 |
4.3.0 | 8,312 | 11/5/2020 |
4.2.0 | 8,433 | 11/2/2020 |
4.1.0 | 2,021 | 10/22/2020 |
4.0.0 | 5,890 | 10/14/2020 |
3.0.0 | 2,850 | 9/17/2020 |
2.10.1 | 5,803 | 8/10/2020 |
2.10.0 | 5,610 | 7/14/2020 |
2.9.1 | 1,879 | 7/14/2020 |
2.9.0 | 2,701 | 6/26/2020 |
2.8.2 | 2,564 | 6/16/2020 |
2.8.1 | 2,999 | 6/8/2020 |
2.8.0 | 1,986 | 6/5/2020 |
2.7.0 | 4,352 | 5/21/2020 |
2.6.7 | 2,160 | 5/13/2020 |
2.6.6 | 30,765 | 4/20/2020 |
2.6.5 | 3,612 | 4/6/2020 |
2.6.4 | 2,183 | 4/1/2020 |
2.6.3 | 2,010 | 3/25/2020 |
2.6.2 | 1,997 | 3/23/2020 |
2.6.1 | 1,902 | 3/19/2020 |
2.6.0 | 3,570 | 3/9/2020 |
2.5.4 | 2,534 | 2/24/2020 |
2.5.3 | 2,007 | 2/19/2020 |
2.5.2 | 2,472 | 2/7/2020 |
2.5.1 | 2,087 | 1/30/2020 |
2.5.0 | 1,998 | 1/22/2020 |
2.4.1 | 2,006 | 1/21/2020 |
2.4.0 | 2,066 | 1/15/2020 |
2.3.2 | 1,992 | 1/15/2020 |
2.3.1 | 2,001 | 12/31/2019 |
2.3.0 | 4,594 | 12/12/2019 |
2.2.2 | 1,962 | 12/10/2019 |
2.2.1 | 2,173 | 12/6/2019 |
2.2.0 | 2,090 | 12/3/2019 |
2.1.14 | 1,901 | 12/3/2019 |
2.1.13 | 1,985 | 12/3/2019 |
2.1.12 | 1,916 | 12/2/2019 |
2.1.11 | 2,005 | 11/25/2019 |
2.1.10 | 1,878 | 11/21/2019 |
2.1.9 | 1,911 | 11/19/2019 |
2.1.8 | 1,929 | 11/19/2019 |
2.1.7 | 1,918 | 11/18/2019 |
2.1.6 | 1,886 | 11/15/2019 |
2.1.5 | 1,913 | 11/15/2019 |
2.1.4 | 1,850 | 11/15/2019 |
2.1.3 | 1,920 | 11/14/2019 |
2.1.2 | 1,899 | 11/13/2019 |
2.1.1 | 2,208 | 11/12/2019 |
2.1.0 | 1,952 | 11/11/2019 |
2.0.2 | 1,976 | 11/8/2019 |
2.0.1 | 1,962 | 11/6/2019 |
2.0.0 | 2,044 | 11/5/2019 |
1.2.4 | 2,020 | 11/4/2019 |
1.2.3 | 1,963 | 11/1/2019 |
1.2.2 | 1,963 | 10/23/2019 |
1.2.1 | 1,978 | 10/18/2019 |
1.2.0 | 1,934 | 10/17/2019 |
1.1.1 | 1,939 | 10/16/2019 |
1.1.0 | 1,977 | 10/11/2019 |
1.0.4 | 1,917 | 10/10/2019 |
1.0.3 | 1,868 | 10/9/2019 |
1.0.2 | 1,950 | 10/7/2019 |
1.0.1 | 2,014 | 9/30/2019 |
1.0.0 | 1,980 | 9/23/2019 |
0.10.2 | 336 | 9/19/2019 |
0.10.1 | 358 | 9/17/2019 |
0.10.0 | 321 | 9/16/2019 |
0.9.1 | 315 | 9/16/2019 |
0.9.0 | 334 | 9/4/2019 |
0.8.5 | 317 | 9/4/2019 |
0.8.0 | 317 | 9/3/2019 |
0.7.1 | 342 | 8/22/2019 |
0.7.0 | 330 | 8/19/2019 |
0.6.1 | 327 | 8/16/2019 |
0.6.0 | 325 | 8/13/2019 |
0.5.0 | 321 | 8/12/2019 |
0.4.5 | 338 | 8/9/2019 |
0.4.4 | 336 | 8/5/2019 |
0.4.3 | 334 | 8/2/2019 |
0.4.2 | 333 | 8/2/2019 |
0.4.1 | 327 | 7/29/2019 |
0.4.0 | 338 | 7/23/2019 |
0.3.1 | 1,969 | 7/18/2019 |
0.3.0 | 2,032 | 7/18/2019 |
0.2.9 | 2,022 | 7/17/2019 |
0.2.2 | 1,934 | 7/15/2019 |
0.2.1 | 2,019 | 7/9/2019 |
0.2.0 | 2,004 | 6/17/2019 |
0.1.3 | 2,039 | 6/14/2019 |
0.1.2 | 1,994 | 6/14/2019 |
0.1.0 | 2,056 | 6/14/2019 |
Initial realease