SharePoint Development Community (PnP) – July 2018 update

SharePoint team

SharePoint Dev Ecosystem / SharePoint Patterns and Practices (PnP) July 2018 update is out with a summary of the latest guidance, samples, and solutions from SharePoint engineering or from the community for the community. This article is a summary of all the different areas and topics around SharePoint Dev ecosystem during the past month.

What is SharePoint Patterns & Practices (PnP)?

SharePoint / Office Dev Patterns and Practices

SharePoint PnP is a nick-name for SharePoint Dev Ecosystem activities coordinated by SharePoint engineering. SharePoint PnP is community driven open source initiative where Microsoft and external community members are sharing their learning’s around implementation practices for SharePoint and Office 365. Active development and contributions happen in GitHub by providing contributions to the samples, reusable components, and documentation.

PnP is owned and coordinated by SharePoint engineering, but this is work done by the community for the community. The initiative is currently facilitated by Microsoft, but already at this point, we have multiple community members as part of the PnP Core team and we are looking to extend the Core team with more community members.

Notice that since this is open source community initiative, there’s no SLAs for the support for the samples provided through GitHub. Obviously, all officially released components and libraries are under official support from Microsoft. You can use SharePoint Developer group in the Microsoft Tech Community for providing input and to ask any questions about the existing materials.

Some key statistics around SharePoint Dev topics from June 2018

  • GitHub repository forks at most popular repositories in SharePoint GitHub organization
  • Unique visitors during past 2 weeks in SharePoint organization repositories – 42,946
  • Merged pull requests across SharePoint repositories (cumulative) – 5,217
  • Closed issues and enhancements ideas cross SharePoint repositories (cumulative) – 4,374
  • SharePoint Online CSOM NuGet package downloads (cumulative) – 568,564
  • Page views in SharePoint Dev pages at docs.microsoft.com – 860,293
  • Unique tenants using PnP components – 13,316
  • Http requests towards SharePoint Online from PnP components (CSOM Core, PowerShell, PnP JS Core) – 10,403,931,322
  • SharePoint Dev YouTube channel had 27,491 views with 185,811 minutes watch time

Main resources around SharePoint PnP and SharePoint development

July 2018 monthly community call

Agenda for the Tuesday 10th of July 2018 SharePoint Dev Ecosystem / Patterns and Practices community call at 8 AM PST / 5 PM CEST:

  • Monthly summary of SharePoint Development topics – Latest SharePoint roadmap and community news – Vesa Juvonen (Microsoft) ~20 min
  • Using Microsoft Graph Custom Schema Extensions with SharePoint Framework – Luis Mañez (ClearPeople) ~15 min
  • SharePoint Starter Kit – Building extending personalized footer for community site – Paolo Pialorsi (Piasys.com) ~15 min
  • Q&A ~10 min

Monthly community call will get recorded and release to PnP YouTube channel typically within 24 hours after the recording is ended. If you have any questions, comments or feedback, please participate in our discussions in the Microsoft Tech Community under SharePoint developer group.

SharePoint Dev Blog posts

Here are the latest blog posts and announcements around SharePoint development topics from dev.office.com/blogs.

PnP Webcasts

PnP Webcasts are typically 15-30 min long conversational webcasts around a specific topic. This series was started in October 2015 and have continued releasing new videos since. All new webcasts are released on PnP YouTube Channel. Here are the new webcasts released after the last monthly release. We are looking into continuing the releases of the webcast in the future.

General Dev, CSOM, PnP Core, PnP PowerShell SIG Bi-Weekly Call Special Interest Group (SIG)

General SP Dev, CSOM PnP Sites Core, PowerShell and Provisioning Special Interest Group (SIG) have bi-weekly meetings to cover the general SharePoint topics, CSOM and latest in the PnP CSOM core component, PnP PowerShell and in the PnP remote provisioning engine. These calls have also free Q&A section if you have any questions about SharePoint development in on-premises or in the cloud. Need to get a recommendation for your design or having a hard time with some APIs? – Drop by, ask a question and we’ll help you.

