public ActionResult DeletePost(RequisitionCancelLineViewModel vm)
        {
            bool BeforeSave = true;

            try
            {
                BeforeSave = MaterialRequestCancelDocEvents.beforeLineDeleteEvent(this, new StockEventArgs(vm.RequisitionCancelHeaderId, vm.RequisitionCancelLineId), ref db);
            }
            catch (Exception ex)
            {
                string message = _exception.HandleException(ex);
                TempData["CSEXC"] += message;
                EventException     = true;
            }

            if (!BeforeSave)
            {
                TempData["CSEXC"] += "Validation failed before delete.";
            }


            if (BeforeSave && !EventException)
            {
                List <LogTypeViewModel> LogList = new List <LogTypeViewModel>();


                RequisitionCancelLine RequisitionLine = (from p in db.RequisitionCancelLine
                                                         where p.RequisitionCancelLineId == vm.RequisitionCancelLineId
                                                         select p).FirstOrDefault();

                //RequisitionCancelLine RequisitionLine = _RequisitionCancelLineService.Find(vm.RequisitionCancelLineId);
                RequisitionCancelHeader header = new RequisitionCancelHeaderService(_unitOfWork).Find(RequisitionLine.RequisitionCancelHeaderId);

                RequisitionCancelLine ExRec = new RequisitionCancelLine();
                ExRec = Mapper.Map <RequisitionCancelLine>(RequisitionLine);

                LogList.Add(new LogTypeViewModel
                {
                    ExObj = ExRec,
                });

                new RequisitionLineStatusService(_unitOfWork).UpdateRequisitionQtyOnCancel(RequisitionLine.RequisitionLineId, RequisitionLine.RequisitionCancelLineId, header.DocDate, 0, ref db, true);

                RequisitionLine.ObjectState = Model.ObjectState.Deleted;
                db.RequisitionCancelLine.Remove(RequisitionLine);

                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.RequisitionCancelHeader.Add(header);
                }

                XElement Modifications = new ModificationsCheckService().CheckChanges(LogList);


                try
                {
                    MaterialRequestCancelDocEvents.onLineDeleteEvent(this, new StockEventArgs(RequisitionLine.RequisitionCancelHeaderId, RequisitionLine.RequisitionCancelLineId), ref db);
                }
                catch (Exception ex)
                {
                    string message = _exception.HandleException(ex);
                    TempData["CSEXCL"] += message;
                    EventException      = true;
                }


                try
                {
                    if (EventException)
                    {
                        throw new Exception();
                    }
                    db.SaveChanges();
                }

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

                try
                {
                    MaterialRequestCancelDocEvents.afterLineDeleteEvent(this, new StockEventArgs(RequisitionLine.RequisitionCancelHeaderId, RequisitionLine.RequisitionCancelLineId), ref db);
                }
                catch (Exception ex)
                {
                    string message = _exception.HandleException(ex);
                    TempData["CSEXC"] += message;
                }


                LogActivity.LogActivityDetail(LogVm.Map(new ActiivtyLogViewModel
                {
                    DocTypeId       = header.DocTypeId,
                    DocId           = header.RequisitionCancelHeaderId,
                    DocLineId       = RequisitionLine.RequisitionCancelLineId,
                    ActivityType    = (int)ActivityTypeContants.Deleted,
                    DocNo           = header.DocNo,
                    xEModifications = Modifications,
                    DocDate         = header.DocDate,
                    DocStatus       = header.Status,
                }));
            }

            return(Json(new { success = true }));
        }
        public ActionResult _ResultsPost(RequisitionCancelListModel vm)
        {
            Dictionary <int, decimal> LineStatus = new Dictionary <int, decimal>();

            var Header = new RequisitionCancelHeaderService(_unitOfWork).Find(vm.RequisitionCancelViewModels.FirstOrDefault().RequisitionCancelHeaderId);

            bool BeforeSave = true;

            try
            {
                BeforeSave = MaterialRequestCancelDocEvents.beforeLineSaveBulkEvent(this, new StockEventArgs(vm.RequisitionCancelViewModels.FirstOrDefault().RequisitionCancelHeaderId), ref db);
            }
            catch (Exception ex)
            {
                string message = _exception.HandleException(ex);
                TempData["CSEXC"] += message;
                EventException     = true;
            }

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

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

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

                        line.RequisitionCancelHeaderId = item.RequisitionCancelHeaderId;
                        line.RequisitionLineId         = item.RequisitionLineId;
                        line.Qty          = item.Qty;
                        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.RequisitionLineId, line.Qty);

                        //_RequisitionCancelLineService.Create(line);

                        line.ObjectState = Model.ObjectState.Added;
                        db.RequisitionCancelLine.Add(line);
                    }
                }

                new RequisitionLineStatusService(_unitOfWork).UpdateRequisitionQtyCancelMultiple(LineStatus, Header.DocDate, ref db);

                try
                {
                    MaterialRequestCancelDocEvents.onLineSaveBulkEvent(this, new StockEventArgs(vm.RequisitionCancelViewModels.FirstOrDefault().RequisitionCancelHeaderId), ref db);
                }
                catch (Exception ex)
                {
                    string message = _exception.HandleException(ex);
                    TempData["CSEXCL"] += message;
                    EventException      = true;
                }

                try
                {
                    if (EventException)
                    {
                        throw new Exception();
                    }
                    db.SaveChanges();
                }

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

                try
                {
                    MaterialRequestCancelDocEvents.afterLineSaveBulkEvent(this, new StockEventArgs(vm.RequisitionCancelViewModels.FirstOrDefault().RequisitionCancelHeaderId), ref db);
                }
                catch (Exception ex)
                {
                    string message = _exception.HandleException(ex);
                    TempData["CSEXC"] += message;
                }

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

                return(Json(new { success = true }));
            }
            return(PartialView("_Results", vm));
        }
