public ActionResult Create(LevelConditionDetailView levelConditionDetailView) { #region Check Access bool hasPermission = GetEmployee().IsGuaranteed("LevelCondition_Insert"); if (!hasPermission) { ModelState.AddModelError("", "AccessDenied"); return(View(levelConditionDetailView)); } #endregion if (ModelState.IsValid) { try { AddLevelConditionRequest request = new AddLevelConditionRequest(); request.CreateEmployeeID = GetEmployee().ID; request.ConditionID = levelConditionDetailView.LevelConditionView.Condition.ID; request.LevelID = levelConditionDetailView.LevelConditionView.LevelID; GeneralResponse response = this._levelConditionService.AddLevelCondition(request); if (response.success) { return(RedirectToAction("Index")); } else { foreach (string error in response.ErrorMessages) { ModelState.AddModelError("", error); } return(View(levelConditionDetailView)); } } catch (Exception ex) { ModelState.AddModelError("", ex.Message); return(View(levelConditionDetailView)); } } return(View(levelConditionDetailView)); }
public GeneralResponse AddLevelCondition(AddLevelConditionRequest request) { GeneralResponse response = new GeneralResponse(); try { LevelCondition levelCondition = new LevelCondition(); levelCondition.ID = Guid.NewGuid(); levelCondition.CreateDate = PersianDateTime.Now; levelCondition.CreateEmployee = _employeeRepository.FindBy(request.CreateEmployeeID); levelCondition.Condition = this._conditionRepository.FindBy(request.ConditionID); levelCondition.Level = this._levelRepository.FindBy(request.LevelID); levelCondition.RowVersion = 1; #region Validation if (levelCondition.GetBrokenRules().Count() > 0) { foreach (BusinessRule businessRule in levelCondition.GetBrokenRules()) { response.ErrorMessages.Add(businessRule.Rule); } return(response); } #endregion _levelConditionRepository.Add(levelCondition); _uow.Commit(); ////response.success = true; } catch (Exception ex) { response.ErrorMessages.Add(ex.Message); } return(response); }