kreta/KretaWeb/Areas/OsztalyCsoport/ApiControllers/OsztalyAmiApiController.cs
2024-03-13 00:33:46 +01:00

237 lines
9.6 KiB
C#

using System;
using System.Collections.Generic;
using System.Linq;
using System.Net;
using System.Net.Http;
using System.Web.Http;
using System.Web.Http.Results;
using Kendo.Mvc.UI;
using Kreta.BusinessLogic.Classes.ComboBox;
using Kreta.BusinessLogic.Helpers;
using Kreta.BusinessLogic.Logic;
using Kreta.BusinessLogic.Security;
using Kreta.Core;
using Kreta.Core.Exceptions;
using Kreta.Enums;
using Kreta.Framework;
using Kreta.Framework.Util;
using Kreta.Resources;
using Kreta.Web.Areas.OsztalyCsoport.Logic;
using Kreta.Web.Areas.OsztalyCsoport.Models;
using Kreta.Web.Helpers;
using Kreta.Web.Helpers.Error;
using Kreta.Web.Helpers.Grid;
using Kreta.Web.Security;
using Newtonsoft.Json;
namespace Kreta.Web.Areas.OsztalyCsoport.ApiControllers
{
[ApiRoleClaimsAuthorize(true)]
[ApiRolePackageAuthorize(KretaClaimPackages.AMImodul.ClaimValue)]
public class OsztalyAmiApiController : ApiController
{
public DataSourceResult GetOsztalyGrid(string data, DataSourceRequest request)
{
var (gridParameter, modelList) = GetGridData(data, request);
return modelList.ToDataSourceResult(gridParameter);
}
[ApiRolePackageAuthorize(KretaClaimPackages.Adminisztrator.ClaimValue)]
public HttpResponseMessage GetExport(string data, DataSourceRequest request)
{
try
{
var (gridParameter, modelList) = GetGridData(data, request);
modelList = modelList.SortingAndPaging(gridParameter.OrderDictionary);
var simpleExportColumnCos = SimpleExportLogic.GetSimpleExportColumnCos<OsztalyGridModel>(OsztalyGridModel.OsztalyExportAttributeId);
var memoryStream = SimpleExportLogic.GetExport(OsztalyCsoportResource.Osztalyok, simpleExportColumnCos, modelList, ClaimData.SelectedTanevID.Value);
return HttpResponseExtensions.GetFileHttpResponse(memoryStream.ToArray(), $"{OsztalyCsoportResource.OsztalyokExportFileName}_{DateTime.Now:yyyy_MM_dd}.xlsx");
}
catch (Exception ex)
{
throw new StatusError(HttpStatusCode.BadRequest, ErrorResource.HibaTortentAFajlExportalasaKozben) { UnHandledException = ex };
}
}
private (GridParameters gridParameter, List<OsztalyGridModel> modelList) GetGridData(string data, DataSourceRequest request)
{
var model = JsonConvert.DeserializeObject<OsztalySearchModel>(data);
var gridParameter = Converter.GridParameter(request);
var searchCo = model.ConvertToCo(OsztalyCsoportLogic.GetSearchDate());
searchCo.FeladatKategoriaId = (int)OktNevelesiKategoriaEnum.AlapfokuMuveszetoktatas;
var coList = new OsztalyHelper(ConnectionTypeExtensions.GetSessionConnectionType()).GetOsztalyCoList(searchCo);
var modelList = new List<OsztalyGridModel>();
foreach (var co in coList)
{
var gridModel = new OsztalyGridModel(co);
modelList.Add(gridModel);
}
return (gridParameter, modelList);
}
[HttpPost]
[ApiValidateAjaxAntiForgeryToken]
public HttpResponseMessage SaveOsztaly(AmiOsztalyModel model)
{
try
{
ModelState.AddRange(AmiOsztalyCsoportLogic.ValidateOsztaly(model));
if (model.NaplosorszamEsTorzslapszamBeallitasaiModelList?.Count > 0)
{
ModelState.AddRange(OsztalyCsoportLogic.ValidateNaplosorszamEsTorzslapszamBeallitasaiModelList(model.NaplosorszamEsTorzslapszamBeallitasaiModelList));
}
if (ModelState.IsValid)
{
AmiOsztalyCsoportLogic.SaveOsztaly(model);
if (model.NaplosorszamEsTorzslapszamBeallitasaiModelList?.Count > 0)
{
OsztalyCsoportLogic.SaveNaplosorszamEsTorzslapszamBeallitasai(model.NaplosorszamEsTorzslapszamBeallitasaiModelList);
}
return new HttpResponseMessage(HttpStatusCode.OK);
}
return Request.CreateErrorResponse(HttpStatusCode.BadRequest, ModelState);
}
catch (SDA.DataProvider.UniqueKeyViolationException)
{
throw new StatusError(HttpStatusCode.BadRequest, StringResourcesUtil.GetString(3684)); // Ebben a tanévben már létezik ilyen nevű osztály
}
catch (BlException e)
{
throw new StatusError(HttpStatusCode.BadRequest, e.Message);
}
}
public HttpResponseMessage SaveModifiedOsztalyGroup(ModOsztalyModel model)
{
try
{
ModelState.AddRange(OsztalyCsoportLogic.ValidateOsztalyGroup(model));
if (ModelState.IsValid)
{
var errorMessage = OsztalyCsoportLogic.SaveOsztalyGroup(model);
if (!string.IsNullOrWhiteSpace(errorMessage))
{
errorMessage = $"{ErrorResource.AzAlabbiOsztalyCsoportokModositasaSikertelenVoltMertVanTanuloBesorolas}{errorMessage}";
return Request.CreateResponse(HttpStatusCode.OK, errorMessage);
}
}
else
{
return Request.CreateErrorResponse(HttpStatusCode.BadRequest, ModelState);
}
}
catch (BlException e)
{
throw new StatusError(HttpStatusCode.BadRequest, e.Message);
}
catch (Exception ex)
{
throw new StatusError(HttpStatusCode.BadRequest, ex.Message);
}
return new HttpResponseMessage(HttpStatusCode.OK);
}
public HttpResponseMessage SaveNaplosorszamListGroup(ModOsztalyModel model)
{
try
{
if (ModelState.IsValid)
{
OsztalyCsoportLogic.SaveNaplosorszamListGroup(model.OsztalyIdArray.Select(int.Parse).ToList());
}
else
{
return Request.CreateErrorResponse(HttpStatusCode.BadRequest, ModelState);
}
}
catch (BlException e)
{
throw new StatusError(HttpStatusCode.BadRequest, e.Message);
}
catch (Exception ex)
{
throw new StatusError(HttpStatusCode.BadRequest, ex.Message);
}
return new HttpResponseMessage(HttpStatusCode.OK);
}
public ModOsztalyModel GetOsztalyModProperties(int? osztalyID = null)
{
return OsztalyCsoportLogic.GetOsztalyModProperties(osztalyID);
}
public DataSourceResult GetOsztalyTanuloi(string osztalyId, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request)
{
return OsztalyCsoportLogic.GetOsztalyTanuloi(osztalyId, request);
}
//Osztályhoz tartozó összes csoport + osztálybontás csoportjai
public DataSourceResult GetOsztalyBontasCsoportjai(string osztalyID, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request)
{
return OsztalyCsoportLogic.GetOsztalyBontasCsoportjai(osztalyID, request);
}
public DataSourceResult GetOsztalyFoglalkozasai(int osztalyID, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request)
{
return OsztalyCsoportLogic.GetOsztalyFoglalkozasai(osztalyID, request);
}
public DataSourceResult GetOsztalyOrarendiOrai(string osztalyID, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request)
{
return OsztalyCsoportLogic.GetOsztalyOrarendiOrai(osztalyID, request);
}
public DataSourceResult GetOsztalyTanmenetei(int osztalyID, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request)
{
return OsztalyCsoportLogic.GetOsztalyTanmenetei(osztalyID, request);
}
public DataSourceResult GetOsztalyErtekelesListGrid(string osztalyId, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request)
{
return OsztalyCsoportLogic.GetOsztalyErtekelesListGrid(osztalyId, request, (int)OktNevelesiKategoriaEnum.AlapfokuMuveszetoktatas);
}
public DataSourceResult GetOsztalyIgazolasai(int osztalyID, [System.Web.Http.ModelBinding.ModelBinder(typeof(ModelBinder.DataSourceRequestModelBinder))] DataSourceRequest request)
{
return OsztalyCsoportLogic.GetOsztalyIgazolasai(osztalyID, request);
}
[HttpPost]
[ApiValidateAjaxAntiForgeryToken]
public IHttpActionResult DeleteOsztalyok(DeleteOsztalyModel model)
{
var returnMsg = OsztalyCsoportLogic.DeleteOsztalyok(model.OsztalyIdLista, model.CsoportokTorlese, out bool deleteError);
if (deleteError)
{
throw new StatusError(HttpStatusCode.BadRequest, returnMsg);
}
return Json(new { Message = returnMsg });
}
public JsonResult<List<ComboBoxListItem>> GetEvfolyamList(string cascadeFilter)
{
return Json(OsztalyCsoportLogic.GetEvfolyamListFilter(cascadeFilter));
}
}
}