Arora.HappyCRUD 1.0.7

dotnet add package Arora.HappyCRUD --version 1.0.7                
NuGet\Install-Package Arora.HappyCRUD -Version 1.0.7                
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="Arora.HappyCRUD" Version="1.0.7" />                
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add Arora.HappyCRUD --version 1.0.7                
#r "nuget: Arora.HappyCRUD, 1.0.7"                
#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 Arora.HappyCRUD as a Cake Addin
#addin nuget:?package=Arora.HappyCRUD&version=1.0.7

// Install Arora.HappyCRUD as a Cake Tool
#tool nuget:?package=Arora.HappyCRUD&version=1.0.7                

HappyCrud

C# Standard Class Library that perform CRUD on IList <T> while tracking Edit State and Validations

nuget

Functions

here is all the Functions and their useage in HappyCRUD

using HappyCRUD; //Using HappyCRUD 
List<Education> list = new(); //Create List of T
list.Create(); //Create new item in List and enables Edit State
list.CreateHere(1); //Create new item in a given index in List and enables Edit State
list.CreateHere(); //Create new item at the start of the List and enables Edit State
list.Cancel(); //Shut down the edit state and restore previous state 
list.Delete(); //Shut down the edit state and delete the item
list.Save(); //shut down the edit state and save the item
list.MoveUp(1); //Takes item via index and move it up
list.MoveDown(0); //Takes item via index and move it down
list.MoveTo(1,5); //Takes item via index and move it to an index then shift the others down
list.SwapWith(1,5); //Takes item via index and Swap it with other item at given index
list.StartEdit(1); //Stat edit state for item via index
list.IsModelValid(); // checks if all items in list is valid
list.First().InEditState = default; //Checks if item is in edit state 
CRUD.IsInEditState = default; //Checks if there is any item is in edit state in the whole model. 

Blazor Example

To Create item.

  <button type="button" class="btn btn-primary"  @onclick="()=>CVModel.CV.Educations.Create()">Add Education</button>

To Cancel, Save or Delete

@if (CVModel.CV.Educations[j].InEditState)
  {                   
      <button type="button" class="btn btn-outline-dark" @onclick="()=>CVModel.CV.Educations.Cancel()">Cancel</button>
      <button type="button" class="btn btn-outline-success" @onclick="()=>CVModel.CV.Educations.Save()">Save</button>
      <button type="button" class="btn btn-outline-danger" @onclick="()=>CVModel.CV.Educations.Delete()">Delete</button>
  }

To edit or move item up and down

@if (!CRUD.IsInEditState)
  {
     @if(!CVModel.CV.Educations[j].InEditState)
       {
          <button type="button" class="btn btn-primary" @onclick="()=>CVModel.CV.Educations.MoveUp(j)">&uarr;</button>
          <button type="button" class="btn btn-primary" @onclick="()=>CVModel.CV.Educations.MoveDown(j)">&darr; </button>
          <button type="button" class="btn btn-primary"  @onclick="()=>CVModel.CV.Educations.StartEdit(j)">Edit </button>
       }
  }   

bind to edit value

@if( CVModel.CV.Educations[j].InEditState )
  {
      <div class="form-group">
        <label>School Name</label>
         <InputText class="form-control" id="LocationName"  @bind-Value="CVModel.CV.Educations![j].LocationName"/>
         <ValidationMessage For="@(()=> CVModel.CV.Educations![j].LocationName)" />
      </div> 
      <div class="form-group">
         <label>Year</label>
         <InputText class="form-control" id="Year" @bind-Value="CVModel.CV.Educations![j].Year"/>
         <ValidationMessage For="@(()=> CVModel.CV.Educations![j].Year)" />
     </div>
  }
else
  {
     <div class="form-group">
         <label>School Name</label>
         <label class="form-control" id="LocationName">@CVModel.CV.Educations![j].LocationName</label>
         <ValidationMessage For="@(()=> CVModel.CV.Educations![j].LocationName)" />
    </div> 
    <div class="form-group">
         <label>Year</label>
         <label class="form-control" id="LocationName">@CVModel.CV.Educations![j].Year</label>
          <ValidationMessage For="@(()=> CVModel.CV.Educations![j].Year)" />
     </div>    
  }

Model Sample

IValidation Interfaces

using HappyCRUD;
     public class Education : IValidation
    {
        public virtual string? LocationName { get; set; }
        public string? Year { get; set; }
        public bool IsValid() => !string.IsNullOrWhiteSpace(LocationName) && !string.IsNullOrWhiteSpace(Year);
        public bool InEditState { get; set; }
    }

Model Sample Extra

HappyCRUD

Product Compatible and additional computed target framework versions.
.NET net5.0 was computed.  net5.0-windows was computed.  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. 
.NET Core netcoreapp3.0 was computed.  netcoreapp3.1 was computed. 
.NET Standard netstandard2.1 is compatible. 
.NET Framework net47 is compatible.  net471 was computed.  net472 was computed.  net48 was computed.  net481 was computed. 
MonoAndroid monoandroid was computed. 
MonoMac monomac was computed. 
MonoTouch monotouch was computed. 
Tizen tizen60 was computed. 
Xamarin.iOS xamarinios was computed. 
Xamarin.Mac xamarinmac was computed. 
Xamarin.TVOS xamarintvos was computed. 
Xamarin.WatchOS xamarinwatchos 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.0.7 651 7/19/2022
1.0.6 500 2/28/2022
1.0.4 445 10/15/2021

New CreateHere function
New MoveTo function
New SwapWith function