You can download invite for the bi-weekly meeting from the following location.

All SIG meetings are being recorded and are available for view from PnP YouTube Channel. Here are the latest recordings of the SIG calls.

  • 28th of June – SP Dev news with engineering update. Building site provisioning solution with PowerApps, Microsoft Flow, and Azure functions – Using Get-PnPSearchCrawlLog cmdlet for search troubleshooting.
  • 14th of June – SP Dev news with engineering update. News around Microsoft Flow and PowerApps from SharePoint perspective. Microsoft PowerApps tips in SharePoint Online. Advance provisioning techniques in SharePoin Starter Kit.

Interested in doing a community demo in these community calls? – Please let us know!

SharePoint Framework (SPFX) and JavaScript Special Interest Group (SIG)

SharePoint Framework and JavaScript Special Interest Group (SIG) has bi-weekly meetings to cover latest changes in the SharePoint Framework side, from the engineering perspective and to cover also latest development related to the PnP JS Core library. These calls are designed to have 50%/50% of content and demos and there has been already great community demos on the new SharePoint Framework Client-side web parts. If you’re interested in showing your code, just let us know.

All SharePoint Framework and JS SIG meetings are recorded, so that you can check the demos and discussions if you can’t make the actual call. You can find the latest recordings from the PnP YouTube Channel. Here are the latest recordings.

  • 5th of July – SharePoint Framework engineering update, PnP JS Core update, Office 365 CLI update, SPFx controls update – System Update Flow with SharePoint Framework, Building search web parts which support configurable templates for rendering.
  • 21st of June – SharePoint Framework engineering update, PnP JS Core update, Office 365 CLI update, SPFx controls update – Using PropertyFiledCollectionData control in SPFx web part, VSTS and SharePoint regarding CD/CI pipelines, React Calendar Feed web part.
  • 7th of June – SharePoint Framework engineering update, PnP JS Core update, Office 365 CLI update, SPFx controls update – Dynamic Data in SharePoint Framework v1.5. Using Jest Test Framework with SharePoint Framework solutions.

Interested in doing a community demo in these community calls? – Please let us know!

SharePoint Dev Ecosystem in GitHub

There are quite a few different GitHub repositories under the SharePoint brand since we wanted to ensure that you can easily find and reuse what’s relevant to you. We do also combine multiple solutions to one repository so that you can more easily sync and get latest changes to our released guidance and samples.

  • PnP – Main repository for SP add-in, Microsoft Graph etc. samples
  • PnP-Guidance – Guidance, presentations, and articles which are partly synced to MSDN
  • PnP-Sites-Core – Office Dev PnP Core component
  • PnP-PowerShell – Office Dev PnP PowerShell Cmdlets
  • PnP-Tools – Tools and scripts targeted more for IT Pro’s and for on-premises for SP2013 and SP2016
  • PnP-Partner-Pack – Packaged guidance with detailed instructions on setting things up in Office 365 and in Azure.
  • PnP-Transformation – Material specifically for the transformation process. Currently, includes samples around InfoPath replacement and transformation tooling from farm solutions to add-in model.
  • PnP-Provisioning-Templates – Source for templates available from PnP Template Gallery at http://templates-gallery.sharepointpnp.com
  • PnP-Provisioning-Schema – PnP Provisioning engine schema repository
  • PnP-IdentityModel – Open source replacement of Microsoft.IdentityModel.Extensions.dll
  • PnPjs – PnPjs Framework repository
  • o365 CLI – Cross-OS command line interface to manage Office 365 tenant settings

What’s supportability story around PnP material?

