top of page

SharePoint Basic SubSite Operations Using TypeScript With Inheritance

Introduction

In this article, you will learn how to perform basic site operations (web scoped) on SharePoint site collections/sites, using TypeScript, with the help of classes and variables. You will see how to create, retrieve, update, and delete the sites/subsites with the help of inheritance approach.

To learn about TypeScript basics and for the prerequisites to be available on Visual Studio for SharePoint TypeScript programming, you can refer to the following article.

In my other article, I have explained about implementing TypeScript basic examples in SharePoint Visual Studio project.

This article focuses more on implementing the site operations (web scoped) using ECMA script, with the help of TypeScript and object oriented programming concepts. Class

The class will hold the necessary members. This means, the class will hold the necessary variables, constructors, and the defined functions. In this sample, two classes are considered: basic class with retrieval and create operations and another class with update and delete operations, which inherits the base class.

Variables

The necessary variables common for all the functions are defined as the member variables. In this case, all the variables to be defined in the base class are given below.

  1. // Variables or Objects  

  2. public context: SP.ClientContext;  

  3. public web: SP.Web;  

  4. public webs: SP.WebCollection;  


Constructor

The constructor can be defined either without parameters or with parameters, depending on the requirement. The context of the site can be set using the respective method. With the help of context object, the other variables can be set while using the respective methods. The variables/objects set using the constructor are context, web, and web collection.

In this sample, all the variables are set in the base class constructor. The derived class constructor will inherit the base constructor using super function.

The below code shows the base class constructor.

  1. constructor(siteRelativeUrl: string) 

  2. {    

  3. this.context = new SP.ClientContext(siteRelativeUrl);    

  4. this.web = this.context.get_web();    

  5. this.webs = this.web.get_webs();    

  6. }    


The below code shows the derived class constructor.

  1. constructor(siteRelativeUrl: string) 

  2. {   super(siteRelativeUrl);  }  


Functions

The required functions are defined inside the classes. The create and retrieval functions are defined in the base class. The update and delete functions are defined in the derived class. In this sample, the basic site operations, mentioned below, are defined using the functions.

  • Retrieve Sub Sites The sub sites available in the site/site collection are retrieved. The web collection is loaded and executed with the help of context. Then, sub sites are accessed from context site.

  • Retrieve Site The site information can be retrieved using TypeScript. The web object is loaded and executed with context. Note - To get the sub site information, the function should be present in derived class.

  • Create Sub Site The sub site can be created on the site collection/site, using TypeScript. The necessary input parameters are passed using WebCreationInformation object.

  • Update Site The site can be updated using TypeScript. In the below sample, the description of the sub site is updated.

  • Delete Site The site can be deleted using TypeScript. The web object needs to be deleted using deleteObject method.

Note

The collection/objects need to be loaded and executed for all the operations, using the context object (defined in the constructor).The site to be retrieved, updated, or deleted is determined based on the context URL.


The code snippet, mentioned below, shows the site functions defined inside the class.

  1. class SiteOperations 

  2. {  

  3. // Variables or Objects  

  4. public context: SP.ClientContext;  

  5. public web: SP.Web;  

  6. public webs: SP.WebCollection;  

  7. // Set objects       

  8. constructor(siteRelativeUrl: string) 

  9. {  

  10. this.context = new SP.ClientContext(siteRelativeUrl);  

  11. this.web = this.context.get_web();  

  12. this.webs = this.web.get_webs();          

  13. }  

  14. // Retrieves all sub sites  

  15. public GetSites() {              

  16. let websites = this.webs;  

  17. this.context.load(websites);  

  18. this.context.executeQueryAsync(function() 

  19. {                  

  20. let subSites = websites.getEnumerator();  

  21. while (subSites.moveNext()) 

  22. {                      

  23. let subSite = subSites.get_current();                      

  24. console.log(subSite.get_title());                  

  25. }              

  26. }, 

  27. function(sender, args) {                  

  28. console.log("Error");              

  29. });          

  30. }  

  31. // creates sub site  

  32. public CreateSubSite() {              

  33. let websites = this.webs;              

  34. let webInfo = new SP.WebCreationInformation();              

  35. webInfo.set_title("SubSite3");              

  36. webInfo.set_description("SubSite created for testing TS");              

  37. webInfo.set_url("SubSite3");              

  38. webInfo.set_language(1033);              

  39. webInfo.set_useSamePermissionsAsParentSite(true);              

  40. webInfo.set_webTemplate("STS#0");              

  41. websites.add(webInfo);  

  42. this.context.load(websites);  

  43. this.context.executeQueryAsync(function() {                  

  44. console.log("SubSite Created");              

  45. }, 

  46. function(sender, args) {                  

  47. console.log("Error");              

  48. });          

  49. }  

  50. // Retrieves site  

  51. public GetSite() {          

  52. let website = this.web;  

  53. this.context.load(website);  

  54. this.context.executeQueryAsync(function() 

  55. {              

  56. console.log(website.get_title());          

  57. }, 

  58. function(sender, args) {});      

  59. }  }  

  60. class WebOperations extends SiteOperations {   // calls the base constructor to set the context and other objects       

  61. constructor(siteRelativeUrl: string) {  

  62. super(siteRelativeUrl);          

  63. }  

  64. // Updates site  

  65. public UpdateSite() {              

  66. let website = this.web;              

  67. website.set_description("Updating using TypeScript");  

  68. this.context.load(website);  

  69. this.context.executeQueryAsync(function() 

  70. {                  

  71. console.log("SubSite updated" + website.get_title());              

  72. }, 

  73. function(sender, args) {                  

  74. console.log(args.get_message());              

  75. });          

  76. }  

  77. // Deletes site  

  78. public DeleteSite() {          

  79. let website = this.web;          

  80. website.deleteObject();  

  81. this.context.executeQueryAsync(function() 

  82. {              

  83. console.log("SubSite Deleted");          

  84. }, 

  85. function(sender, args) 

  86. {              

  87. console.log(args.get_message());          

  88. });      

  89. }  }  


Execution

The classes are instantiated with the help of objects. Context of the site is set using the constructors.

In the below sample,For base class, root site URL can be set as context, by passing the site collection URL as object parameter.For the derived class, the sub site URL can be set as context, by passing the sub site URL as object parameter.The code snippet, mentioned below, triggers the members defined inside the classes. The comments are provided along with the function calls to explain every step in details.

  1. // Loads necessary files  

  2. $(document).ready(function() 

  3. {      

  4. SP.SOD.executeOrDelayUntilScriptLoaded(function() 

  5. {          

  6. SP.SOD.executeOrDelayUntilScriptLoaded(() => GetData(), 'SP.js');      

  7. }, 

  8. 'SP.RunTime.js');  

  9. });  

  10. // Instantiate object and call the methods  

  11. function GetData() 

  12. {      

  13. let siteOps = new SiteOperations("/");      

  14. siteOps.GetSites(); 

  15. // Retrieves all sub sites from site collection       

  16. siteOps.GetSite(); 

  17. // Retrieves current site(site collection) information       

  18. siteOps.CreateSubSite(); 

  19. // Creates a sub site for site collection       

  20. let webOps = new WebOperations("/SubSite1");      

  21. webOps.UpdateSite(); // Updates sub site SubSite1       

  22. webOps.DeleteSite(); // Deletes sub site SubSite1       

  23. webOps.GetSites(); // Retrieves all sub sites from SubSite1 site       

  24. webOps.CreateSubSite(); // Creates a sub site for SubSite1 site  

  25. }  


Summary

Thus, you have learned the basic site operations, using TypeScript programming with help of inheritance approach.

0 comments

Comments


bottom of page