public void Execute(DataTable dataTableForWorkOrderDetails, AddWorkOrderCM model) { using (var sqlCommand = CreateCommand()) { sqlCommand.Connection = Connection; sqlCommand.CommandText = "[dbo].[uspAddWorkOrderMaster]"; sqlCommand.CommandType = CommandType.StoredProcedure; sqlCommand.Parameters.Add(AddParameter("@WorkOrderMaster", SsDbType.Structured, ParameterDirection.Input, dataTableForWorkOrderDetails)); sqlCommand.ExecuteNonQuery(); } }
public AddWorkOrderQM AddWorkOrder(AddWorkOrderCM addWorkOrderCM) { using (var connection = new DbConnectionProvider().CreateConnection()) { connection.Open(); var command = new WorkOrderMasterInsertCommand { Connection = connection }; command.Execute(addWorkOrderCM.WorkOrderMasterListItems.ToDataTableWithNull(), addWorkOrderCM); } return(new AddWorkOrderQM()); }
public WorkOrderResponseDto AddWorkOrder(WorkOrderRequestDto workOrderRequestDto) { var getWorkOrderClientSerialNoQM = new GetWorkOrderClientSerialNoQM(); string ClientSerialStartName = System.Configuration.ConfigurationManager.AppSettings["ClientStartName"].ToString(); string CurrentMonth = Constant.GetMonthByAlphabet(System.DateTime.UtcNow.Month); string CurrentYear = Constant.GetYearByAlphabet(System.DateTime.UtcNow.Year); var clientSerialDigit = ClientSerialStartName + CurrentYear + CurrentMonth; getWorkOrderClientSerialNoQM = workOrderRepository.GetWorkOrderClientSerialNo(clientSerialDigit); string clientSerialNo = ""; string clientSerialNumber = ""; var existingclientSerialDigit = ""; if (!string.IsNullOrEmpty(getWorkOrderClientSerialNoQM.WorkOrderClientSerialNo)) { clientSerialNumber = getWorkOrderClientSerialNoQM.WorkOrderClientSerialNo.ToString(); existingclientSerialDigit = getWorkOrderClientSerialNoQM.WorkOrderClientChar; } #region Section For to save the work order master common details workOrderRepository.AddWorkOrderMasterCommon(workOrderRequestDto.WorkOrderType, workOrderRequestDto.WorkOrderNumber, workOrderRequestDto.WorkOrderDate, workOrderRequestDto.VendorCode); #endregion #region Section For to save the work order masters information & work order details foreach (var workOrderMaster in workOrderRequestDto.WorkOrderMasterDetails) { var workOrderMasterItems = new List <WorkOrderMasterItems>(); var cModel = new AddWorkOrderCM(); var workOrderMasterDetails = new WorkOrderMasterItems { WorkOrderNumber = workOrderMaster.WorkOrderNumber, WorkOrderSerial = workOrderMaster.WorkOrderSerial, DCNumber = workOrderMaster.DCNumber, DCDate = workOrderMaster.DCDate, DCSerial = workOrderMaster.DCSerial, PONumber = workOrderMaster.PONumber, PODate = workOrderMaster.PODate, POSerial = workOrderMaster.POSerial, DrawingNo = workOrderMaster.DrawingNo, DrawingRev = workOrderMaster.DrawingRev, PartCode = workOrderMaster.PartCode, WOQuantity = workOrderMaster.WOQuantity, Rate = workOrderMaster.Rate, DeliveryDate = workOrderMaster.DeliveryDate, DCQuantity = 0, RejectedQuantity = 0, InvoicedQuantity = 0, SCSentQuantity = 0, SCReceivedQuantity = 0, CreatedBy = workOrderMaster.CreatedBy, CreatedDateTime = workOrderMaster.CreatedDateTime, VendorCode = workOrderMaster.VendorCode, MaterialCode = workOrderMaster.MaterialCode, ItemCode = workOrderMaster.ItemCode, HeatNo = workOrderMaster.HeatNo }; workOrderMasterItems.Add(workOrderMasterDetails); cModel.WorkOrderMasterListItems = workOrderMasterItems; // Section to add the work order master information var response = workOrderRepository.AddWorkOrder(cModel); // Section to add the work order details information var quantity = cModel.WorkOrderMasterListItems.FirstOrDefault().WOQuantity; var heatNo = cModel.WorkOrderMasterListItems.FirstOrDefault().HeatNo; var woSerialNo = cModel.WorkOrderMasterListItems.FirstOrDefault().WorkOrderSerial; var workOrderNumber = cModel.WorkOrderMasterListItems.FirstOrDefault().WorkOrderNumber; if (!string.IsNullOrEmpty(clientSerialNumber)) { //var existingclientSerialDigit = clientSerialNo.ToString().Substring(0, 3); if (!clientSerialDigit.Equals(existingclientSerialDigit)) { string serialNoStarting = "0"; clientSerialNo = clientSerialDigit + serialNoStarting; } else { clientSerialNo = existingclientSerialDigit + clientSerialNumber; } } else { string serialNoStarting = "0"; clientSerialNo = clientSerialDigit + serialNoStarting; } for (int i = 0; i < quantity; i++) { var splitSerialChar = clientSerialNo.ToString().Substring(0, 3); var splitSerialNo = clientSerialNo.ToString().Substring(3); clientSerialNo = splitSerialChar + ((Convert.ToInt64(splitSerialNo) + 1)); clientSerialNumber = ((Convert.ToInt64(splitSerialNo) + 1)).ToString(); existingclientSerialDigit = splitSerialChar; WorkOrderDetailsCM workOrderDetailsCM = new WorkOrderDetailsCM() { WorkOrderNumber = workOrderNumber, WorkOrderSerial = woSerialNo, SerialNo = clientSerialNo, HeatNo = heatNo, Invoice = false, JTC = false, SubContract = false, DC = false, CreatedDateTime = System.DateTime.UtcNow }; workOrderRepository.AddWorkOrderDetails(workOrderDetailsCM); } } #endregion return(new WorkOrderResponseDto()); }