From 3c83f9f4b01b5965e04739e5f8accf3235f8f699 Mon Sep 17 00:00:00 2001 From: Sergey Chebotar Date: Mon, 20 Feb 2023 21:53:21 +0300 Subject: [PATCH] Add base crud actions for bundles --- Controllers/BundleController.cs | 110 ++++++++++++++++++ Controllers/BundlesController.cs | 47 -------- Controllers/HomeController.cs | 8 +- Models/IRepository.cs | 10 -- Models/MyDarlingRepository.cs | 32 ----- Program.cs | 2 +- .../Add.cshtml => Bundle/Create.cshtml} | 4 +- Views/Bundle/Details.cshtml | 34 ++++++ Views/{Bundles => Bundle}/Index.cshtml | 10 +- Views/Bundles/Edit.cshtml | 34 ------ Views/Home/_Projects.cshtml | 4 +- 11 files changed, 157 insertions(+), 138 deletions(-) create mode 100644 Controllers/BundleController.cs delete mode 100644 Controllers/BundlesController.cs delete mode 100644 Models/IRepository.cs delete mode 100644 Models/MyDarlingRepository.cs rename Views/{Bundles/Add.cshtml => Bundle/Create.cshtml} (87%) create mode 100644 Views/Bundle/Details.cshtml rename Views/{Bundles => Bundle}/Index.cshtml (70%) delete mode 100644 Views/Bundles/Edit.cshtml diff --git a/Controllers/BundleController.cs b/Controllers/BundleController.cs new file mode 100644 index 0000000..8e72dd3 --- /dev/null +++ b/Controllers/BundleController.cs @@ -0,0 +1,110 @@ +using System.Data; +using Microsoft.AspNetCore.Mvc; +using Microsoft.EntityFrameworkCore; +using MyDarling.Models; + +namespace MyDarling.Controllers +{ + public class BundleController : Controller + { + private DataContext context; + public bool TryUpdateModel { get; private set; } + + public BundleController(DataContext context) + { + this.context = context; + } + + public ActionResult Index() + { + return View(context.UnderwearBundles.Include(b => b.Figures)); + } + + public ActionResult Create() + { + return View(); + } + + [HttpPost] + public async Task Create([Bind] UnderwearBundle bundle) + { + try + { + if (ModelState.IsValid) + { + await context.UnderwearBundles.AddAsync(bundle); + context.SaveChanges(); + return RedirectToAction(nameof(Index)); + } + } + catch (DataException) + { + ModelState.AddModelError("", "Unable to save changes"); + } + return View(bundle); + } + + public async Task Details(int id) + { + return View(await context.UnderwearBundles.FindAsync(id)); + } + + public async Task Edit(int id) + { + return View(nameof(Details), await context.UnderwearBundles.FindAsync(id)); + } + + [HttpPost] + public async Task Edit(int? id) + { + if (id == null) + { + return NotFound(); + } + + var bundle = await context.UnderwearBundles.FindAsync(id); + if (bundle == null) + { + return NotFound(); + } + + if (await TryUpdateModelAsync( + bundle, + "", + b => b.Name, b => b.Description, b => b.Price)) + { + try + { + await context.SaveChangesAsync(); + return RedirectToAction(nameof(Index)); + } + catch (System.Exception) + { + ModelState.AddModelError("", "Unable to save changes"); + } + } + return View(bundle); + } + + [HttpPost] + public async Task Delete(int id) + { + var bundleToDelete = await context.UnderwearBundles.FindAsync(id); + if (bundleToDelete == null) + { + return NotFound(); + } + + try + { + context.UnderwearBundles.Remove(bundleToDelete); + await context.SaveChangesAsync(); + return RedirectToAction(nameof(Index)); + } + catch(DbUpdateException) + { + return RedirectToAction(nameof(Delete), new {id = id, saveChangesError = true}); + } + } + } +} \ No newline at end of file diff --git a/Controllers/BundlesController.cs b/Controllers/BundlesController.cs deleted file mode 100644 index aeefebb..0000000 --- a/Controllers/BundlesController.cs +++ /dev/null @@ -1,47 +0,0 @@ -using Microsoft.AspNetCore.Mvc; -using Microsoft.EntityFrameworkCore; -using MyDarling.Models; - -namespace MyDarling.Controllers -{ - public class BundlesController : Controller - { - private IRepository repository; - - public BundlesController(IRepository repository) - { - this.repository = repository; - } - - public ActionResult Index() - { - return View(repository); - } - - public ActionResult Edit(int id) - { - return View(repository.Bundles.Where(b => b.Id == id).FirstOrDefault()); - } - - public ActionResult Delete(int id) - { - var bundle = repository.Bundles.Where(b => b.Id == id).FirstOrDefault(); - if (bundle != null) - { - repository.Remove(bundle); - } - return RedirectToAction("Index"); - } - - public ActionResult Add() - { - return View(); - } - [HttpPost] - public ActionResult Add(UnderwearBundle b) - { - repository.Add(b); - return RedirectToAction("Index"); - } - } -} \ No newline at end of file diff --git a/Controllers/HomeController.cs b/Controllers/HomeController.cs index 228a9c3..028322c 100644 --- a/Controllers/HomeController.cs +++ b/Controllers/HomeController.cs @@ -6,14 +6,14 @@ namespace MyDarling.Controllers { public class HomeController : Controller { - private IRepository repository; - public HomeController(IRepository repository) + private DataContext context; + public HomeController(DataContext context) { - this.repository = repository; + this.context = context; } public IActionResult Index() { - return View(repository); + return View(context.UnderwearBundles.Include(b => b.Figures)); } } } \ No newline at end of file diff --git a/Models/IRepository.cs b/Models/IRepository.cs deleted file mode 100644 index 363f48d..0000000 --- a/Models/IRepository.cs +++ /dev/null @@ -1,10 +0,0 @@ -namespace MyDarling.Models -{ - public interface IRepository - { - public IQueryable Bundles { get; } - public void Add(UnderwearBundle b); - public void Remove(UnderwearBundle p); - public void Save(); - } -} \ No newline at end of file diff --git a/Models/MyDarlingRepository.cs b/Models/MyDarlingRepository.cs deleted file mode 100644 index 15f058c..0000000 --- a/Models/MyDarlingRepository.cs +++ /dev/null @@ -1,32 +0,0 @@ -using Microsoft.EntityFrameworkCore; - -namespace MyDarling.Models -{ - public class MyDarlingRepository : IRepository - { - private DataContext DbContext { get; } - public MyDarlingRepository(IServiceProvider provider) - { - DbContext = provider.CreateScope().ServiceProvider.GetRequiredService(); - } - - public IQueryable Bundles => DbContext.UnderwearBundles.Include(b => b.Figures); - - public void Add(UnderwearBundle b) - { - DbContext.UnderwearBundles.Add(b); - DbContext.SaveChanges(); - } - - public void Remove(UnderwearBundle b) - { - DbContext.UnderwearBundles.Remove(b); - DbContext.SaveChanges(); - } - - public void Save() - { - DbContext.SaveChanges(); - } - } -} \ No newline at end of file diff --git a/Program.cs b/Program.cs index 2d52ee9..5309b9f 100644 --- a/Program.cs +++ b/Program.cs @@ -8,7 +8,7 @@ builder.Services.AddDbContext(opts => opts.UseSqlite(builder.Configuration["ConnectionStrings:MyDarlingDb"]); opts.EnableSensitiveDataLogging(true); }); -builder.Services.AddSingleton(); +// builder.Services.AddSingleton(); builder.Services.AddControllersWithViews(); var app = builder.Build(); diff --git a/Views/Bundles/Add.cshtml b/Views/Bundle/Create.cshtml similarity index 87% rename from Views/Bundles/Add.cshtml rename to Views/Bundle/Create.cshtml index 36b329b..4afc5e1 100644 --- a/Views/Bundles/Add.cshtml +++ b/Views/Bundle/Create.cshtml @@ -11,7 +11,7 @@ -
+
@@ -23,7 +23,7 @@
- +
diff --git a/Views/Bundle/Details.cshtml b/Views/Bundle/Details.cshtml new file mode 100644 index 0000000..edaec11 --- /dev/null +++ b/Views/Bundle/Details.cshtml @@ -0,0 +1,34 @@ +@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers +@model MyDarling.Models.UnderwearBundle + + + + + + Bundles list + + + + + +
+
+
+ + +
+
+ + @Html.TextAreaFor(model => model.Description, new { @class="form-control", @rows = 4 }) +
+
+ + +
+ + +
+
+ + + \ No newline at end of file diff --git a/Views/Bundles/Index.cshtml b/Views/Bundle/Index.cshtml similarity index 70% rename from Views/Bundles/Index.cshtml rename to Views/Bundle/Index.cshtml index 01c5a31..678caf0 100644 --- a/Views/Bundles/Index.cshtml +++ b/Views/Bundle/Index.cshtml @@ -1,5 +1,5 @@ @addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers -@model MyDarling.Models.IRepository +@model IQueryable @@ -18,23 +18,21 @@ Name Descrition Price - Actions - @foreach (var bundle in Model.Bundles) + @foreach (var bundle in Model) { @bundle.Id - @bundle.Name + @bundle.Name @bundle.Description @bundle.Price - Delete } - Add bundle + Add bundle
diff --git a/Views/Bundles/Edit.cshtml b/Views/Bundles/Edit.cshtml deleted file mode 100644 index 60a2420..0000000 --- a/Views/Bundles/Edit.cshtml +++ /dev/null @@ -1,34 +0,0 @@ -@addTagHelper *, Microsoft.AspNetCore.Mvc.TagHelpers - - - - - - Bundles list - - - - - - - - - - - - - - - - - - - - - - -
#NameDescritionPrice
@Model.Id@Model.Name@Model.Description@Model.Price
-
- - - \ No newline at end of file diff --git a/Views/Home/_Projects.cshtml b/Views/Home/_Projects.cshtml index 314a9f0..0603c06 100644 --- a/Views/Home/_Projects.cshtml +++ b/Views/Home/_Projects.cshtml @@ -1,10 +1,10 @@ -@model MyDarling.Models.IRepository; +@model IQueryable; @using System.Globalization;
- @foreach (var bundle in @Model.Bundles.Where(b => b.Price != 0)) + @foreach (var bundle in @Model.Where(b => b.Price != 0)) {