Exemple #1
0
        public ActionResult _FilterPost(PurchaseOrderCancelFilterViewModel vm)
        {
            List <PurchaseOrderCancelLineViewModel> temp = _PurchaseOrderCancelLineService.GetPurchaseOrderLineForMultiSelect(vm).ToList();
            PurchaseOrderCancelMasterDetailModel    svm  = new PurchaseOrderCancelMasterDetailModel();

            svm.PurchaseOrderCancelViewModels = temp;
            return(PartialView("_Results", svm));
        }
Exemple #2
0
        public ActionResult _ResultsPost(PurchaseOrderCancelMasterDetailModel vm)
        {
            int Serial = _PurchaseOrderCancelLineService.GetMaxSr(vm.PurchaseOrderCancelViewModels.FirstOrDefault().PurchaseOrderCancelHeaderId);
            Dictionary <int, decimal> LineStatus = new Dictionary <int, decimal>();
            var Header = new PurchaseOrderCancelHeaderService(_unitOfWork).Find(vm.PurchaseOrderCancelViewModels.FirstOrDefault().PurchaseOrderCancelHeaderId);

            bool BeforeSave = true;

            try
            {
                BeforeSave = PurchaseOrderCancelDocEvents.beforeLineSaveBulkEvent(this, new PurchaseEventArgs(vm.PurchaseOrderCancelViewModels.FirstOrDefault().PurchaseOrderCancelHeaderId), ref db);
            }
            catch (Exception ex)
            {
                string message = _exception.HandleException(ex);
                TempData["CSEXCL"] += message;
                EventException      = true;
            }

            if (!BeforeSave)
            {
                ModelState.AddModelError("", "Validation failed before save");
            }


            if (ModelState.IsValid && BeforeSave && !EventException)
            {
                foreach (var item in vm.PurchaseOrderCancelViewModels)
                {
                    decimal balqty = (from p in db.ViewPurchaseOrderBalance
                                      where p.PurchaseOrderLineId == item.PurchaseOrderLineId
                                      select p.BalanceQty).FirstOrDefault();

                    if (item.Qty > 0 && item.Qty <= balqty)
                    {
                        PurchaseOrderCancelLine line = new PurchaseOrderCancelLine();

                        line.PurchaseOrderCancelHeaderId = item.PurchaseOrderCancelHeaderId;
                        line.PurchaseOrderLineId         = item.PurchaseOrderLineId;
                        line.Qty          = item.Qty;
                        line.Sr           = Serial++;
                        line.CreatedDate  = DateTime.Now;
                        line.ModifiedDate = DateTime.Now;
                        line.CreatedBy    = User.Identity.Name;
                        line.ModifiedBy   = User.Identity.Name;
                        line.Remark       = item.Remark;

                        LineStatus.Add(line.PurchaseOrderLineId, line.Qty);

                        line.ObjectState = Model.ObjectState.Added;
                        db.PurchaseOrderCancelLine.Add(line);

                        //_PurchaseOrderCancelLineService.Create(line);
                    }
                }
                new PurchaseOrderLineStatusService(_unitOfWork).UpdatePurchaseQtyCancelMultiple(LineStatus, Header.DocDate, ref db);


                if (Header.Status != (int)StatusConstants.Drafted && Header.Status != (int)StatusConstants.Import)
                {
                    Header.Status       = (int)StatusConstants.Modified;
                    Header.ModifiedBy   = User.Identity.Name;
                    Header.ModifiedDate = DateTime.Now;

                    Header.ObjectState = Model.ObjectState.Modified;
                    db.PurchaseOrderCancelHeader.Add(Header);
                }

                try
                {
                    PurchaseOrderCancelDocEvents.onLineSaveBulkEvent(this, new PurchaseEventArgs(vm.PurchaseOrderCancelViewModels.FirstOrDefault().PurchaseOrderCancelHeaderId), ref db);
                }
                catch (Exception ex)
                {
                    string message = _exception.HandleException(ex);
                    TempData["CSEXCL"] += message;
                    EventException      = true;
                }

                try
                {
                    if (EventException)
                    {
                        throw new Exception();
                    }

                    db.SaveChanges();
                    //_unitOfWork.Save();
                }

                catch (Exception ex)
                {
                    string message = _exception.HandleException(ex);
                    TempData["CSEXCL"] += message;
                    return(PartialView("_Results", vm));
                }

                try
                {
                    PurchaseOrderCancelDocEvents.afterLineSaveBulkEvent(this, new PurchaseEventArgs(vm.PurchaseOrderCancelViewModels.FirstOrDefault().PurchaseOrderCancelHeaderId), ref db);
                }
                catch (Exception ex)
                {
                    string message = _exception.HandleException(ex);
                    TempData["CSEXC"] += message;
                }

                LogActivity.LogActivityDetail(LogVm.Map(new ActiivtyLogViewModel
                {
                    DocTypeId    = Header.DocTypeId,
                    DocId        = Header.PurchaseOrderCancelHeaderId,
                    ActivityType = (int)ActivityTypeContants.MultipleCreate,
                    DocNo        = Header.DocNo,
                    DocDate      = Header.DocDate,
                    DocStatus    = Header.Status,
                }));

                return(Json(new { success = true }));
            }
            return(PartialView("_Results", vm));
        }