public ActionResult Edit() { // Retrieve ID from session string code = SessionManager.CommandsCode; CommandsVM model = new CommandsVM(); // Not from staff or error if (String.IsNullOrEmpty(code)) { //If session has lists then use them RepopulateListsFromCacheSession(model); //Assume we are in create mode as no code passed model.CommandsItem = new CommandsModel(); } //if we have been passed a code then assume we are in edit situation and we need to retrieve from the database. else { // Create service instance AdminServiceClient sc = new AdminServiceClient(); try { // Call service to get Commands item and any associated lookups CommandsVMDC returnedObject = sc.GetCommands(CurrentUser, CurrentUser, appID, "", code); // Close service communication sc.Close(); //Get view model from service model = ConvertCommandsDC(returnedObject); ResolveFieldCodesToFieldNamesUsingLists(model); //Store the service version SessionManager.CommandsServiceVersion = model.CommandsItem; } catch (Exception e) { // Handle the exception string message = ExceptionManager.HandleException(e, sc); model.Message = message; return(View(model)); } } //Adds current retrieved Commands to session SessionManager.CurrentCommands = model.CommandsItem; SetAccessContext(model); return(View(model)); }
private CommandsVM ConvertCommandsDC(CommandsVMDC returnedObject) { CommandsVM model = new CommandsVM(); // Map Commands Item model.CommandsItem = Mapper.Map <CommandsDC, CommandsModel>(returnedObject.CommandsItem); // Map lookup data lists return(model); }
/// <summary> /// Create a Commands /// </summary> /// <param name="currentUser"></param> /// <param name="user"></param> /// <param name="appID"></param> /// <param name="overrideID"></param> /// <param name="dc"></param> /// <param name="dataRepository"></param> /// <param name="uow"></param> public CommandsVMDC CreateCommands(string currentUser, string user, string appID, string overrideID, CommandsDC dc, IRepository <Commands> dataRepository, IUnitOfWork uow) { try { #region Parameter validation // Validate parameters if (string.IsNullOrEmpty(currentUser)) { throw new ArgumentOutOfRangeException("currentUser"); } if (string.IsNullOrEmpty(user)) { throw new ArgumentOutOfRangeException("user"); } if (string.IsNullOrEmpty(appID)) { throw new ArgumentOutOfRangeException("appID"); } if (null == dc) { throw new ArgumentOutOfRangeException("dc"); } if (null == dataRepository) { throw new ArgumentOutOfRangeException("dataRepository"); } if (null == uow) { throw new ArgumentOutOfRangeException("uow"); } #endregion using (uow) { // Create a new ID for the Commands item dc.Code = Guid.NewGuid(); // Map data contract to model Commands destination = Mapper.Map <CommandsDC, Commands>(dc); // Add the new item dataRepository.Add(destination); // Commit unit of work uow.Commit(); } // Create aggregate data contract CommandsVMDC returnObject = new CommandsVMDC(); // Add new item to aggregate returnObject.CommandsItem = dc; return(returnObject); } catch (Exception e) { //Prevent exception from propogating across the service interface ExceptionManager.ShieldException(e); return(null); } }
/// <summary> /// Retrieve a Commands with associated lookups /// </summary> /// <param name="currentUser"></param> /// <param name="user"></param> /// <param name="appID"></param> /// <param name="overrideID"></param> /// <param name="code"></param> /// <param name="dataRepository"></param> /// <param name="uow"></param> /// <returns></returns> public CommandsVMDC GetCommands(string currentUser, string user, string appID, string overrideID, string code, IUnitOfWork uow, IRepository <Commands> dataRepository ) { try { #region Parameter validation // Validate parameters if (string.IsNullOrEmpty(currentUser)) { throw new ArgumentOutOfRangeException("currentUser"); } if (string.IsNullOrEmpty(user)) { throw new ArgumentOutOfRangeException("user"); } if (string.IsNullOrEmpty(appID)) { throw new ArgumentOutOfRangeException("appID"); } if (null == dataRepository) { throw new ArgumentOutOfRangeException("dataRepository"); } if (null == uow) { throw new ArgumentOutOfRangeException("uow"); } #endregion using (uow) { CommandsDC destination = null; // If code is null then just return supporting lists if (!string.IsNullOrEmpty(code)) { // Convert code to Guid Guid codeGuid = Guid.Parse(code); // Retrieve specific Commands Commands dataEntity = dataRepository.Single(x => x.Code == codeGuid); // Convert to data contract for passing through service interface destination = Mapper.Map <Commands, CommandsDC>(dataEntity); } // Create aggregate contract CommandsVMDC returnObject = new CommandsVMDC(); returnObject.CommandsItem = destination; return(returnObject); } } catch (Exception e) { //Prevent exception from propogating across the service interface ExceptionManager.ShieldException(e); return(null); } }
//This method is shared between create and save private ActionResult UpdateCommands() { // Get the updated model var model = GetUpdatedModel(); // Test to see if there are any errors var errors = ModelState .Where(x => x.Value.Errors.Count > 0) .Select(x => new { x.Key, x.Value.Errors[0].ErrorMessage }) .ToArray(); //Set flags false SetFlagsFalse(model); // Test to see if the model has validated correctly if (ModelState.IsValid) { // Create service instance AdminServiceClient sc = new AdminServiceClient(); //Attempt update try { // Map model to data contract CommandsDC CommandsItem = Mapper.Map <CommandsDC>(model.CommandsItem); CommandsVMDC returnedObject = null; if (null == model.CommandsItem.Code || model.CommandsItem.Code == Guid.Empty) { // Call service to create new Commands item returnedObject = sc.CreateCommands(CurrentUser, CurrentUser, appID, "", CommandsItem); } else { // Call service to update Commands item returnedObject = sc.UpdateCommands(CurrentUser, CurrentUser, appID, "", CommandsItem); } // Close service communication sc.Close(); // Retrieve item returned by service var createdCommands = returnedObject.CommandsItem; // Map data contract to model model.CommandsItem = Mapper.Map <CommandsModel>(createdCommands); //After creation some of the fields are display only so we need the resolved look up nmames ResolveFieldCodesToFieldNamesUsingLists(model); // Set access context to Edit mode model.AccessContext = CommandsAccessContext.Edit; // Save version of item returned by service into session SessionManager.CommandsServiceVersion = model.CommandsItem; SessionManager.CurrentCommands = model.CommandsItem; // Remove the state from the model as these are being populated by the controller and the HTML helpers are being populated with // the POSTED values and not the changed ones. ModelState.Clear(); model.Message = FixedResources.MESSAGE_UPDATE_SUCCEEDED; } catch (Exception e) { // Handle the exception string message = ExceptionManager.HandleException(e, sc); model.Message = message; return(View(model)); } } return(View(model)); }