Following statements apply across all of the PnP samples and solutions, including samples, core component(s) and solutions, like SharePoint Starter Kit.

  • PnP guidance and samples are created by Microsoft & by the Community
  • PnP guidance and samples are maintained by Microsoft & community
  • PnP uses supported and recommended techniques
  • PnP implementations are reviewed and approved by Microsoft engineering
  • PnP is an open-source initiative by the community – people who work on the initiative for the benefit of others, have their normal day job as well
  • PnP is NOT a product and therefore it’s not supported by Premier Support or other official support channels
  • PnP is supported in similar ways as other open source projects done by Microsoft with support from the community by the community
  • There are numerous partners that utilize PnP within their solutions for customers. Support for this is provided by the Partner. When PnP material is used in deployments, we recommend being clear with your customer/deployment owner on the support model

Latest changes

SharePoint Starter Kit

SP Starter Kit

SharePoint Starter Kit demonstrates how to extend out of the box modern experiences in the SharePoint. It demonstrates multiple different techniques and uses different patterns and practices to build end-to-end demonstration solution which can be provisioned to any Office 365 tenant. It contains for example following capabilities, which you can learn from or use them as your reference:

  • How to provision site collections using PowerShell
  • How to apply content and layouts to site collections
  • How to create and use Site Designs and Site Scripts
  • How to build custom web parts and extensions for your deployment
  • 15 different ready to use web parts
  • 7 different extensions
  • Hub site configuration
  • etc. etc. etc.

Following are the key changes in the Starter Kit since the previous monthly summary

  • Significantly improved documentation
  • Provisioning improvements for more complete automation
  • Code changes to simplify web part and extension reuse also outside of the Starter Kit solution

SharePoint Starter Kit was announced in SharePoint Conference 2018 and we will keep on evolving and update this reference solution also during future releases. We also do welcome contributions on this open-source community lead project.

SharePoint Framework samples

These are samples which are available from the SharePoint client-side web part sample repository at https://github.com/SharePoint/sp-dev-fx-webparts or from the SharePoint Framework Extensions repository at https://github.com/SharePoint/sp-dev-fx-extensions.

Reusable open source controls for SharePoint Framework

New reusable controls initiative was announced in Ignite 2017 during September. There are two npm packages and source code repositories for the reusable controls which you can use in your SharePoint Framework solutions. We do welcome community contributions to these initiatives as well. There are two different repositories: sp-dev-fx-property-controls and sp-dev-fx-controls-react. Here are the changes on these repositories.

Added

  • A newPeoplePicker control added #19

Enhancements

  • Add npm postinstall script to automatically add the localization config #64
  • Add a description to the PropertyFieldCollectionData panel #67
  • Added a font field type for the PropertyFieldCollectionData control #66
  • Added a URL field type for the PropertyFieldCollectionData control #72
  • Field validation implemented to enable/disable save buttons in PropertyFieldCollectionData control. Related to previous enhancement.
  • Added properties to the TaxonomyPicker to specify which terms are disabled/not-selectable #69

Fixes

  • Bug in TaxonomyPicker where values are not updated by an async change #83
  • FieldUserRenderer uses email prop for GetPropertiesFor #84
  • Fixed issue in single selection mode when all group items were selected in the ListView when a user clicked on the group header #86
  • PropertyFieldPeoplePicker validation error does not clear as expected #68

Community list formatting definitions

SharePoint list formatting capability was released for First Release customers during October 2017. As part of the availability, we also announced the availability of open source repository for sharing different column formatting definitions. Since we will be releasing also new view formatting capability soon, the repository has been renamed as sp-dev-list-formatting as it will be containing both view and column formatting samples.

  • Updates to date-range-rag sample, which shows how to create red-amber-green bars based on date ranges

Community Site Designs and Site Scripts

SharePoint Site Designs and Site Scripts has been released for production usage during March 2018. As part of the availability, we also announced the availability of open source repository for sharing different Site Designs and Site Scripts. Following lists the changes in the Site Design and Site Script area.

  • No new Site Designs or Site Scripts during June, but some adjustments and improvements on existing ones.

Office 365 CLI

