public async void Post([FromBody] TaskViewModel task) { bool hasPermissions = await HasTaskEditPermissions(task.ToModel(_prepOpsDataAccess)); if (!hasPermissions) { HttpUnauthorized(); } bool alreadyExists = _prepOpsDataAccess.GetTask(task.Id) != null; if (alreadyExists) { HttpBadRequest(); } var model = task.ToModel(_prepOpsDataAccess); if (model == null) { HttpBadRequest("Should have found a matching activity Id"); } await _prepOpsDataAccess.AddTask(model); }
public IActionResult Edit(int id) { var dbTask = _dataAccess.GetTask(id); var model = new TaskViewModel { Id = dbTask.Id, Name = dbTask.Name, Description = dbTask.Description, ActivityId = dbTask.Activity.Id, ActivityName = dbTask.Activity.Name, StartDateTime = dbTask.StartDateTimeUtc, EndDateTime = dbTask.EndDateTimeUtc }; return View(model); }
public static PrepOpsTask ToModel(this TaskViewModel task, IPrepOpsDataAccess dataAccess) { var activity = dataAccess.GetActivity(task.ActivityId); if (activity == null) return null; bool newTask = true; PrepOpsTask dbtask; if (task.Id == 0) { dbtask = new PrepOpsTask(); } else { dbtask = dataAccess.GetTask(task.Id); newTask = false; } // dbtask.Id = task.Id; dbtask.Description = task.Description; dbtask.Activity = activity; dbtask.EndDateTimeUtc = task.EndDateTime.HasValue ? task.EndDateTime.Value.UtcDateTime : new Nullable<DateTime>(); dbtask.StartDateTimeUtc = task.EndDateTime.HasValue ? task.StartDateTime.Value.UtcDateTime : new Nullable<DateTime>(); dbtask.Name = task.Name; // Workaround: POST is bringing in empty AssignedVolunteers. Clean this up. Discussing w/ Kiran Challa. // Workaround: the if statement is superflous, and should go away once we have the proper fix referenced above. if (task.AssignedVolunteers != null) { var bogusAssignedVolunteers = (from assignedVolunteer in task.AssignedVolunteers where string.IsNullOrEmpty(assignedVolunteer.UserId) select assignedVolunteer).ToList(); foreach (var bogus in bogusAssignedVolunteers) { task.AssignedVolunteers.Remove(bogus); } } // end workaround if (task.AssignedVolunteers != null && task.AssignedVolunteers.Count > 0) { var taskUsersList = task.AssignedVolunteers.Select(tvm => new TaskUsers { Task = dbtask, User = dataAccess.GetUser(tvm.UserId) }).ToList(); // We may be updating an existing task if (newTask || dbtask.AssignedVolunteers.Count == 0) { dbtask.AssignedVolunteers = taskUsersList; } else { // Can probably rewrite this more efficiently. foreach (TaskUsers taskUsers in taskUsersList) { if (!(from entry in dbtask.AssignedVolunteers where entry.User.Id == taskUsers.User.Id select entry).Any()) { dbtask.AssignedVolunteers.Add(taskUsers); } } } } return dbtask; }
public static PrepOpsTask ToModel(this TaskViewModel task, IPrepOpsDataAccess dataAccess) { var activity = dataAccess.GetActivity(task.ActivityId); if (activity == null) { return(null); } bool newTask = true; PrepOpsTask dbtask; if (task.Id == 0) { dbtask = new PrepOpsTask(); } else { dbtask = dataAccess.GetTask(task.Id); newTask = false; } // dbtask.Id = task.Id; dbtask.Description = task.Description; dbtask.Activity = activity; dbtask.EndDateTimeUtc = task.EndDateTime.HasValue ? task.EndDateTime.Value.UtcDateTime : new Nullable <DateTime>(); dbtask.StartDateTimeUtc = task.EndDateTime.HasValue ? task.StartDateTime.Value.UtcDateTime : new Nullable <DateTime>(); dbtask.Name = task.Name; // Workaround: POST is bringing in empty AssignedVolunteers. Clean this up. Discussing w/ Kiran Challa. // Workaround: the if statement is superflous, and should go away once we have the proper fix referenced above. if (task.AssignedVolunteers != null) { var bogusAssignedVolunteers = (from assignedVolunteer in task.AssignedVolunteers where string.IsNullOrEmpty(assignedVolunteer.UserId) select assignedVolunteer).ToList(); foreach (var bogus in bogusAssignedVolunteers) { task.AssignedVolunteers.Remove(bogus); } } // end workaround if (task.AssignedVolunteers != null && task.AssignedVolunteers.Count > 0) { var taskUsersList = task.AssignedVolunteers.Select(tvm => new TaskUsers { Task = dbtask, User = dataAccess.GetUser(tvm.UserId) }).ToList(); // We may be updating an existing task if (newTask || dbtask.AssignedVolunteers.Count == 0) { dbtask.AssignedVolunteers = taskUsersList; } else { // Can probably rewrite this more efficiently. foreach (TaskUsers taskUsers in taskUsersList) { if (!(from entry in dbtask.AssignedVolunteers where entry.User.Id == taskUsers.User.Id select entry).Any()) { dbtask.AssignedVolunteers.Add(taskUsers); } } } } return(dbtask); }