Files
everything2/EveryThing/Pages/TransportLoadingOrder/Index.cshtml.cs
2023-06-26 08:12:25 +02:00

78 lines
2.9 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Threading.Tasks;
using Microsoft.AspNetCore.Identity;
using Microsoft.AspNetCore.Mvc;
using Microsoft.AspNetCore.Mvc.RazorPages;
using Microsoft.EntityFrameworkCore;
using EveryThing.Data;
using EveryThing.Models;
using EveryThing.Models.Transport;
using Microsoft.AspNetCore.Authorization;
namespace EveryThing.Pages.TransportLoadingOrder
{
[Authorize(Roles = "Administrator,TransportThingUser")]
public class IndexModel : PageModel
{
private readonly EveryThing.Data.ApplicationDbContext _context;
private readonly UserManager<IdentityApplicationUser> _userManager;
public IndexModel(EveryThing.Data.ApplicationDbContext context, UserManager<IdentityApplicationUser> userManager)
{
_context = context;
_userManager = userManager;
}
public IList<Models.Transport.TransportLoadingOrder> TransportLoadingOrder { get;set; }
public async Task OnGetAsync(string searchString)
{
ViewData["SearchString"] = searchString;
var user = _userManager.GetUserAsync(User).Result;
TransportLoadingOrder = await _context.TransportLoadingOrders
.Include(t => t.Partner)
.Where(x => x.IdCompanyFk == user.IdCompanyFk)
.OrderByDescending(x => x.OrderYear).ThenByDescending(x => x.OrderNumber)
.ToListAsync();
if (!string.IsNullOrEmpty(searchString))
{
TransportLoadingOrder = TransportLoadingOrder.Where(x => x.Company.Title.Contains(searchString) || x.OrderYear + "-" + x.OrderNumber == searchString).ToList();
}
}
public IActionResult OnDeleteTransportLoadingOrder(int idLoadingOrder)
{
var user = _userManager.GetUserAsync(User).Result;
var successful = true;
var error = "";
var transportLoadingOrder = _context.TransportLoadingOrders
.Where(x => x.IdCompanyFk == user.IdCompanyFk)
.FirstOrDefault(x => x.IdTransportLoadingOrder == idLoadingOrder);
if (transportLoadingOrder != null)
{
var items = _context.TransportLoadingOrderLoadUnloads.Where(x => x.IdTransportLoadingOrderFk == idLoadingOrder).ToList();
for (var i = 0; i < items.Count(); i++)
{
_context.TransportLoadingOrderLoadUnloads.Remove(items[i]);
}
_context.TransportLoadingOrders.Remove(transportLoadingOrder);
_context.SaveChanges();
}
else
{
successful = false;
error = $"Transport loading order with ID: {idLoadingOrder} not found";
}
return new JsonResult(new { idLoadingOrder = idLoadingOrder, error = error, successful = successful });
}
}
}