Office 365 CLI was released in November 2017. This is an open source tool which enables you to controls tenant level properties in SharePoint Online or in Office 365.

v1.4.0 release available with following changes

Added

Changes

  • refactored to return a non-zero error code on error solving #468
  • fixed adding an item to list referenced by id solving #473
  • added support for upgrading projects built using SharePoint Framework v1.4.0 #478
  • added support for upgrading projects built using SharePoint Framework v1.3.4 #479
  • added support for upgrading projects built using SharePoint Framework v1.3.2 #481
  • added support for upgrading projects built using SharePoint Framework v1.3.1 #482
  • added support for upgrading projects built using SharePoint Framework v1.3.0 #483
  • added support for upgrading projects built using SharePoint Framework v1.2.0 #484
  • clarified usage of the spo file get command #497
  • added support for upgrading projects built using SharePoint Framework v1.5.0 #505

PnP CSOM Core and Provisioning Engine

PnP CSOM Core component is a wrapper on top of native SharePoint CSOM and REST API, which simplifies complex scenarios with remote APIs, one of the example is the PnP Provisioning Engine for remote templates. The first version of the PnP remote provisioning engine was released with the May 2015 release. This list contains the main updates in this release:

Added

  • Information management async extension methods #1843 [baywet]
  • TimerJob AppOnly authentication in High Trust context #1808 [ypcode]

Changed

  • Added PowerApps client-side web part type
  • Fix NullReferenceException when parsing client-side page header html #1821 [SchauDK]
  • Changed multi lookup field provisioning to also handle list url in List #1822 [cebud]
  • Don’t wrap client-side text in P if it already was done as part of the provided text
  • Added tokenization of client-side page header image URL
  • Fix #1810 ContentTypeBinding with lowercase ContentTypeID [TeodoraI]
  • Fix list attribute for lookup fields #1826 [sebastianmattar]

See also https://testautomation.sharepointpnp.com for day-to-day results and executed tests.

PnP JavaScript Core Library – PnPjs

Latest update is version 1.1.2 on the PnPJs library. Here’s are the latest changes since the previous monthly release. Notice that if you are using old pnp-js-core, we highly recommend upgrading to the new PnPjs library.

Added

  • tooling: Setup Travis CI to process PRs and merges [PR]
  • tooling: Added support for –verbose flag when using gulp test
  • documentation: Added article on deployment listing cdnjs urls [PR]
  • @pnp/nodejs: Support for local cloud authentication (China, Germany, US Gov) [PR]

Changed

  • tooling: Updated travis test to use a custom mocha impl allowing for ignore timeouts [PR]
  • @pnp/pnpjs: Updated global variable name from $pnp -> pnp, docs updated to reflect change [PR]
  • @pnp/common: dateAdd timespan parameter now bound to custom string enumeration type
  • documentation: Styling changes [PR]
  • @pnp/nodejs: SPFetchClient contructor realm parameter is now fifth [PR]
  • @pnp/sp: Added View, Views, and ViewFields to the exports [PR]

Fixed

  • @pnp/sp: Fixed bug where parsing ClientSideText webpart from existing page included extra “” [PR]
  • @pnp/sp: Changed return type of getPropertiesFor to be any instead of any[] [PR]
  • @pnp/sp: Fixed issue with decoding escaped json in ClientSidePage [PR] [PR]

This is a similar effort as what PnP initiative previously has done with the PnP CSOM Core Component together with the community.

PnP PowerShell

PnP PowerShell providers more than three hundred additional PowerShell cmdlets, which can be used to manipulate content in SharePoint Online and in on-premises (SP2013, SP2016). These cmdlets are additive for SharePoint Online management shell, which concentrate more on the administrative tasks with SharePoint Online. PnP PowerShell uses the PnP CSOM extension under the covers to automate the needed remote operations.

Here are the latest changes in the PnP PowerShell

