using EgwCoreLib.Lux.Data.DbModel.Cost; using EgwCoreLib.Lux.Data.DbModel.Task; using EgwCoreLib.Lux.Data.Services; using Microsoft.AspNetCore.Components; using Microsoft.JSInterop; namespace Lux.UI.Components.Compo.JobTask { public partial class JobStepMan { #region Public Properties [Parameter] public JobTaskModel CurrJob { get; set; } [Parameter] public List CurrRecords { get; set; } = null!; [Parameter] public string CurrSearch { get; set; } = string.Empty; [Parameter] public EventCallback EC_Selected { get; set; } [Parameter] public EventCallback EC_Updated { get; set; } [Parameter] public List ListAllTags { get; set; } = new List(); [Parameter] public List ListPhases { get; set; } [Parameter] public List ListResources { get; set; } #endregion Public Properties #region Protected Fields protected List FiltRecords = new List(); protected List ListRecords = new List(); #endregion Protected Fields #region Protected Properties [Inject] protected DataLayerServices DLService { get; set; } = null!; [Inject] protected IJSRuntime JSRuntime { get; set; } = null!; /// /// Elenco ordinato fasi /// protected List ListPhasesOrd { get => ListPhases.OrderBy(x => x.CodPhase).ThenBy(x => x.Name).ToList(); } /// /// Elenco ordinato risorse /// protected List ListResourcesOrd { get => ListResources.OrderBy(x => x.CodResource).ThenBy(x => x.Name).ToList(); } protected int PhaseId { get => newRecord != null ? newRecord.PhaseID : 0; set { if (newRecord != null && newRecord.PhaseID != value) { newRecord.PhaseID = value; } } } protected decimal ProductivityRateProxy { get => editRecord != null ? Math.Round(editRecord.ProductivityRate, 3) : 0; set { if (editRecord != null) { editRecord.ProductivityRate = Math.Round(value, 3); } } } protected int ResourceId { get => newRecord != null ? newRecord.ResourceID : 0; set { if (newRecord != null && newRecord.ResourceID != value) { newRecord.ResourceID = value; } } } #endregion Protected Properties #region Protected Methods /// /// Genera nuovo record e lo salva /// protected async Task DoAdd() { if (newRecord != null) { // verifico non sia duplicato... var recExist = CurrRecords.Count(x => x.Description == newRecord.Description); if (recExist > 0) { errorMsg = $"Errore: record già esistente | {newRecord.Description}"; } else { errorMsg = ""; // faccio upsert record... await DLService.JobStepUpsertAsync(newRecord); // segnalo update x reload await EC_Updated.InvokeAsync(true); newRecord = null; addVisible = false; #if false // rileggo ReloadData(); #endif } } } /// /// Annullamento salvataggio /// protected async void DoCancel() { editRecord = null; selRecord = null; await EC_Updated.InvokeAsync(true); } /// /// Eliminazione record /// /// protected async Task DoDelete(JobStepModel rec2del) { if (!await JSRuntime.InvokeAsync("confirm", $"Sicuro di voler eliminare il record? {rec2del.Description} ({rec2del.JobStepID})")) return; // esegue eliminazione del record... await DLService.JobStepDeleteAsync(rec2del); // segnalo update x reload await EC_Updated.InvokeAsync(true); #if false // rileggo ReloadData(); #endif } /// /// Edit articolo selezionato /// /// protected async void DoEdit(JobStepModel curRec) { editRecord = curRec; selRecord = curRec; #if false await EC_Selected.InvokeAsync(curRec); #endif await Task.Delay(1); } /// /// Reset selezione /// protected async void DoReset() { editRecord = null; selRecord = null; await EC_Selected.InvokeAsync(selRecord); } /// /// Effettua salvataggio record /// /// protected async Task DoSave() { if (editRecord != null) { errorMsg = ""; // faccio upsert record... await DLService.JobStepUpsertAsync(editRecord); // segnalo update x reload await EC_Updated.InvokeAsync(true); editRecord = null; addVisible = false; } } /// /// Selezione articolo x display info /// /// protected async void DoSelect(JobStepModel curRec) { selRecord = curRec; await EC_Selected.InvokeAsync(curRec); } protected override void OnParametersSet() { ReloadData(); } protected void ToggleAdd() { addVisible = !addVisible; if (addVisible) { newRecord = new JobStepModel() { JobID = CurrJob.JobID, Index = totalCount + 1, Description = $"Fase {totalCount + 1}", PhaseID = 0, ResourceID = 0 }; } } #endregion Protected Methods #region Private Fields private bool addVisible = false; private int currPage = 1; private JobStepModel? editRecord = null; private string errorMsg = ""; private JobStepModel? newRecord = null; private int numRecord = 10; private JobStepModel? selRecord = null; private int totalCount = 0; #endregion Private Fields #region Private Methods /// /// Check selezione riga item /// /// /// private string checkSel(JobStepModel curRec) { string answ = ""; if (selRecord != null) { answ = curRec.JobStepID == selRecord.JobStepID ? "table-info" : ""; } return answ; } private void ReloadData() { if (CurrRecords != null) { // se ho ricerca testuale faccio filtro ulteriore... if (!string.IsNullOrEmpty(CurrSearch)) { FiltRecords = CurrRecords .Where(x => x.Description.Contains(CurrSearch, StringComparison.InvariantCultureIgnoreCase)) .ToList(); } else { FiltRecords = CurrRecords; } totalCount = FiltRecords.Count; // fix paginazione ListRecords = CurrRecords .OrderBy(x => x.Index) .Skip(numRecord * (currPage - 1)) .Take(numRecord) .ToList(); } } #endregion Private Methods } }