Get Your SharePoint 2019 Environment Ready For SPFx Development
Overview
SharePoint Framework (SPFx) is well known for developing the solutions for modern sites in SharePoint Online. Anyway, it isn't just constrained to the cloud. SharePoint Framework development is likewise upheld on SharePoint OnPremise environment (SharePoint 2016 onwards).
In this article, we will explore how we can get our SharePoint 2019 On-Premises environment ready for SharePoint Framework and start developing SPFx client side web parts.
Make SharePoint Server 2019 SPFx Ready
SharePoint Framework is by default supported in SharePoint Server 2019, without any additional feature patch installations. Follow below steps to make your SP2019 environment ready for SPFx development.
**Install NodeJS **
- Install version 8.x from https://nodejs.org
- If you already have NodeJS installed, check the version by running below command.
node -v
Install Code Editor
Install any of below code editor
- Visual Studio Code (https://code.visualstudio.com)
- Atom (https://atom.io)
- Webstorm (https://www.jetbrains.com/webstorm)
Install Yeoman and gulp
Run below command
npm install -g yo gulp
Install Yeoman SharePoint Generator
SPFx version 1.4.1 is supported with SharePoint 2019 (except MS Graph APIs). Run below command.
npm install -g @microsoft/generator-sharepoint
Develop SharePoint Framework Web Part
1. Open command prompt. Create a directory for SPFx solution.
md spfx-sp2019-onprem
- Navigate to above created directory.
cd spfx-sp2019-onprem
- Run Yeoman SharePoint Generator to create the solution.
yo @microsoft/sharepoint
- Yeoman generator will present you with the wizard by asking questions about the solution to be created.
Solution Name: Hit enter to have default name (spfx-sp2019-onprem in this case) or type in any other name for your solution.
Selected choice: Hit enter (default choice)
Target for component: Here we can select the target environment where we are planning to deploy the client webpart i.e. SharePoint Online only (latest) / SharePoint 2016 onwards, including 2019 and SharePoint Online / SharePoint 2019 onwards, including SharePoint Online.
Selected choice: SharePoint 2019 onwards, including SharePoint Online
Place of files: We may choose to use the same folder or create a subfolder for our solution.
Selected choice: Same folder
Deployment option: Selecting Y will allow the app to deployed instantly to all sites and will be accessible everywhere.
Selected choice: N (install on each site explicitly)
Type of client-side component to create: We can choose to create client side webpart or an extension.
Selected choice: WebPart
Web part name: Hit enter to select the default name or type in any other name.
Selected choice: HelloSP2019
Web part description: Hit enter to select the default description or type in any other value.
Selected choice: SP2019 development with SPFx
Framework to use: Select any JavaScript framework to develop the component. Available choices are No JavaScript Framework, React, and Knockout.
Selected choice: React
5. Yeoman generator will perform scaffolding process to generate the solution. The scaffolding process will take significant amount of time.
6. Once the scaffolding process is completed, lock down the version of project dependencies by running below command.
npm shrinkwrap
- In the command prompt type below command to open the solution in code editor of your choice.
code .
SPFx Support for SharePoint 2019
If you use the SharePoint Framework v1.7, you can target scaffolded solution to SharePoint 2019, which will ensure that packages are correct for your target environment.
Open package.json file and observe the SPFx version being used (~1.4.0).
Test the SPFx WebPart On Local SharePoint Workbench
- On the command prompt, type “gulp serve”.
- Open SharePoint site.
- Navigate to /_layouts/15/workbench.aspx
- Add the webpart to page.
Set Up App Catalog
We will set up an App catalog to add the SPFx solution later. Follow below steps as Farm administrator.
- Open SharePoint 2019 Central Administration site.
- From left menu, click Apps.
- Under App Management, click Manage App Catalog.
- Select web application to create the app catalog site.
- Select Create a new app catalog site.
Enable Scripting Capabilities
This is an optional step only if you are planning to use SPFx web parts on classic SharePoint sites. If you are going to use SPFx web parts only on Modern SharePoint sites, then you may skip this step.
- Open SharePoint 2019 Management Shell as an administrator.
- Execute below PowerShell command.
(Get-SPSite -Identity "http://portal.contoso.com/sites/ModernSite").DenyPermissionsMask = [Microsoft.SharePoint.SPBasePermissions]::EmptyMask
Prepare the Package
We will now prepare a package (.sppkg) to deploy to SharePoint app catalog.
Bundle the solution
In the command prompt, type the below command.
gulp bundle --ship
This command will minify the required assets to “temp\deploy” folder.
Package the solution
In the command prompt, type the below command.
gulp package-solution --ship
This will create the solution package (sppkg) in sharepoint\solution folder.
Upload the Package to App Catalog
We will upload the SPFx package to app catalog to make it available on all sites.
- Open SharePoint App Catalog site.
- From left menu, click Apps for SharePoint.
- Click Upload to add SPFx package from “\sharepoint\solution” location.
- Click Deploy.
Add SPFx Solution to Modern SharePoint Site
We will add SPFx solution to SP2019 Modern SharePoint site.
- Open SharePoint 2019 Modern SharePoint site.
- Click cog wheel > Site contents.
Add SPFx Web Part to Modern Page
Once the SPFx solution is successfully deployed to SharePoint site, we will add web part to modern page.
Click F12 to open the developer dashboard and observe the CDN from where the assets are being loaded from.
Troubleshooting
Workbench does not load
Although you have everything installed and correctly setup, you might face below issues on “gulp serve”
Internet explorer
In the command prompt, run below command to resolve the issue.
set NODE_NO_HTTP2=1
“gulp serve” is not running
In some cases SharePoint workbench (https://[tenant].sharepoint.com/_layouts/15/workbench.aspx) shows below error although “gulp serve” is running.
Open below url in the next tab of browser. Accept the warning message.
https://localhost:4321/temp/manifests.js
Conclusion
For the future compatibility of solution, it is recommended to start using SharePoint Framework based development in SharePoint OnPremise. Also one thing to note that SPFx solutions created for SharePoint Online might not work for SharePoint OnPremise.