예제 #1
0
        public JsonResult CreditServices_Insert(AddCreditServiceRequest request)
        {
            GeneralResponse response = new GeneralResponse();

            #region Access Check
            bool hasPermission = GetEmployee().IsGuaranteed("CreditService_Insert");
            if (!hasPermission)
            {
                response.ErrorMessages.Add("AccessDenied");
                return(Json(response, JsonRequestBehavior.AllowGet));
            }
            #endregion

            response = _creditServiceService.AddCreditServices(request, GetEmployee().ID);

            return(Json(response, JsonRequestBehavior.AllowGet));
        }
예제 #2
0
        public GeneralResponse AddCreditServices(AddCreditServiceRequest request, Guid EmployeeID)
        {
            GeneralResponse response = new GeneralResponse();

            try
            {
                CreditService creditService = new CreditService();

                #region Validate Uncredit Service Code

                string _errorMessag = AddValidate(request.CreditServiceCode, request.ServiceName);

                if (_errorMessag != "NoError")
                {
                    response.ErrorMessages.Add(_errorMessag);
                    return(response);
                }


                #endregion

                if (request.MaxDiscount > request.UnitPrice)
                {
                    response.ErrorMessages.Add("تخفیف نمیتواند بیش از قیمت پایه باشد");
                    return(response);
                }

                creditService.ID                = Guid.NewGuid();
                creditService.CreateDate        = PersianDateTime.Now;
                creditService.CreateEmployee    = _employeeRepository.FindBy(EmployeeID);
                creditService.CreditServiceCode = request.CreditServiceCode;
                creditService.Discontinued      = request.Discontinued;
                creditService.ExpDays           = request.ExpDays;
                creditService.Imposition        = request.Imposition;
                creditService.MaxDiscount       = request.MaxDiscount;
                creditService.Network           = this._networkRepository.FindBy(request.NetworkID);
                creditService.PurchaseUnitPrice = request.PurchaseUnitPrice;
                creditService.ResellerUnitPrice = request.ResellerUnitPrice;
                creditService.ServiceName       = request.ServiceName;
                creditService.UnitPrice         = request.UnitPrice;
                creditService.Note              = request.Note;
                creditService.Discontinued      = request.Discontinued;
                creditService.Bonus             = request.Bonus;
                creditService.Comission         = request.Comission;
                creditService.SortOrder         = GetSortOrder();
                creditService.RowVersion        = 1;

                #region validation

                if (creditService.GetBrokenRules().Count() > 0)
                {
                    foreach (BusinessRule businessRule in creditService.GetBrokenRules())
                    {
                        response.ErrorMessages.Add(businessRule.Rule);
                    }

                    return(response);
                }
                #endregion

                _creditServiceRepository.Add(creditService);
                _uow.Commit();
            }
            catch (Exception ex)
            {
                if (ex.InnerException != null && ex.InnerException.Message.Substring(0, 177) == @"The INSERT statement conflicted with the CHECK constraint ""CK_CreditService"". The conflict occurred in database ""Saman"", table ""Store.CreditService"", column 'CreditServiceCode'.")
                {
                    response.ErrorMessages.Add("MustBeBegin3000Key");
                }
                else
                {
                    response.ErrorMessages.Add(ex.Message);
                    if (ex.InnerException != null)
                    {
                        response.ErrorMessages.Add(ex.InnerException.Message);
                    }
                }
            }

            return(response);
        }