IE11 Compatible. Testing and working with IE11 (#203)

* update react-taxonomypicker styles

* react async await PnP JS Core with Logging first release

* update react

* update license

* Establish SPFx Context

* IE11 compatible
This commit is contained in:
José Quinto 2017-05-10 02:28:50 +01:00 committed by Vesa Juvonen
parent f0126843a6
commit f0202c5c7b
3 changed files with 76 additions and 32 deletions

View File

@ -51,6 +51,7 @@ https://your-domain.sharepoint.com/_layouts/15/workbench.aspx
## Features ## Features
- [Async / Await functionality working with PnP JS sample](https://github.com/jquintozamora/spfx-react-async-await-sp-pnp-js/blob/master/src/webparts/asyncAwaitPnPJs/components/AsyncAwaitPnPJs.tsx#L93) - [Async / Await functionality working with PnP JS sample](https://github.com/jquintozamora/spfx-react-async-await-sp-pnp-js/blob/master/src/webparts/asyncAwaitPnPJs/components/AsyncAwaitPnPJs.tsx#L93)
- Tested and working on IE11 (as TypeScript config provides Promise polyfill)
- React Container for the initial load. [Smart Component](https://github.com/jquintozamora/spfx-react-async-await-sp-pnp-js/blob/master/src/webparts/asyncAwaitPnPJs/components/IAsyncAwaitPnPJsState.ts) - React Container for the initial load. [Smart Component](https://github.com/jquintozamora/spfx-react-async-await-sp-pnp-js/blob/master/src/webparts/asyncAwaitPnPJs/components/IAsyncAwaitPnPJsState.ts)
- [Interface best practices](https://github.com/jquintozamora/spfx-react-async-await-sp-pnp-js/tree/master/src/webparts/asyncAwaitPnPJs/interfaces) - [Interface best practices](https://github.com/jquintozamora/spfx-react-async-await-sp-pnp-js/tree/master/src/webparts/asyncAwaitPnPJs/interfaces)
- [PnP JS and SPFx Logging systems integration](https://blog.josequinto.com/2017/04/30/how-to-integrate-pnp-js-core-and-sharepoint-framework-logging-systems) - [PnP JS and SPFx Logging systems integration](https://blog.josequinto.com/2017/04/30/how-to-integrate-pnp-js-core-and-sharepoint-framework-logging-systems)

View File

@ -12,8 +12,20 @@ import AsyncAwaitPnPJs from './components/AsyncAwaitPnPJs';
import { IAsyncAwaitPnPJsProps } from './components/IAsyncAwaitPnPJsProps'; import { IAsyncAwaitPnPJsProps } from './components/IAsyncAwaitPnPJsProps';
import { IAsyncAwaitPnPJsWebPartProps } from './IAsyncAwaitPnPJsWebPartProps'; import { IAsyncAwaitPnPJsWebPartProps } from './IAsyncAwaitPnPJsWebPartProps';
// import pnp from "sp-pnp-js";
export default class AsyncAwaitPnPJsWebPart extends BaseClientSideWebPart<IAsyncAwaitPnPJsWebPartProps> { export default class AsyncAwaitPnPJsWebPart extends BaseClientSideWebPart<IAsyncAwaitPnPJsWebPartProps> {
// // https://github.com/SharePoint/PnP-JS-Core/wiki/Using-sp-pnp-js-in-SharePoint-Framework
// public onInit(): Promise<void> {
// return super.onInit().then(_ => {
// // establish SPFx context
// pnp.setup({
// spfxContext: this.context
// });
// });
// }
public render(): void { public render(): void {
const element: React.ReactElement<IAsyncAwaitPnPJsProps > = React.createElement( const element: React.ReactElement<IAsyncAwaitPnPJsProps > = React.createElement(
AsyncAwaitPnPJs, AsyncAwaitPnPJs,

View File

@ -46,9 +46,12 @@ export default class AsyncAwaitPnPJs extends React.Component<IAsyncAwaitPnPJsPro
: 0; : 0;
return ( return (
<div className={styles.container}> <div className={styles.container}>
<div className={`ms-Grid-row ms-bgColor-themeDark ms-fontColor-white ${styles.row}`}> <div className={"ms-Grid-row ms-bgColor-themeDark ms-fontColor-white " + styles.row"}>
<div className="ms-Grid-col ms-u-lg10 ms-u-xl8 ms-u-xlPush2 ms-u-lgPush1"> <div className="ms-Grid-col ms-u-lg10 ms-u-xl8 ms-u-xlPush2 ms-u-lgPush1">
<span className="ms-font-xl ms-fontColor-white">Welcome to SharePoint Async Await SP PnP JS Demo!</span> <span className="ms-font-xl ms-fontColor-white">Welcome to SharePoint Async Await SP PnP JS Demo!</span>
<div>
{this._gerErrors()}
</div>
<p className="ms-font-l ms-fontColor-white">List of documents:</p> <p className="ms-font-l ms-fontColor-white">List of documents:</p>
<div> <div>
<div className={styles.row}> <div className={styles.row}>
@ -78,6 +81,51 @@ export default class AsyncAwaitPnPJs extends React.Component<IAsyncAwaitPnPJsPro
); );
} }
private _enableLogging() {
////////////////////////////////////////////////////////////////////////
// enable Logging system
////////////////////////////////////////////////////////////////////////
// we will integrate PnP JS Logging System with SPFx Logging system
// 1. Logger object => PnP JS Logger
// https://github.com/SharePoint/PnP-JS-Core/wiki/Working-With:-Logging
// 2. Log object => SPFx Logger
// https://github.com/SharePoint/sp-dev-docs/wiki/Working-with-the-Logging-API
////////////////////////////////////////////////////////////////////////
// [PnP JS Logging] activate Info level
Logger.activeLogLevel = LogLevel.Info;
// [PnP JS Logging] create a custom FunctionListener to integrate PnP JS and SPFx Logging systems
const listener = new FunctionListener((entry: LogEntry) => {
// get React component name
const componentName: string = (this as any)._reactInternalInstance._currentElement.props.description;
// mapping betwween PnP JS Log types and SPFx logging methods
// instead of using switch we use object easy syntax
const logLevelConversion = { Verbose: "verbose", Info: "info", Warning: "warn", Error: "error" };
// create Message. Two importante notes here:
// 1. Use JSON.stringify to output everything. It´s helpful when some internal exception comes thru.
// 2. Use JavaScript´s Error constructor allows us to output more than 100 characters using SPFx logging
let formatedMessage;
if (entry.level === LogLevel.Error) {
formatedMessage = new Error(`Message: ${entry.message} Data: ${JSON.stringify(entry.data)}`);
// formatedMessage = `Message: ${entry.message} Data: ${JSON.stringify(entry.data)}`;
} else {
formatedMessage = `Message: ${entry.message} Data: ${JSON.stringify(entry.data)}`;
}
// [SPFx Logging] Calculate method to invoke verbose, info, warn or error
const method = logLevelConversion[LogLevel[entry.level]];
// [SPFx Logging] Call SPFx Logging system with the message received from PnP JS Logging
Log[method](componentName, formatedMessage);
});
// [PnP JS Logging] Once create the custom listerner we should subscribe to it
Logger.subscribe(listener);
}
// Async functions were introduced with ES3/ES5 native support in TypeScript 2.1 // Async functions were introduced with ES3/ES5 native support in TypeScript 2.1
// https://blogs.msdn.microsoft.com/typescript/2016/12/07/announcing-typescript-2-1/ // https://blogs.msdn.microsoft.com/typescript/2016/12/07/announcing-typescript-2-1/
// Async function always return a Promise, on this scenario we return void Promise // Async function always return a Promise, on this scenario we return void Promise
@ -95,7 +143,7 @@ export default class AsyncAwaitPnPJs extends React.Component<IAsyncAwaitPnPJsPro
.items .items
.select("Title", "FileLeafRef") .select("Title", "FileLeafRef")
.expand("File/Length") .expand("File/Length")
.usingCaching() // .usingCaching()
.get(); .get();
// use map to convert IResponseItem[] into our internal object IFile[] // use map to convert IResponseItem[] into our internal object IFile[]
@ -116,35 +164,18 @@ export default class AsyncAwaitPnPJs extends React.Component<IAsyncAwaitPnPJsPro
} }
} }
private _enableLogging() { private _gerErrors() {
//////////////////////////////////////////////////////////////////////// return this.state.errors.length > 0
// enable Logging system ?
//////////////////////////////////////////////////////////////////////// <div style={{ color: "orangered" }} >
// we will integrate PnP JS Logging System with SPFx Logging system <div>Errors:</div>
// 1. Logger object => PnP JS Logger {
// https://github.com/SharePoint/PnP-JS-Core/wiki/Working-With:-Logging this.state.errors.map((item) => {
// 2. Log object => SPFx Logger return (<div>{JSON.stringify(item)}</div>);
// https://github.com/SharePoint/sp-dev-docs/wiki/Working-with-the-Logging-API })
//////////////////////////////////////////////////////////////////////// }
// [PnP JS Logging] activate Info level </div>
Logger.activeLogLevel = LogLevel.Info; : null
// [PnP JS Logging] create a custom FunctionListener to integrate PnP JS and SPFx Logging systems
let listener = new FunctionListener((entry: LogEntry) => {
// get React component name
const componentName: string = (this as any)._reactInternalInstance._currentElement.type.name;
// mapping betwween PnP JS Log types and SPFx logging methods
// instead of using switch we use object easy syntax
const logLevelConversion = { Verbose: "verbose", Info: "info", Warning: "warn", Error: "error" };
// create Message. Two importante notes here:
// 1. Use JSON.stringify to output everything. It´s helpful when some internal exception comes thru.
// 2. Use JavaScript´s Error constructor allows us to output more than 100 characters using SPFx logging
const formatedMessage: Error = new Error(`Message: ${entry.message} Data: ${JSON.stringify(entry.data)}`);
// [SPFx Logging] Calculate method to invoke verbose, info, warn or error
const method = logLevelConversion[LogLevel[entry.level]];
// [SPFx Logging] Call SPFx Logging system with the message received from PnP JS Logging
Log[method](componentName, formatedMessage);
});
// [PnP JS Logging] Once create the custom listerner we should subscribe to it
Logger.subscribe(listener);
} }
} }