Introduction
In this article, you will learn how to add a web part to a page using PnP Core CSOM library on SharePoint online sites.
The main advantage of using PnP Core libraries is the reduced code to get/set the required information. The required object can be retrieved/created/updated with a very small piece of code, once the client context is set. Prerequisite
The code, given below, is being tested, using Visual Studio console application. Once the console application is created, the packages can be installed, using "Install-Package SharePointPnPCoreOnline" command on Package Manager console of Visual Studio. Once installed, the references and packages will be imported to the solution. The references used in the sample are given below.
Microsoft.SharePoint.Client
OfficeDevPnP.Core
Connect to SharePoint Online site The Authentication Manager is used to retrieve the client context of the site. To connect to SharePoint Online site, the token, given below is used.
GetSharePointOnlineAuthenticatedContextToken
The parameters required are.
SharePoint Online site URL
Tenant UserId
Tenant Password (or secured string)
Add Web Part To Page
The web parts can be added to a page with the help of web part XML. The following steps explain the process in detail.
Input the site detail, user details for authentication, page details and web part info.
Authenticate and get the client context of the site and then the necessary Web object.
Using Web object, add the web part to a page using AddWebPartToWebPartPage method. The required parameters are given below.
a. Page URL
b. Web part entity object which contains web part XML and web part zone.
Display the results.
Web Part XML The web part XML needs to be saved and placed in a local folder for this operation. Each and every web part present on a SharePoint site is defined by XML. The web part XML contains the basic information about the web part. Some of the properties include web part title, description, assembly information, web part type, etc. The web part XML differs from each and every web part type. The web part XML of existing web part can be taken by the following steps.
Navigate to respective page
Edit the page
From the drop down of a web part, click on export
The following snippet shows the content editor web part XML. Similarly other web part XML can also be identified by above steps.
<?xml version="1.0" encoding="utf-8"?>
<WebPart xmlns:xsd="http://www.w3.org/2001/XMLSchema" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xmlns="http://schemas.microsoft.com/WebPart/v2">
<Title>Content Editor Custom WebPart</Title>
<FrameType>Default</FrameType>
<Description>Allows authors to enter rich text content.</Description>
<IsIncluded>true</IsIncluded>
<ZoneID>Header</ZoneID>
<PartOrder>0</PartOrder>
<FrameState>Normal</FrameState>
<Height />
<Width />
<AllowRemove>true</AllowRemove>
<AllowZoneChange>true</AllowZoneChange>
<AllowMinimize>true</AllowMinimize>
<AllowConnect>true</AllowConnect>
<AllowEdit>true</AllowEdit>
<AllowHide>true</AllowHide>
<IsVisible>true</IsVisible>
<DetailLink />
<HelpLink />
<HelpMode>Modeless</HelpMode>
<Dir>Default</Dir>
<PartImageSmall />
<MissingAssembly>Cannot import this Web Part.</MissingAssembly>
<PartImageLarge>/_layouts/15/images/mscontl.gif</PartImageLarge>
<IsIncludedFilter />
<Assembly>Microsoft.SharePoint, Version=16.0.0.0, Culture=neutral, PublicKeyToken=71e9bce111e9429c</Assembly>
<TypeName>Microsoft.SharePoint.WebPartPages.ContentEditorWebPart</TypeName>
<ContentLink xmlns="http://schemas.microsoft.com/WebPart/v2/ContentEditor" />
<Content xmlns="http://schemas.microsoft.com/WebPart/v2/ContentEditor" />
<PartStorage xmlns="http://schemas.microsoft.com/WebPart/v2/ContentEditor" />
</WebPart>
The following code snippet shows you the way to add a web part to a page.
// Input Parameters
string siteUrl = "https://abc.sharepoint.com";
string userName = "abc@abc.onmicrosoft.com";
string password = "***";
AuthenticationManager authManager = new AuthenticationManager();
try
{
using (var clientContext = authManager.GetSharePointOnlineAuthenticatedContextTenant(siteUrl, userName, password))
{
// Input Parameters
string webPartXml = @"C:\ContentEditorWP.xml";
string pageUrl = "/Pages/TestPage1.aspx";
WebPartEntity webpart = new WebPartEntity();
webpart.WebPartXml = System.IO.File.ReadAllText(webPartXml);
// Web Part XML
webpart.WebPartZone = "Right";
// Web Part Zone
// Adds web part
clientContext.Site.RootWeb.AddWebPartToWebPartPage(pageUrl, webpart);
Console.ReadKey();
}
}
catch (Exception ex)
{
Console.WriteLine("Error Message: " + ex.Message);
Console.ReadKey();
}
The following snapshot shows the web part added to the right side. The placement of the web part is decided using web part zone property.
Summary Thus you have learned how to add a web part to a page using PnP Core CSOM library. The operation is compatible for SharePoint online site. For on premise site, the authentication mechanism needs to be changed.
Commenti