Gridazor 1.0.0-alpha
See the version list below for details.
dotnet add package Gridazor --version 1.0.0-alpha
NuGet\Install-Package Gridazor -Version 1.0.0-alpha
<PackageReference Include="Gridazor" Version="1.0.0-alpha" />
paket add Gridazor --version 1.0.0-alpha
#r "nuget: Gridazor, 1.0.0-alpha"
// Install Gridazor as a Cake Addin #addin nuget:?package=Gridazor&version=1.0.0-alpha&prerelease // Install Gridazor as a Cake Tool #tool nuget:?package=Gridazor&version=1.0.0-alpha&prerelease
Gridazor
Gridazor is a C# library that provides HTML helpers for Razor views/pages in ASP.NET Core applications. It simplifies the process of generating and managing data tables in your web applications by using the powerful Ag-Grid library for the front end. With Gridazor, you can easily bind lists to tables and submit data without needing AJAX.
Features
- Easy Table Generation: Automatically generate tables from your models.
- Data Binding: Bind lists to tables with minimal setup.
- Non-AJAX Submission: Submit table data without the need for AJAX.
- Ag-Grid Integration: Utilize the robust features of Ag-Grid for front-end table management.
- Customizable: Customize column definitions, cell editors, and more.
Installation
You can install Gridazor via NuGet Package Manager:
Install-Package Gridazor
Or via the .NET CLI:
dotnet add package Gridazor
Usage
Example Model
public class IndexVM
{
public List<Test> Tests { get; set; } = [];
}
public class Test
{
[Hide]
[Required(false)]
public Guid Id { get; set; } = Guid.NewGuid();
[RowSelection]
public string Name { get; set; } = string.Empty;
[CellEditor("agLargeTextCellEditor")]
public string? Description { get; set; }
public int CatId { get; set; }
}
Example Razor View
@model IndexVM
@using Gridazor;
<div class="card card-primary">
@using (Html.BeginForm("Index", "Home", FormMethod.Post))
{
<div class="card-header">
<button id="delete-button" type="button" class="btn btn-danger">Delete</button>
</div>
<div class="card-body">
@Html.GridEditorFor(x => x.Tests, "myGrid", "ag-theme-quartz")
</div>
<div class="card-footer">
<button type="submit" class="btn btn-primary">Submit</button>
</div>
}
</div>
Example Script Section
@section Scripts{
<script src="https://cdn.jsdelivr.net/npm/ag-grid-community/dist/ag-grid-community.min.js"></script>
<script>
const dropdownValues = @Html.Raw(Json.Serialize(ViewBag.Cats));
$("#myGrid").gridazor({
propertyName: '@nameof(Model.Tests)',
enableRtl: false,
overrideColumnDefs: [{
field: "catId",
headerName: "Cat Id",
cellEditor: CustomDropdownEditor,
cellEditorParams: {
values: dropdownValues.map(item => ({
value: item.id,
text: item.name
}))
},
valueFormatter: function (params) {
const option = params.colDef.cellEditorParams.values.find(opt => opt.value === params.value);
return option ? option.text : params.value;
}
}],
enableDelete: true,
deleteButtonId: "delete-button"
});
</script>
}
Customization
Gridazor allows for extensive customization, including:
- Column Definitions: Override default column definitions.
- Cell Editors: Use custom cell editors or pre-built Ag-Grid editors.
- RTL Support: Enable or disable right-to-left text direction.
- Row Deletion: Enable row deletion with a custom delete button.
Contributing
Contributions are welcome! Please feel free to submit a pull request or open an issue.
License
This project is licensed under the MIT License. See the LICENSE file for details.
Product | Versions 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 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 is compatible. 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. |
-
net6.0
- Microsoft.AspNetCore.Mvc.ViewFeatures (>= 2.2.0)
-
net7.0
- Microsoft.AspNetCore.Mvc.ViewFeatures (>= 2.2.0)
-
net8.0
- Microsoft.AspNetCore.Mvc.ViewFeatures (>= 2.2.0)
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.0.4 | 780 | 10/31/2024 | |
1.0.3 | 1,082 | 9/28/2024 | |
1.0.2 | 107 | 9/27/2024 | |
1.0.1 | 145 | 9/22/2024 | |
1.0.0-alpha | 98 | 9/11/2024 |