DrUalcman-BlazorIndexedDb
1.5.19
See the version list below for details.
dotnet add package DrUalcman-BlazorIndexedDb --version 1.5.19
NuGet\Install-Package DrUalcman-BlazorIndexedDb -Version 1.5.19
<PackageReference Include="DrUalcman-BlazorIndexedDb" Version="1.5.19" />
paket add DrUalcman-BlazorIndexedDb --version 1.5.19
#r "nuget: DrUalcman-BlazorIndexedDb, 1.5.19"
// Install DrUalcman-BlazorIndexedDb as a Cake Addin #addin nuget:?package=DrUalcman-BlazorIndexedDb&version=1.5.19 // Install DrUalcman-BlazorIndexedDb as a Cake Tool #tool nuget:?package=DrUalcman-BlazorIndexedDb&version=1.5.19
BlazorIndexedDb
Manage indexedDb from c# with Blazor. Simple way to interact with IndexedDB similar how you can do with EntityFramework
NuGet installation
PM> Install-Package DrUalcman-BlazorIndexedDb
We are working in...
Working in set the storename like the name set into the StoreSet. Now is getting from the class model name. This create you can't have 2 StoreSet with same class model (not usuall but can be). Excample, class is Person and you have Employee table and Customer table using this class. Then in indexed DB only create one Store with name Person.
Current features
Create StoreContext from abstract class. StoreSet per each model you need into a database. Set PrimaKey in the model. CURD from StoreSet Select all or one by PrimaryKey or property (field only one field for the where action) from StoreSet
How to use
BlazorIndexedDb requires an instance IJSRuntime, should normally already be registered.
Create any code first database model you'd like to create and inherit from IndexedDb. You must be use the attribute FieldAttribute to setup the properties.
Your model (eg. PlayList) should contain an Id property or a property marked with the key attribute.
public class PlayList
{
[FieldAttribute(IsKeyPath = true, IsAutoIncemental = false, IsUnique = true)]
public string Id { get; set; }
public string Url { get; set; }
public string Title { get; set; }
public string Ownner { get; set; }
}
namespace
BlazorIndexedDb
BlazorIndexedDb.Attributes
BlazorIndexedDb.Commands
BlazorIndexedDb.Models
BlazorIndexedDb.Store
Then can create a DBContext class inherits from StoreContext to manage the database like in EF using a constructor with IJSRuntime and properties with the server about how to manage your tables.
public class DBContext : StoreContext
{
#region properties
public StoreSet<PlayList> PlaysList { get; set; }
#endregion
#region constructor
public DBContext(IJSRuntime js) : base(js, new Settings { DBName = "MyDBName", Version = 1 }) { }
#endregion
}
In Program.cs add the service for the DBContext
public class Program
{
public static async Task Main(string[] args)
{
var builder = WebAssemblyHostBuilder.CreateDefault(args);
builder.RootComponents.Add<App>("#app");
builder.Services.AddScoped(sp => new HttpClient { BaseAddress = new Uri(builder.HostEnvironment.BaseAddress) });
//INJECT THE DBContext
builder.Services.AddScope<DBContext>();
await builder.Build().RunAsync();
}
}
In the Index.html or the file are you using to start the app add
<script src="_content/DrUalcman-BlazorIndexedDb/jsDB.js"></script>
<script src="_content/DrUalcman-BlazorIndexedDb/MyDbJs.js"></script>
In the component need to use a IndexDb inject DBContext
[Inject]
public DBContext _DBContext { get; set; }
void Select()
{
var PlaysList = await DB.PlaysList.SelectAsync();
}
void Add()
{
var NewItems = new List<PlayList>();
CommandResponse response = await DB.PlaysList.AddAsync(NewItems);
Console.WriteLine(response.Message);
Console.WriteLine(response.Result);
//Get result per each element
foreach (var item in response.Response)
{
Console.WriteLine(item.Message);
Console.WriteLine(item.Result);
}
}
void Update()
{
var NewItem = new PlayList();
CommandResponse response = await DB.PlaysList.UpdateAsync(NewItem);
Console.WriteLine(response.Message);
Console.WriteLine(response.Result);
//Get result per each element
foreach (var item in response.Response)
{
Console.WriteLine(item.Message);
Console.WriteLine(item.Result);
}
}
void Delete()
{
int id = 1;
CommandResponse response = await DB.PlaysList.DeleteAsync(id);
Console.WriteLine(response.Message);
Console.WriteLine(response.Result);
//Get result per each element
foreach (var item in response.Response)
{
Console.WriteLine(item.Message);
Console.WriteLine(item.Result);
}
}
You can modify the model classes any time, but if the model you will pass don't match with the model created when create the IndexDb this will return a exception.
IJSRuntime Db extensions
- SingleRecord<TModel>
- DbSelect<TModel>
- DbInsert<TModel>
- DbUpdate<TModel>
- DbDelete<TModel>
- DbCleanTable<TModel>
Working with records from IJSRuntime Db extensions
In all the select action you will receive the List<TModel> except if you are looking for one Key Id send, then you will receive the Model object. In all actions you will receive a ResponseJsDb model or a List<ResponseJsDb> with all the responses, if you are sending a lot of rows.
public class ResponseJsDb
{
public bool Result { get; set; }
public string Message { get; set; }
}
Working with records from StoreSet
The store set always return the model or list of the model for all select actions and CommandResponse record for the comands actions
public record CommandResponse(bool Result, string Message, List<ResponseJsDb> Response);
More info
Check <a href="https://blazorindexdb.community-mall.com/">our web</a> to get more info.
Dependencies
<a href="https://github.com/drualcman/jsDB">jsDB</a>
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net5.0 is compatible. 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. |
-
net5.0
- Microsoft.AspNetCore.Components.Web (>= 5.0.8)
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.8.47 | 105 | 10/10/2024 | |
1.7.46 | 178 | 9/5/2024 | |
1.6.45 | 107 | 9/4/2024 | |
1.6.44 | 110 | 8/30/2024 | |
1.6.43 | 136 | 8/17/2024 | |
1.6.42 | 92 | 8/7/2024 | |
1.6.41 | 263 | 6/22/2024 | |
1.6.40 | 278 | 4/16/2024 | |
1.6.39 | 215 | 3/26/2024 | |
1.6.38 | 237 | 2/28/2024 | |
1.6.37 | 178 | 2/27/2024 | |
1.6.36 | 221 | 2/27/2024 | |
1.6.35 | 236 | 2/18/2024 | |
1.6.34 | 645 | 10/10/2023 | |
1.6.33 | 386 | 8/18/2023 | |
1.6.32 | 784 | 3/23/2023 | |
1.6.31 | 808 | 1/28/2023 | |
1.6.30 | 888 | 8/10/2022 | |
1.6.28 | 844 | 5/25/2022 | |
1.6.27 | 854 | 4/3/2022 | |
1.6.26 | 797 | 4/3/2022 | |
1.6.25 | 768 | 4/3/2022 | |
1.5.24 | 620 | 12/28/2021 | |
1.5.23 | 554 | 12/27/2021 | |
1.5.22 | 597 | 12/19/2021 | |
1.5.21 | 664 | 11/15/2021 | |
1.5.20 | 736 | 11/14/2021 | |
1.5.19 | 773 | 10/25/2021 | |
1.5.18 | 679 | 10/24/2021 | |
1.5.17 | 720 | 8/29/2021 | |
1.4.16 | 670 | 8/9/2021 | |
1.4.15 | 692 | 8/8/2021 | |
1.4.14 | 656 | 8/3/2021 | |
1.4.13 | 794 | 7/12/2021 | |
1.3.11 | 742 | 5/8/2021 | |
1.3.10 | 695 | 5/2/2021 |
Fix bug null reference when check a enumeral property. Change to abstac the class StoreContext. Removed unnecesary class StoreService and the interface.