Added

  • Added IncludeClassification to Get-PnPUnifiedGroup
  • Updated documentation for Get-PnPSearchCrawlLog
  • Added -NewFileName to Add-PnPFile cmdlet

Other

  • Updated automatically generated PnP PowerShell cmdlet documentation at docs.microsoft.com

PnP sample library

Here are updates across the PnP code sample library by the community on the code and documentation, which is a great way to contribute as well.

  • Updates to o365.Modern.Provisioning solution which shows how to build provisioning automation with Microsoft Bot Framework, Microsoft Flow, and Azure Function
  • Updates to Visual Studio extension for SharePoint Framework to support SharePoint Framework 1.5.1
  • SharePoint.UIExperience.Scanner v1.7 switched to use the latest CSOM version + small improvements in the Excel dashboard template
  • Lot’s of improvements in the SharePoint Modernization Framework which can be used to transform classic wiki and web part pages to client-side modern pages:
    • Page title handling got improved
    • Documentation for functions and selectors is now autogenerated
    • Improved handling of BR tags
    • Support for having text before and after the web part but inside the div surrounding the web part
    • Theme colors are transformed now
    • Source page item-level permissions are copied to the target page (can be optionally turned off)
    • Improved reliability in handling image URL’s outside of the current web
    • Fixed layout transformation for HeaderRightColumnBody and HeaderLeftColumnBody web part page layouts
    • Fixed “duplicate key” issue when transforming multiple pages in sequence
    • Fixed ListId datatype in model
    • A calendar web part is now transformed to the Events web part
    • Tasks web part is not transformed anymore
    • Correctly identify a discussion board
  • SharePoint.SiteColProvisioning.Configuration script updated with SharePoint 2019 support and notes

SharePoint Dev articles

SharePoint Dev articles are surfaced currently in docs.microsoft.com/en-us/sharepoint/dev. ´Since the last release, we have now merged also SharePoint PnP Solution guidance to docs.microsoft.com platform, so you’ll only have one location to follow all relevant SharePoint Dev documentation and guidance. You can provide contributions to these documents by submitting documentation improvements using GitHub tooling. All of the SharePoint Dev docs are stored and surfaced from the sp-dev-docs repository.

Here are new/updated articles on the SharePoint Development.

PnP Guidance videos

You can find all SharePoint Dev videos on our YouTube Channel at http://aka.ms/sppnp-videos. This location contains already a significant amount of detailed training material, demo videos, and community call recordings.

Key contributors to the July 2018 update

Here’s the list of active contributors (in alphabetical order) since last release details in SharePoint Dev repositories or community channels. PnP is really about building tooling and knowledge together with the community for the community, so your contributions are highly valued across the Office 365 customers, partners and obviously also at Microsoft.

Thank you for your assistance and contributions on the behalf of the community. You are making a difference!

Companies: Here’s the companies, which provided support for PnP initiative for this month by allowing their employees working for the benefit of others in the PnP initiative. There were also people who contributed from other companies during last month, but we did not get their logos and approval to show them in time for these communications. If you still want your logo for this month’s release, please let us know and share the logo with us. Thx.

2toLead
aequos
Arvo Systems
Catapult Systems
ClearPeople
Content and Code
CPS
DMI
piasys
 Puzzlepart
 onebit software
 Rapid Circle
 rencore
 SharePointalist
Sogeti
SoSP
 Stefan Bauer
Valo
Voitanos
WorkPoint A/S
Wortell

Microsoft people: Here’s the list of Microsoft people who have been closely involved with the PnP work during last month.

Next steps

  • July 2018 monthly community call is on Tuesday 10th of July at 8 AM PST / 5 PM CEST / 4 PM GMT for latest release details with demos – Download recurrent invite to monthly community call with a detailed schedule for your time zone from http://aka.ms/sppnp-call.

Learn, Reuse, Share - aka.ms/sppnp

“Sharing is caring”


SharePoint Team, Microsoft – 9th of July 2018

Feedback usabilla icon