public ActionResult CreateOrEditPurchaseRequest(PurchaseRequestConfigModel _purchaserequestconfig)
        {
            _purchaserequestconfig.Account = (AccountModel)Session["UserLogon"];
            var request = new PurchaseRequestConfigRequest
            {
                Data = _purchaserequestconfig
            };

            PurchaseRequestConfigResponse _response = new PurchaseRequestConfigResponse();

            new PurchaseRequestConfigValidator(_unitOfWork).Validate(request, out _response);

            return(RedirectToAction("PurchaseRequestConfigList"));
        }
        public JsonResult DeletePurchaseRequestConfig(int id)
        {
            PurchaseRequestConfigResponse _response = new PurchaseRequestConfigResponse();
            var request = new PurchaseRequestConfigRequest
            {
                Data = new PurchaseRequestConfigModel
                {
                    Id      = id,
                    Account = Session["UserLogon"] == null ? new AccountModel() : (AccountModel)Session["UserLogon"]
                },
                Action = ClinicEnums.Action.DELETE.ToString()
            };

            new PurchaseRequestConfigValidator(_unitOfWork).Validate(request, out _response);

            return(Json(new { Status = _response.Status, Message = _response.Message }, JsonRequestBehavior.AllowGet));
        }
        private void ValidateForDelete(PurchaseRequestConfigRequest request, out PurchaseRequestConfigResponse response)
        {
            response = new PurchaseRequestConfigResponse();

            if (request.Action == ClinicEnums.Action.DELETE.ToString())
            {
                bool isHavePrivilege = IsHaveAuthorization(DELETE_M_PURCHASEREQUESTCONFIG, request.Data.Account.Privileges.PrivilegeIDs);
                if (!isHavePrivilege)
                {
                    response.Status  = false;
                    response.Message = Messages.UnauthorizedAccess;
                }
            }

            if (response.Status)
            {
                response = new PurchaseRequestConfigHandler(_unitOfWork).RemoveData(request);
            }
        }
        public void Validate(PurchaseRequestConfigRequest request, out PurchaseRequestConfigResponse response)
        {
            response = new PurchaseRequestConfigResponse();

            if (request.Action != null && request.Action.Equals(ClinicEnums.Action.DELETE.ToString()))
            {
                if (request.Action != null && request.Action.Equals(ClinicEnums.Action.DELETE.ToString()))
                {
                    ValidateForDelete(request, out response);
                }
            }
            else
            {
                bool isHavePrivilege = true;

                if (errorFields.Any())
                {
                    response.Status  = false;
                    response.Message = string.Format(Messages.ValidationErrorFields, String.Join(",", errorFields));
                }

                if (request.Data.Id == 0)
                {
                    isHavePrivilege = IsHaveAuthorization(ADD_M_PURCHASEREQUESTCONFIG, request.Data.Account.Privileges.PrivilegeIDs);
                }
                else
                {
                    isHavePrivilege = IsHaveAuthorization(EDIT_M_PURCHASEREQUESTCONFIG, request.Data.Account.Privileges.PrivilegeIDs);
                }

                if (!isHavePrivilege)
                {
                    response.Status  = false;
                    response.Message = Messages.UnauthorizedAccess;
                }

                if (response.Status)
                {
                    response = new PurchaseRequestConfigHandler(_unitOfWork).CreateOrEdit(request);
                }
            }
        }