示例#3
0
        public ActionResult DeleteConfirmed(ReasonViewModel vm)
        {
            bool BeforeSave = true;

            try
            {
                BeforeSave = MaterialRequestCancelDocEvents.beforeHeaderDeleteEvent(this, new StockEventArgs(vm.id), ref db);
            }
            catch (Exception ex)
            {
                string message = _exception.HandleException(ex);
                TempData["CSEXC"] += message;
                EventException     = true;
            }

            if (!BeforeSave)
            {
                TempData["CSEXC"] += "Failed validation before delete";
            }

            if (ModelState.IsValid && BeforeSave && !EventException)
            {
                List <LogTypeViewModel> LogList = new List <LogTypeViewModel>();

                //var temp = _RequisitionCancelHeaderService.Find(vm.id);

                var temp = (from p in db.RequisitionCancelHeader
                            where p.RequisitionCancelHeaderId == vm.id
                            select p).FirstOrDefault();

                try
                {
                    MaterialRequestCancelDocEvents.onHeaderDeleteEvent(this, new StockEventArgs(vm.id), ref db);
                }
                catch (Exception ex)
                {
                    string message = _exception.HandleException(ex);
                    TempData["CSEXC"] += message;
                    EventException     = true;
                }


                RequisitionCancelHeader ExRec = new RequisitionCancelHeader();
                ExRec = Mapper.Map <RequisitionCancelHeader>(temp);

                LogList.Add(new LogTypeViewModel
                {
                    ExObj = ExRec,
                });

                //var lines = new RequisitionCancelLineService(_unitOfWork).GetRequisitionCancelLineForHeader(vm.id);
                var lines = (from p in db.RequisitionCancelLine
                             where p.RequisitionCancelHeaderId == vm.id
                             select p).ToList();

                new RequisitionLineStatusService(_unitOfWork).DeleteRequisitionQtyOnCancelMultiple(vm.id, ref db);

                foreach (var item in lines)
                {
                    RequisitionCancelLine ExRecLine = new RequisitionCancelLine();
                    ExRecLine = Mapper.Map <RequisitionCancelLine>(item);

                    LogList.Add(new LogTypeViewModel
                    {
                        ExObj = ExRecLine,
                    });

                    item.ObjectState = Model.ObjectState.Deleted;
                    db.RequisitionCancelLine.Remove(item);

                    //new RequisitionCancelLineService(_unitOfWork).Delete(item.RequisitionCancelLineId);
                }


                //_RequisitionCancelHeaderService.Delete(vm.id);

                temp.ObjectState = Model.ObjectState.Deleted;
                db.RequisitionCancelHeader.Remove(temp);

                XElement Modifications = new ModificationsCheckService().CheckChanges(LogList);

                try
                {
                    if (EventException)
                    {
                        throw new Exception();
                    }
                    db.SaveChanges();
                }

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

                try
                {
                    MaterialRequestCancelDocEvents.afterHeaderDeleteEvent(this, new StockEventArgs(vm.id), ref db);
                }
                catch (Exception ex)
                {
                    string message = _exception.HandleException(ex);
                    TempData["CSEXC"] += message;
                }

                LogActivity.LogActivityDetail(LogVm.Map(new ActiivtyLogViewModel
                {
                    DocTypeId       = temp.DocTypeId,
                    DocId           = temp.RequisitionCancelHeaderId,
                    ActivityType    = (int)ActivityTypeContants.Deleted,
                    UserRemark      = vm.Reason,
                    DocNo           = temp.DocNo,
                    xEModifications = Modifications,
                    DocDate         = temp.DocDate,
                    DocStatus       = temp.Status,
                }));

                return(Json(new { success = true }));
            }
            return(PartialView("_Reason", vm));
        }
        public ActionResult _CreatePost(RequisitionCancelLineViewModel svm)
        {
            bool BeforeSave = true;

            try
            {
                if (svm.RequisitionLineId <= 0)
                {
                    BeforeSave = MaterialRequestCancelDocEvents.beforeLineSaveEvent(this, new StockEventArgs(svm.RequisitionCancelHeaderId, EventModeConstants.Add), ref db);
                }
                else
                {
                    BeforeSave = MaterialRequestCancelDocEvents.beforeLineSaveEvent(this, new StockEventArgs(svm.RequisitionCancelHeaderId, EventModeConstants.Edit), ref db);
                }
            }
            catch (Exception ex)
            {
                string message = _exception.HandleException(ex);
                TempData["CSEXCL"] += message;
                EventException      = true;
            }

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


            if (svm.RequisitionCancelLineId <= 0)
            {
                ViewBag.LineMode = "Create";
            }
            else
            {
                ViewBag.LineMode = "Edit";
            }

            if (svm.RequisitionCancelLineId <= 0)
            {
                RequisitionCancelHeader temp = new RequisitionCancelHeaderService(_unitOfWork).Find(svm.RequisitionCancelHeaderId);

                RequisitionCancelLine s = new RequisitionCancelLine();
                decimal balqty          = (from p in db.ViewRequisitionBalance
                                           where p.RequisitionLineId == svm.RequisitionLineId
                                           select p.BalanceQty).FirstOrDefault();
                if (balqty < svm.Qty)
                {
                    ModelState.AddModelError("Qty", "Qty Exceeding Balance Qty");
                }
                if (svm.Qty == 0)
                {
                    ModelState.AddModelError("Qty", "Please Check Qty");
                }
                if (ModelState.IsValid && BeforeSave && !EventException)
                {
                    s.Remark = svm.Remark;
                    s.RequisitionCancelHeaderId = svm.RequisitionCancelHeaderId;
                    s.RequisitionLineId         = svm.RequisitionLineId;
                    s.Qty          = svm.Qty;
                    s.CreatedDate  = DateTime.Now;
                    s.ModifiedDate = DateTime.Now;
                    s.CreatedBy    = User.Identity.Name;
                    s.ModifiedBy   = User.Identity.Name;
                    s.ObjectState  = Model.ObjectState.Added;

                    db.RequisitionCancelLine.Add(s);

                    //_RequisitionCancelLineService.Create(s);

                    new RequisitionLineStatusService(_unitOfWork).UpdateRequisitionQtyOnCancel(s.RequisitionLineId, s.RequisitionCancelLineId, temp.DocDate, s.Qty, ref db, true);

                    if (temp.Status != (int)StatusConstants.Drafted && temp.Status != (int)StatusConstants.Import)
                    {
                        temp.Status       = (int)StatusConstants.Modified;
                        temp.ModifiedBy   = User.Identity.Name;
                        temp.ModifiedDate = DateTime.Now;
                        temp.ObjectState  = Model.ObjectState.Modified;
                        db.RequisitionCancelHeader.Add(temp);
                    }

                    try
                    {
                        MaterialRequestCancelDocEvents.onLineSaveEvent(this, new StockEventArgs(s.RequisitionCancelHeaderId, s.RequisitionLineId, EventModeConstants.Add), ref db);
                    }
                    catch (Exception ex)
                    {
                        string message = _exception.HandleException(ex);
                        TempData["CSEXCL"] += message;
                        EventException      = true;
                    }

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

                        db.SaveChanges();
                    }

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

                    try
                    {
                        MaterialRequestCancelDocEvents.afterLineSaveEvent(this, new StockEventArgs(s.RequisitionCancelHeaderId, s.RequisitionLineId, EventModeConstants.Add), ref db);
                    }
                    catch (Exception ex)
                    {
                        string message = _exception.HandleException(ex);
                        TempData["CSEXCL"] += message;
                    }

                    LogActivity.LogActivityDetail(LogVm.Map(new ActiivtyLogViewModel
                    {
                        DocTypeId    = temp.DocTypeId,
                        DocId        = temp.RequisitionCancelHeaderId,
                        DocLineId    = s.RequisitionCancelLineId,
                        ActivityType = (int)ActivityTypeContants.Added,
                        DocNo        = temp.DocNo,
                        DocDate      = temp.DocDate,
                        DocStatus    = temp.Status,
                    }));

                    return(RedirectToAction("_Create", new { id = s.RequisitionCancelHeaderId, sid = svm.PersonId }));
                }
                return(PartialView("_Create", svm));
            }
            else
            {
                List <LogTypeViewModel> LogList = new List <LogTypeViewModel>();

                RequisitionCancelHeader temp = new RequisitionCancelHeaderService(_unitOfWork).Find(svm.RequisitionCancelHeaderId);
                int           status         = temp.Status;
                StringBuilder logstring      = new StringBuilder();

                RequisitionCancelLine s = _RequisitionCancelLineService.Find(svm.RequisitionCancelLineId);

                RequisitionCancelLine ExRec = new RequisitionCancelLine();
                ExRec = Mapper.Map <RequisitionCancelLine>(s);


                decimal balqty = (from p in db.ViewRequisitionBalance
                                  where p.RequisitionLineId == svm.RequisitionLineId
                                  select p.BalanceQty).FirstOrDefault();
                if (balqty + s.Qty < svm.Qty)
                {
                    ModelState.AddModelError("Qty", "Qty Exceeding Balance Qty");
                }


                if (ModelState.IsValid && BeforeSave)
                {
                    if (svm.Qty > 0)
                    {
                        s.Remark       = svm.Remark;
                        s.Qty          = svm.Qty;
                        s.ModifiedBy   = User.Identity.Name;
                        s.ModifiedDate = DateTime.Now;

                        new RequisitionLineStatusService(_unitOfWork).UpdateRequisitionQtyOnCancel(s.RequisitionLineId, s.RequisitionCancelLineId, temp.DocDate, s.Qty, ref db, true);
                    }

                    //_RequisitionCancelLineService.Update(s);
                    s.ObjectState = Model.ObjectState.Modified;
                    db.RequisitionCancelLine.Add(s);

                    LogList.Add(new LogTypeViewModel
                    {
                        ExObj = ExRec,
                        Obj   = s,
                    });


                    if (temp.Status != (int)StatusConstants.Drafted)
                    {
                        temp.Status      = (int)StatusConstants.Modified;
                        temp.ObjectState = Model.ObjectState.Modified;
                        db.RequisitionCancelHeader.Add(temp);
                        //new RequisitionCancelHeaderService(_unitOfWork).Update(temp);
                    }

                    XElement Modifications = new ModificationsCheckService().CheckChanges(LogList);

                    try
                    {
                        MaterialRequestCancelDocEvents.onLineSaveEvent(this, new StockEventArgs(s.RequisitionCancelHeaderId, s.RequisitionCancelLineId, EventModeConstants.Edit), ref db);
                    }
                    catch (Exception ex)
                    {
                        string message = _exception.HandleException(ex);
                        TempData["CSEXC"] += message;
                        EventException     = true;
                    }

                    try
                    {
                        if (EventException)
                        {
                            throw new Exception();
                        }
                        db.SaveChanges();
                    }

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

                    try
                    {
                        MaterialRequestCancelDocEvents.afterLineSaveEvent(this, new StockEventArgs(s.RequisitionCancelHeaderId, s.RequisitionCancelLineId, EventModeConstants.Edit), ref db);
                    }
                    catch (Exception ex)
                    {
                        string message = _exception.HandleException(ex);
                        TempData["CSEXC"] += message;
                    }

                    //SAving the Activity Log::

                    LogActivity.LogActivityDetail(LogVm.Map(new ActiivtyLogViewModel
                    {
                        DocTypeId       = temp.DocTypeId,
                        DocId           = temp.RequisitionCancelHeaderId,
                        DocLineId       = s.RequisitionCancelLineId,
                        ActivityType    = (int)ActivityTypeContants.Modified,
                        DocNo           = temp.DocNo,
                        xEModifications = Modifications,
                        DocDate         = temp.DocDate,
                        DocStatus       = temp.Status,
                    }));

                    //End Of Saving Activity Log

                    return(Json(new { success = true }));
                }
                return(PartialView("_Create", svm));
            }
        }
