123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157 |
- using com.sun.org.glassfish.external.statistics;
- using Comal.Classes;
- using InABox.Configuration;
- using InABox.Core;
- using InABox.Database.Stores;
- using InABox.Scripting;
- using PRSStores;
- using System;
- namespace Comal.Stores;
- internal class BillStore : BaseStore<Bill>
- {
- protected override void BeforeSave(Bill entity)
- {
- base.BeforeSave(entity);
- if(entity.HasOriginalValue(x => x.Number) || entity.SupplierLink.HasOriginalValue(x => x.ID))
- {
- var existing = Provider.Query<Bill>(
- new Filter<Bill>(x => x.Number).IsEqualTo(entity.Number)
- .And(x => x.SupplierLink.ID).IsEqualTo(entity.SupplierLink.ID)
- .And(x => x.ID).IsNotEqualTo(entity.ID),
- Columns.None<Bill>().Add(x => x.ID));
- if(existing.Rows.Count > 0)
- {
- throw new DuplicateCodeException(typeof(Bill), new Dictionary<string, object> {{ nameof(Bill.Number), entity.Number }});
- }
- }
- if (entity.ID == Guid.Empty)
- {
- var defaultApprovalSet = Provider.Query<BillApprovalSet>(
- new Filter<BillApprovalSet>(x => x.IsDefault).IsEqualTo(true),
- Columns.None<BillApprovalSet>().Add(x => x.ID))
- .ToObjects<BillApprovalSet>().FirstOrDefault();
- if (defaultApprovalSet is not null)
- {
- entity.ApprovalSet.ID = defaultApprovalSet.ID;
- }
- }
- //UpdateAggregate<Supplier>(entity, entity.SupplierLink, Sum<Supplier>(b => b.Balance, s => s.Balance));
- }
- private void ClearBillApprovals(Bill bill)
- {
- // We need to clear all automatic bill approvals.
- var approvals = Provider.Query(
- new Filter<BillApproval>(x => x.Bill.ID).IsEqualTo(bill.ID)
- .And(x => x.IsCustom).IsEqualTo(false),
- Columns.Required<BillApproval>().Add(x => x.ID))
- .ToList<BillApproval>();
- Provider.Delete(approvals, UserID);
- }
- private void UpdateBillApprovals(Bill bill)
- {
- if (bill.ID == Guid.Empty) return;
- if(bill.ApprovalSet.ID == Guid.Empty)
- {
- ClearBillApprovals(bill);
- return;
- }
- var setEmployees = Provider.Query(
- new Filter<BillApprovalSetEmployee>(x => x.ApprovalSet.ID).IsEqualTo(bill.ApprovalSet.ID),
- Columns.None<BillApprovalSetEmployee>().Add(x => x.Employee.ID),
- new SortOrder<BillApprovalSetEmployee>(x => x.Sequence))
- .ToArray<BillApprovalSetEmployee>();
- var approvals = Provider.Query(
- new Filter<BillApproval>(x => x.Bill.ID).IsEqualTo(bill.ID),
- Columns.Required<BillApproval>().Add(x => x.Employee.ID).Add(x => x.IsCustom).Add(x => x.Approved))
- .ToList<BillApproval>();
- try
- {
- var customApprovals = new List<BillApproval>();
- foreach(var approval in approvals)
- {
- if (approval.IsCustom)
- {
- customApprovals.Add(approval);
- }
- else
- {
- if(approval.Approved != DateTime.MinValue)
- {
- // These really are custom approvals for our purposes, since they've been modified.
- customApprovals.Add(approval);
- }
- }
- }
- // Build up the automatic list.
- var autoApprovals = new List<BillApproval>();
- foreach(var employee in setEmployees)
- {
- var approval = new BillApproval();
- approval.Employee.CopyFrom(employee.Employee);
- approval.IsCustom = false;
- autoApprovals.Add(approval);
- }
- if(BillApprovalSetStore.GetUpdateApprovalsScript(bill.ApprovalSet.ID) is ScriptDocument script)
- {
- script.Execute(methodname: BillApprovalSet.UpdateBillApprovalsMethodName, parameters: [bill, autoApprovals]);
- }
- // Now, we have to merge the custom and auto lists, only saving auto approvals if there are no custom ones for that employee.
- var toAdd = new List<BillApproval>();
- var toRemove = new List<BillApproval>();
- var newList = customApprovals.ToList();
- foreach(var approval in autoApprovals)
- {
- newList.Add(approval);
- if (!approvals.Any(x => x.Employee.ID == approval.Employee.ID))
- {
- toAdd.Add(approval);
- }
- }
- foreach(var approval in approvals)
- {
- if (!newList.Any(x => x.Employee.ID == approval.Employee.ID))
- {
- toRemove.Add(approval);
- }
- }
- foreach(var approval in toAdd)
- {
- approval.Bill.ID = bill.ID;
- }
- Provider.Save(toAdd);
- Provider.Delete(toRemove, UserID);
- }
- catch(Exception e)
- {
- CoreUtils.LogException(UserID, e, "Error running bill approval script");
- }
- }
- protected override void AfterSave(Bill entity)
- {
- base.AfterSave(entity);
- UpdateBillApprovals(entity);
- }
- protected override void BeforeDelete(Bill entity)
- {
- base.BeforeDelete(entity);
- entity.SupplierLink.ID = Guid.Empty;
- //UpdateAggregate<Supplier>(entity, entity.SupplierLink, Sum<Supplier>(b => b.Balance, s => s.Balance));
- }
- }
|