top of page

CSOM: Working with Office365 Project Online Tasks - Part II

This article explains steps for adding, updating or deleting a task to/from Office 365 Project Online plan schedules.

This article series focuses on working with  office 365 project online plan schedule tasks using Client Side Object model approach. In the previous post, we have seen multiple ways of retrieving tasks from the project plans.

Adding a Task: 

A task can be added to the Office 365 project plan schedule by the following steps.

  • Required project needs to be checked-out before any operation. 

  • Task collection is retrieved from the draft project. 

  • Task creation object is created with necessary OOB field values, and will be added to the task collection. 

  • Then the draft project will be updated and published. 

The following code snippet shows the above explained steps.


private static void AddTask()

{

using (ProjectContext projContext = new ProjectContext("https://nakkeerann.sharepoint.com/sites/pwa"))

{

projContext.Credentials = new SharePointOnlineCredentials("nav@nakkeerann.onmicrosoft.com", password);

var projects = projContext.Projects;

var projectId = "3a000b01-55f2-e811-afac-00155d24c70d";

var project = projects.GetById(projectId);

project.CheckOut();

var draftProject = project.Draft;

var tasks = draftProject.Tasks;

TaskCreationInformation newTask = new TaskCreationInformation();

newTask.Name = "Task4";

//newTask["a"] = "";

tasks.Add(newTask);

draftProject.Update();

draftProject.Publish(true);

projContext.ExecuteQuery();


Console.WriteLine("Task Created: " + newTask.Name);

}

}


Updating a Task: 

A task can be update on the Office 365 project plan schedule by the following steps.

  • Required project needs to be checked-out before any operation. 

  • Task collection is retrieved from the draft project. 

  • Task is retrieved from the task collection. 

  • Necessary OOB/custom fields can be set with new values. 

  • Then the draft project will be updated and published. 

  • Execute query using Project context . 

The following code snippet shows the update operation.

private static void UpdateTaskById()

{

using (ProjectContext projContext = new ProjectContext("https://nakkeerann.sharepoint.com/sites/pwa"))

{

projContext.Credentials = new SharePointOnlineCredentials("nav@nakkeerann.onmicrosoft.com", password);

var projects = projContext.Projects;

var projectId = "3a000b01-55f2-e811-afac-00155d24c70d";

var project = projects.GetById(projectId);

project.CheckOut();

var draftProject = project.Draft;

var tasks = draftProject.Tasks;

var taskId = "4709f408-55f2-e811-afa6-a01d710bba4a";

var task = tasks.GetById(taskId);

task.Start = DateTime.Now;

task.Finish = DateTime.Now.AddDays(365);

task["Custom_0652e0806606e911afb600155d48510a"] = "Task Dates Updated";


draftProject.Update();

draftProject.Publish(true);

projContext.ExecuteQuery();


Console.WriteLine("Task Updated");

}

}

Deleting a Task: 

A task can be deleted from the Office 365 project plan schedule by the following steps.

  • Check-out the project, and retrieve the tasks collection. 

  • Retrieve the task from the task collection. 

  • Delete the task object. 

  • Then the draft project will be updated and published. 

  • Execute query using Project context . 

The following code snippet shows the delete operation.


private static void DeleteTaskById()

{

using (ProjectContext projContext = new ProjectContext("https://nakkeerann.sharepoint.com/sites/pwa"))

{

projContext.Credentials = new SharePointOnlineCredentials("nav@nakkeerann.onmicrosoft.com", password);

var projects = projContext.Projects;

var projectId = "3a000b01-55f2-e811-afac-00155d24c70d";

var project = projects.GetById(projectId);

project.CheckOut();

var draftProject = project.Draft;

var tasks = draftProject.Tasks;

var taskId = "4709f408-55f2-e811-afa6-a01d710bba4a";

var task = tasks.GetById(taskId);

task.DeleteObject();

draftProject.Update();

draftProject.Publish(true);

projContext.ExecuteQuery();


Console.WriteLine("Task Deleted");

}

}

0 comments

Comments


bottom of page