示例#5
0
 public void Update(RequisitionCancelLine pt)
 {
     pt.ObjectState = ObjectState.Modified;
     _unitOfWork.Repository <RequisitionCancelLine>().Update(pt);
 }
示例#6
0
 public void Delete(RequisitionCancelLine pt)
 {
     _unitOfWork.Repository <RequisitionCancelLine>().Delete(pt);
 }
示例#7
0
 public RequisitionCancelLine Create(RequisitionCancelLine pt)
 {
     pt.ObjectState = ObjectState.Added;
     _unitOfWork.Repository <RequisitionCancelLine>().Insert(pt);
     return(pt);
 }
示例#8
0
 public RequisitionCancelLine Add(RequisitionCancelLine pt)
 {
     _unitOfWork.Repository <RequisitionCancelLine>().Insert(pt);
     return(pt);
 }
示例#9
0
        public bool CancelPendingWeavingRequisitions(int HeaderId, string UserName, int DocType)
        {
            bool Success = false;
            var  PendingRequisitionLines = (from p in db.ViewRequisitionBalance
                                            where p.RequisitionHeaderId == HeaderId && p.BalanceQty > 0
                                            select new { p.RequisitionLineId, p.BalanceQty, p.PersonId }).ToList();

            int SiteId     = (int)System.Web.HttpContext.Current.Session["SiteId"];
            int DivisionId = (int)System.Web.HttpContext.Current.Session["DivisionId"];

            var ReasonId = (from p in db.RequisitionSetting
                            where p.DocTypeId == DocType && p.DivisionId == DivisionId && p.SiteId == SiteId
                            select p.DefaultReasonId).FirstOrDefault();

            if (!ReasonId.HasValue)
            {
                ReasonId = new ReasonService(_unitOfWork).GetReasonList(TransactionDocCategoryConstants.RequisitionCancel).FirstOrDefault().ReasonId;
            }

            if (PendingRequisitionLines.Count() > 0)
            {
                RequisitionCancelHeader Header = new RequisitionCancelHeader();
                Header.CreatedBy   = UserName;
                Header.CreatedDate = DateTime.Now;
                Header.DivisionId  = DivisionId;
                Header.DocDate     = DateTime.Now;
                Header.DocTypeId   = DocType;
                Header.SiteId      = SiteId;
                Header.DocNo       = new DocumentTypeService(_unitOfWork).FGetNewDocNo("DocNo", ConfigurationManager.AppSettings["DataBaseSchema"] + ".RequisitionCancelHeaders", Header.DocTypeId, Header.DocDate, Header.DivisionId, Header.SiteId);

                Header.ModifiedBy   = UserName;
                Header.ModifiedDate = DateTime.Now;
                Header.PersonId     = PendingRequisitionLines.FirstOrDefault().PersonId;
                Header.ReasonId     = ReasonId.Value;

                Header.ObjectState = Model.ObjectState.Added;
                db.RequisitionCancelHeader.Add(Header);


                foreach (var item in PendingRequisitionLines)
                {
                    RequisitionCancelLine Line = new RequisitionCancelLine();
                    Line.CreatedBy                 = UserName;
                    Line.CreatedDate               = DateTime.Now;
                    Line.ModifiedBy                = UserName;
                    Line.ModifiedDate              = DateTime.Now;
                    Line.Qty                       = item.BalanceQty;
                    Line.RequisitionLineId         = item.RequisitionLineId;
                    Line.RequisitionCancelHeaderId = Header.RequisitionCancelHeaderId;
                    Line.ObjectState               = Model.ObjectState.Added;
                    db.RequisitionCancelLine.Add(Line);

                    RequisitionLineStatus LineStatus = db.RequisitionLineStatus.Find(item.RequisitionLineId);

                    if (LineStatus != null)
                    {
                        LineStatus.CancelQty   = (LineStatus.CancelQty ?? 0) + Line.Qty;
                        LineStatus.ObjectState = Model.ObjectState.Modified;

                        db.RequisitionLineStatus.Add(LineStatus);
                    }
                }

                try
                {
                    db.SaveChanges();
                }
                catch (Exception Ex)
                {
                    Success = false;
                }
                Success = true;
            }
            return(Success);
        }