/// <summary> /// convert part model to part master for update part master /// </summary> /// <param name="model"></param> /// <returns></returns> public IV00101_Part_Master ConvertToUpdateMaster(PartOperationModel model) { IV00101_Part_Master partMaster = new IV00101_Part_Master(); var _partStatusRepository = new PartStatusRepository(); var partStatus = _partStatusRepository.GetPartStatus(model.PartStatusId); var active = (partStatus != null && (!partStatus.Description.ToLower().Replace(" ", string.Empty).Equals("inactive") || !partStatus.Description.ToLower().Replace(" ", string.Empty).Equals("archive") || !partStatus.Description.ToLower().Replace(" ", string.Empty).Equals("purge"))) ? true : false; partMaster.ITEMNMBR = model.PartNumber; partMaster.ITEMDESC = model.PartDescription; partMaster.ITEMSHWT = Convert.ToInt32(model.Weight * 100.00m); partMaster.STNDCOST = model.Cost; partMaster.LOCNCODE = model.SiteId; partMaster.INACTIVE = Convert.ToByte(active); partMaster.ITMCLSCD = "STANDRRD"; if (_partStatusRepository != null) { _partStatusRepository.Dispose(); _partStatusRepository = null; } return(partMaster); }
/// <summary> /// convert part model to domain for update part /// </summary> /// <param name="model"></param> /// <returns></returns> public Part ConvertToUpdatePart(PartOperationModel model) { Part part = new Part(); var _partStatusRepository = new PartStatusRepository(); var partStatus = _partStatusRepository.GetPartStatus(model.PartStatusId); var active = (partStatus != null && (!partStatus.Description.ToLower().Replace(" ", string.Empty).Equals("inactive") || !partStatus.Description.ToLower().Replace(" ", string.Empty).Equals("archive") || !partStatus.Description.ToLower().Replace(" ", string.Empty).Equals("purge"))) ? true : false; part.PartId = model.PartId ?? Guid.Empty; part.Number = model.PartNumber; part.AccountCode = model.AccountCode; part.CustomerId = model.CustomerId; part.CustomerAddressId = model.CustomerAddressId; part.FoundryId = model.FoundryId; part.SubFoundryId = model.SubFoundryId; part.HtsNumberId = model.HtsNumberId; part.MaterialId = model.MaterialId; part.MaterialSpecificationId = model.MaterialSpecificationId; part.PartStatusId = model.PartStatusId; part.PartTypeId = model.PartTypeId; part.ShipmentTermId = model.ShipmentTermId; part.PaymentTermId = model.PaymentTermId; part.SurchargeId = model.SurchargeId; part.SiteId = model.SiteId; part.DestinationId = model.DestinationId; part.CoatingTypeId = model.CoatingTypeId; part.PatternMaterialId = model.PatternMaterialId; part.IsRaw = model.IsRaw; part.IsMachined = model.IsMachined; part.PalletQuantity = model.PalletQuantity; part.AdditionalCost = model.AdditionalCost; part.FixtureDate = model.FixtureDate; part.FixtureCost = model.FixtureCost; part.FixturePrice = model.FixturePrice; part.PatternDate = model.PatternDate; part.PatternCost = model.PatternCost; part.PatternPrice = model.PatternPrice; part.IsFamilyPattern = model.IsFamilyPattern; part.Notes = model.Notes; part.MinimumQuantity = model.MinimumQuantity; part.SafetyQuantity = model.SafetyQuantity; part.OrderCycle = model.OrderCycle; part.LeadTime = model.LeadTime; part.AnnualUsage = model.AnnualUsage; part.FoundryOrderId = model.FoundryOrderId; part.ToolingDescription = model.ToolingDescription; part.IsActive = active; if (_partStatusRepository != null) { _partStatusRepository.Dispose(); _partStatusRepository = null; } return(part); }
/// <summary> /// convert part to quote part view model /// </summary> /// <param name="part"></param> /// <returns></returns> public QuotePartViewModel ConvertToView(Part part) { QuotePartViewModel model = new QuotePartViewModel(); var _partRepository = new PartRepository(); var _dynamicsPartRepository = new PartDynamicsRepository(); var _partStatusRepository = new PartStatusRepository(); var dynamicsPart = _dynamicsPartRepository.GetPartMaster(part.Number); var dynamicsPartCurrency = _dynamicsPartRepository.GetPartCurrency(part.Number); var partStatus = _partStatusRepository.GetPartStatus(part.PartStatusId); var partDrawing = _partRepository.GetPartDrawings(part.PartId).FirstOrDefault(x => x.IsLatest); model.PartId = part.PartId; model.PartNumber = (!string.IsNullOrEmpty(part.Number)) ? part.Number : "N/A"; model.PartDescription = (dynamicsPart != null && !string.IsNullOrEmpty(dynamicsPart.ITEMDESC)) ? dynamicsPart.ITEMDESC : "N/A"; model.CustomerId = part.CustomerId; model.FoundryId = part.FoundryId; model.RevisionNumber = (partDrawing != null && !string.IsNullOrEmpty(partDrawing.RevisionNumber)) ? partDrawing.RevisionNumber : "N/A"; model.Weight = (dynamicsPart != null) ? (dynamicsPart.ITEMSHWT / 100.00m) : 0.00m; model.AnnualUsage = part.AnnualUsage; model.Price = (dynamicsPartCurrency != null) ? (decimal)dynamicsPartCurrency.LISTPRCE : 0.00m; model.PatternPrice = part.PatternPrice; model.FixturePrice = part.FixturePrice; model.Cost = (dynamicsPart != null) ? (decimal)dynamicsPart.STNDCOST : 0.00m; model.PatternCost = part.PatternCost; model.FixtureCost = part.FixtureCost; model.IsRaw = part.IsRaw; model.IsMachined = part.IsMachined; if (_partRepository != null) { _partRepository.Dispose(); _partRepository = null; } if (_dynamicsPartRepository != null) { _dynamicsPartRepository.Dispose(); _dynamicsPartRepository = null; } if (_partStatusRepository != null) { _partStatusRepository.Dispose(); _partStatusRepository = null; } return(model); }
/// <summary> /// convert part to project part list model /// </summary> /// <param name="part"></param> /// <returns></returns> public ProjectPartViewModel ConvertToListView(Part part) { ProjectPartViewModel model = new ProjectPartViewModel(); var _dynamicsPartRepository = new PartDynamicsRepository(); var _customerDynamicsRepository = new CustomerDynamicsRepository(); var _foundryDynamicsRepository = new FoundryDynamicsRepository(); var _htsNumberRepository = new HtsNumberRepository(); var _partTypeRepository = new PartTypeRepository(); var _partStatusRepository = new PartStatusRepository(); var dynamicsPart = _dynamicsPartRepository.GetPartMaster(part.Number); var dynamicsCustomer = _customerDynamicsRepository.GetCustomer(part.CustomerId); var dynamicsFoundry = _foundryDynamicsRepository.GetFoundry(part.FoundryId); var htsNumber = _htsNumberRepository.GetHtsNumber(part.HtsNumberId); var partType = _partTypeRepository.GetPartType(part.PartTypeId); var partStatus = _partStatusRepository.GetPartStatus(part.PartStatusId); model.PartId = part.PartId; model.PartNumber = (!string.IsNullOrEmpty(part.Number)) ? part.Number : "N/A"; model.PartDescription = (dynamicsPart != null && !string.IsNullOrEmpty(dynamicsPart.ITEMDESC)) ? dynamicsPart.ITEMDESC : "N/A"; model.CustomerId = part.CustomerId; model.CustomerName = (dynamicsCustomer != null && !string.IsNullOrEmpty(dynamicsCustomer.SHRTNAME)) ? dynamicsCustomer.SHRTNAME : "N/A"; model.FoundryId = part.FoundryId; model.FoundryName = (dynamicsFoundry != null && !string.IsNullOrEmpty(dynamicsFoundry.VENDSHNM)) ? dynamicsFoundry.VENDSHNM : "N/A"; model.HtsNumberId = part.HtsNumberId; model.HtsNumber = (htsNumber != null && !string.IsNullOrEmpty(htsNumber.Description)) ? htsNumber.Description + "(" + (htsNumber.DutyRate * 100).ToString() + "%)" : "N/A"; model.PartTypeId = part.PartTypeId; model.PartTypeDescription = (partType != null && !string.IsNullOrEmpty(partType.Description)) ? partType.Description : "N/A"; model.PartStatusId = part.PartStatusId; model.PartStatusDescription = (partStatus != null && !string.IsNullOrEmpty(partStatus.Description)) ? partStatus.Description : "N/A"; model.IsProject = false; if (_dynamicsPartRepository != null) { _dynamicsPartRepository.Dispose(); _dynamicsPartRepository = null; } if (_customerDynamicsRepository != null) { _customerDynamicsRepository.Dispose(); _customerDynamicsRepository = null; } if (_foundryDynamicsRepository != null) { _foundryDynamicsRepository.Dispose(); _foundryDynamicsRepository = null; } if (_htsNumberRepository != null) { _htsNumberRepository.Dispose(); _htsNumberRepository = null; } if (_partTypeRepository != null) { _partTypeRepository.Dispose(); _partTypeRepository = null; } if (_partStatusRepository != null) { _partStatusRepository.Dispose(); _partStatusRepository = null; } return(model); }
/// <summary> /// convert project part to part view model /// </summary> /// <param name="projectPart"></param> /// <returns></returns> public PartViewModel ConvertToView(ProjectPart projectPart) { PartViewModel model = new PartViewModel(); var _projectRepository = new ProjectRepository(); var _foundryOrderRepository = new FoundryOrderRepository(); var _partTypeRepository = new PartTypeRepository(); var _partStatusRepository = new PartStatusRepository(); var partType = _partTypeRepository.GetPartType(projectPart.PartTypeId); var statusEntity = _partStatusRepository.GetPartStatus(projectPart.PartStatusId); var foundryOrderPart = _foundryOrderRepository.GetFoundryOrderPartByProjectPart(projectPart.ProjectPartId); if (foundryOrderPart != null) { var toolingOrder = _foundryOrderRepository.GetToolingFoundryOrder(foundryOrderPart.FoundryOrderId); model.FoundryOrderId = (toolingOrder != null) ? foundryOrderPart.FoundryOrderId : Guid.Empty; model.ToolingOrderNumber = (toolingOrder != null && !string.IsNullOrEmpty(toolingOrder.Number)) ? toolingOrder.Number : "N/A"; model.ToolingDescription = projectPart.ToolingDescription; } model.ProjectPartId = projectPart.ProjectPartId; model.PartId = projectPart.PartId; model.PartNumber = (!string.IsNullOrEmpty(projectPart.Number)) ? projectPart.Number : "N/A"; model.PartDescription = (!string.IsNullOrEmpty(projectPart.Description)) ? projectPart.Description : "N/A"; model.AccountCode = (!string.IsNullOrEmpty(projectPart.AccountCode)) ? projectPart.AccountCode : "N/A"; model.RevisionNumber = (!string.IsNullOrEmpty(projectPart.RevisionNumber)) ? projectPart.RevisionNumber : "N/A"; model.CustomerId = projectPart.CustomerId; model.CustomerAddressId = projectPart.CustomerAddressId; model.FoundryId = projectPart.FoundryId; model.SubFoundryId = projectPart.SubFoundryId; model.HtsNumberId = projectPart.HtsNumberId; model.MaterialId = projectPart.MaterialId; model.SpecificationMaterialId = projectPart.MaterialSpecificationId; model.PartStatusId = projectPart.PartStatusId; model.PartStatusDescription = (statusEntity != null && !string.IsNullOrEmpty(statusEntity.Description)) ? statusEntity.Description : "N/A"; model.PartTypeId = projectPart.PartTypeId; model.PartTypeDescription = (partType != null && !string.IsNullOrEmpty(partType.Description)) ? partType.Description : "N/A"; model.ShipmentTermId = projectPart.ShipmentTermId; model.PaymentTermId = projectPart.PaymentTermId; model.SurchargeId = projectPart.SurchargeId; model.SiteId = projectPart.SiteId; model.DestinationId = projectPart.DestinationId; model.CoatingTypeId = projectPart.CoatingTypeId; model.PatternMaterialId = projectPart.PatternMaterialId; model.IsRaw = projectPart.IsRaw; model.IsMachined = projectPart.IsMachined; model.PalletQuantity = (projectPart.PalletQuantity != 0) ? projectPart.PalletQuantity : 0; model.PalletWeight = (projectPart.PalletQuantity != 0) ? projectPart.PalletQuantity * projectPart.Weight : 0.00m; model.Weight = (projectPart.Weight != 0.00m) ? projectPart.Weight : 0.00m; model.Cost = (projectPart.Cost != 0.00m) ? projectPart.Cost : 0.00m; model.Price = (projectPart.Price != 0.00m) ? projectPart.Price : 0.00m; model.AdditionalCost = (projectPart.AdditionalCost != 0.00m) ? projectPart.AdditionalCost : 0.00m; model.YearlySalesTotal = 0.00m; model.SixtyDaysSalesTotal = 0.00m; model.MonthlySalesTotal = 0.00m; model.AverageDailySales = 0.00m; model.QuantityOnHand = 0; model.FixtureDate = (projectPart.FixtureDate != null) ? projectPart.FixtureDate : DateTime.MinValue; model.FixtureCost = (projectPart.FixtureCost != 0.00m) ? projectPart.FixtureCost : 0.00m; model.FixturePrice = (projectPart.FixturePrice != 0.00m) ? projectPart.FixturePrice : 0.00m; model.PatternDate = projectPart.PatternDate; model.PatternCost = (projectPart.PatternCost != 0.00m) ? projectPart.PatternCost : 0.00m; model.PatternPrice = (projectPart.PatternPrice != 0.00m) ? projectPart.PatternPrice : 0.00m; model.IsFamilyPattern = projectPart.IsFamilyPattern; model.Notes = (projectPart.Notes != null) ? projectPart.Notes : "N/A"; model.AnnualUsage = (projectPart.PatternPrice != 0) ? projectPart.AnnualUsage : 0; model.IsActive = true; model.IsProjectPart = true; if (projectPart.ProjectPartDrawings != null && projectPart.ProjectPartDrawings.Count > 0) { var drawings = new List <DrawingViewModel>(); foreach (var partDrawing in projectPart.ProjectPartDrawings) { DrawingViewModel convertedModel = new ProjectPartDrawingConverter().ConvertToView(partDrawing); drawings.Add(convertedModel); } model.Drawings = drawings; } if (projectPart.ProjectPartLayouts != null && projectPart.ProjectPartLayouts.Count > 0) { var layouts = new List <LayoutViewModel>(); foreach (var partLayout in projectPart.ProjectPartLayouts) { LayoutViewModel convertedModel = new ProjectPartLayoutConverter().ConvertToView(partLayout); layouts.Add(convertedModel); } model.Layouts = layouts; } if (_projectRepository != null) { _projectRepository.Dispose(); _projectRepository = null; } if (_foundryOrderRepository != null) { _foundryOrderRepository.Dispose(); _foundryOrderRepository = null; } if (_partTypeRepository != null) { _partTypeRepository.Dispose(); _partTypeRepository = null; } if (_partStatusRepository != null) { _partStatusRepository.Dispose(); _partStatusRepository = null; } return(model); }