Skip to content

chanm003/spfx2016

Repository files navigation

spfx2016

SPFx sample app that targets SP2016 on-premise environment. Serves as guidance and how-to for common operations (create, read, update, delete) of list items.

Screenshots

Once provisioned, this app provisions a single SharePoint list.

Site Contents

Query all list items.

get all

Clicking on "Avery Stewart" below creates a new list item.

contacts

Query for a single list item.

chat

Update a single list item.

update1

Update a single list item again.

update2

Query all list tiems.

get all

Setting up Windows Machine for SPFx Development

  1. Install code editor VSCode
  2. Install NodeJS NodeJS
  3. Install Git Git
  4. Install Node Version Manager NVM
  5. Install required tools from npm
nvm install 10.20.1
nvm use 10.20.1
npm install -g [email protected]
npm install -g [email protected]
npm install -g @microsoft/[email protected]
npm install -g rimraf

Get Source Code

cd ~/Desktop
git clone https://github.com/chanm003/spfx2016.git
cd spfx2016
npm install

Cache SPO credentials for Proxy

The following steps need to be performed when you first clone the repository onto your local machine or whenever the password to your real SharePoint environment expires.

  1. Cache credentials
    cd ~/Desktop/spfx2016
    rimraf .\config\private.json && npm run proxy
    
  2. When prompted provide your credentials
    SharePoint URL https://chanm003.sharepoint.com
    Authentication strategy User credentials (SAML/ADFS)
    User name [email protected]
    Password *************
    
  3. Verify private.json is generated
    • This file is in the config directory.
    • This file stores credentials in an encrypted manner.
    • This file is NEVER checked into source control.
  4. Verify proxy server is returning the same XML data as your real SPO environment. Below screenshots show requests to /_api/web endpoint using BOTH the proxy running on localhost:8080 and the real SPO endpoint (SharePoint URL you entered on Step 2) Proxy Server
  5. Repeat steps 1-4 as necessary if you receive the following authentication error. Below screenshot shows error message when you enter invalid username/credentials. Proxy Server
  6. Hit Ctrl+C to quit

Manually create a list called "Chats" in SPO (DEV environment)

Update the webRelativeUrl property accordingly inside of settings.ts

schema

Run the App Locally during DEV

cd ~/Desktop/spfx2016
npm run bump:typescript
npm run serve

Installing the App on SP2016

Pre-requisites, obtain some URLs from your SP2016 STAGING/PROD Environment

URL Example Purpose
Document library (or subfolder) http://socafrica.westeurope.cloudapp.azure.com/SPFxBundles/sp-2016 This is where you will upload your JSON, bundled .JS, images
App Catalog http://socafrica.westeurope.cloudapp.azure.com/sites/appcatalog This is where you will upload your .sppkg

Get Source Code

cd ~/Desktop
git clone https://github.com/chanm003/spfx2016.git

Edit CDN Base Path to match URL of document library (or subfolder) that you created

code ~/Desktop/spfx2016/config/write-manifests.json

During local DEV, we normally run the gulp serve. This will start up a server on your DEV box and serve your JSON/Javascript from http://localhost:4321/temp/deploy. Prior to deployment, we need to change this. Using URLs obtained from previous section, we would use http://socafrica.westeurope.cloudapp.azure.com/SPFxBundles/sp-2016

Build source code

cd ~/Desktop/spfx2016
nvm use 10.20.1
npm install
npm run bump:typescript
gulp build
gulp bundle --ship
gulp package-solution --ship

Upload Build Artifacts to SP2016

Source Destination
~/Desktop/spfx2016/sharepoint/solution/sp-2016.sppkg App Catalog
~/Desktop/spfx2016/temp/deploy/* Document library/folder that you created

Go to Site Contents to Add your App, then Create Site Page, Insert Web Part on the Site Page

TBD

Making Changes to Source Code, Running and Testing locally

TBD

Configuring SP2016 Farm to Support SPFX

This section documents the steps for enabling SPFx development at the farm-level. Some or all of these requirements may have already been met by enabling the farm to support Add-Ins (i.e. App Catalog already exists). Only Farm Administrators will have permissions to perform the steps in this section.

Install Feature Pack 2

  1. Download and install KB4011127
  2. Download and install KB4011112

Double click to begin install. Installer will detect and automatically exit if already installed. If one or both installation processes are required, be sure to adhere to best practices and run the SharePoint Products Configuration Wizard.

Setup an App Catalog

Two service applications are required.

farm1

Ensure service application is associated with web application.

farm2

Configure prefix for Apps.

farm3

Provision App Catalog.

farm4

Remove restriction that blocks .JSON files.

farm5

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published