mirror of https://github.com/vector-im/riot-web
				
				
				
			Merge pull request #6161 from matrix-org/dbkr/widget_load_error
Better handling for widgets that fail to loadpull/21833/head
						commit
						399be4fa5d
					
				|  | @ -47,9 +47,14 @@ export default class AppTile extends React.Component { | ||||||
| 
 | 
 | ||||||
|         // The key used for PersistedElement
 |         // The key used for PersistedElement
 | ||||||
|         this._persistKey = getPersistKey(this.props.app.id); |         this._persistKey = getPersistKey(this.props.app.id); | ||||||
|         this._sgWidget = new StopGapWidget(this.props); |         try { | ||||||
|         this._sgWidget.on("preparing", this._onWidgetPrepared); |             this._sgWidget = new StopGapWidget(this.props); | ||||||
|         this._sgWidget.on("ready", this._onWidgetReady); |             this._sgWidget.on("preparing", this._onWidgetPrepared); | ||||||
|  |             this._sgWidget.on("ready", this._onWidgetReady); | ||||||
|  |         } catch (e) { | ||||||
|  |             console.log("Failed to construct widget", e); | ||||||
|  |             this._sgWidget = null; | ||||||
|  |         } | ||||||
|         this.iframe = null; // ref to the iframe (callback style)
 |         this.iframe = null; // ref to the iframe (callback style)
 | ||||||
| 
 | 
 | ||||||
|         this.state = this._getNewState(props); |         this.state = this._getNewState(props); | ||||||
|  | @ -97,7 +102,7 @@ export default class AppTile extends React.Component { | ||||||
|             // Force the widget to be non-persistent (able to be deleted/forgotten)
 |             // Force the widget to be non-persistent (able to be deleted/forgotten)
 | ||||||
|             ActiveWidgetStore.destroyPersistentWidget(this.props.app.id); |             ActiveWidgetStore.destroyPersistentWidget(this.props.app.id); | ||||||
|             PersistedElement.destroyElement(this._persistKey); |             PersistedElement.destroyElement(this._persistKey); | ||||||
|             this._sgWidget.stop(); |             if (this._sgWidget) this._sgWidget.stop(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|         this.setState({ hasPermissionToLoad }); |         this.setState({ hasPermissionToLoad }); | ||||||
|  | @ -117,7 +122,7 @@ export default class AppTile extends React.Component { | ||||||
| 
 | 
 | ||||||
|     componentDidMount() { |     componentDidMount() { | ||||||
|         // Only fetch IM token on mount if we're showing and have permission to load
 |         // Only fetch IM token on mount if we're showing and have permission to load
 | ||||||
|         if (this.state.hasPermissionToLoad) { |         if (this._sgWidget && this.state.hasPermissionToLoad) { | ||||||
|             this._startWidget(); |             this._startWidget(); | ||||||
|         } |         } | ||||||
| 
 | 
 | ||||||
|  | @ -146,10 +151,15 @@ export default class AppTile extends React.Component { | ||||||
|         if (this._sgWidget) { |         if (this._sgWidget) { | ||||||
|             this._sgWidget.stop(); |             this._sgWidget.stop(); | ||||||
|         } |         } | ||||||
|         this._sgWidget = new StopGapWidget(newProps); |         try { | ||||||
|         this._sgWidget.on("preparing", this._onWidgetPrepared); |             this._sgWidget = new StopGapWidget(newProps); | ||||||
|         this._sgWidget.on("ready", this._onWidgetReady); |             this._sgWidget.on("preparing", this._onWidgetPrepared); | ||||||
|         this._startWidget(); |             this._sgWidget.on("ready", this._onWidgetReady); | ||||||
|  |             this._startWidget(); | ||||||
|  |         } catch (e) { | ||||||
|  |             console.log("Failed to construct widget", e); | ||||||
|  |             this._sgWidget = null; | ||||||
|  |         } | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     _startWidget() { |     _startWidget() { | ||||||
|  | @ -161,7 +171,7 @@ export default class AppTile extends React.Component { | ||||||
|     _iframeRefChange = (ref) => { |     _iframeRefChange = (ref) => { | ||||||
|         this.iframe = ref; |         this.iframe = ref; | ||||||
|         if (ref) { |         if (ref) { | ||||||
|             this._sgWidget.start(ref); |             if (this._sgWidget) this._sgWidget.start(ref); | ||||||
|         } else { |         } else { | ||||||
|             this._resetWidget(this.props); |             this._resetWidget(this.props); | ||||||
|         } |         } | ||||||
|  | @ -209,7 +219,7 @@ export default class AppTile extends React.Component { | ||||||
|         // Delete the widget from the persisted store for good measure.
 |         // Delete the widget from the persisted store for good measure.
 | ||||||
|         PersistedElement.destroyElement(this._persistKey); |         PersistedElement.destroyElement(this._persistKey); | ||||||
| 
 | 
 | ||||||
|         this._sgWidget.stop({forceDestroy: true}); |         if (this._sgWidget) this._sgWidget.stop({forceDestroy: true}); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     _onWidgetPrepared = () => { |     _onWidgetPrepared = () => { | ||||||
|  | @ -340,7 +350,13 @@ export default class AppTile extends React.Component { | ||||||
|                 <Spinner message={_t("Loading...")} /> |                 <Spinner message={_t("Loading...")} /> | ||||||
|             </div> |             </div> | ||||||
|         ); |         ); | ||||||
|         if (!this.state.hasPermissionToLoad) { |         if (this._sgWidget === null) { | ||||||
|  |             appTileBody = ( | ||||||
|  |                 <div className={appTileBodyClass} style={appTileBodyStyles}> | ||||||
|  |                     <AppWarning errorMsg={_t("Error loading Widget")} /> | ||||||
|  |                 </div> | ||||||
|  |             ); | ||||||
|  |         } else if (!this.state.hasPermissionToLoad) { | ||||||
|             // only possible for room widgets, can assert this.props.room here
 |             // only possible for room widgets, can assert this.props.room here
 | ||||||
|             const isEncrypted = MatrixClientPeg.get().isRoomEncrypted(this.props.room.roomId); |             const isEncrypted = MatrixClientPeg.get().isRoomEncrypted(this.props.room.roomId); | ||||||
|             appTileBody = ( |             appTileBody = ( | ||||||
|  | @ -364,7 +380,7 @@ export default class AppTile extends React.Component { | ||||||
|             if (this.isMixedContent()) { |             if (this.isMixedContent()) { | ||||||
|                 appTileBody = ( |                 appTileBody = ( | ||||||
|                     <div className={appTileBodyClass} style={appTileBodyStyles}> |                     <div className={appTileBodyClass} style={appTileBodyStyles}> | ||||||
|                         <AppWarning errorMsg="Error - Mixed content" /> |                         <AppWarning errorMsg={_t("Error - Mixed content")} /> | ||||||
|                     </div> |                     </div> | ||||||
|                 ); |                 ); | ||||||
|             } else { |             } else { | ||||||
|  |  | ||||||
|  | @ -1925,6 +1925,8 @@ | ||||||
|     "Widgets do not use message encryption.": "Widgets do not use message encryption.", |     "Widgets do not use message encryption.": "Widgets do not use message encryption.", | ||||||
|     "Widget added by": "Widget added by", |     "Widget added by": "Widget added by", | ||||||
|     "This widget may use cookies.": "This widget may use cookies.", |     "This widget may use cookies.": "This widget may use cookies.", | ||||||
|  |     "Error loading Widget": "Error loading Widget", | ||||||
|  |     "Error - Mixed content": "Error - Mixed content", | ||||||
|     "Popout widget": "Popout widget", |     "Popout widget": "Popout widget", | ||||||
|     "Use the <a>Desktop app</a> to see all encrypted files": "Use the <a>Desktop app</a> to see all encrypted files", |     "Use the <a>Desktop app</a> to see all encrypted files": "Use the <a>Desktop app</a> to see all encrypted files", | ||||||
|     "Use the <a>Desktop app</a> to search encrypted messages": "Use the <a>Desktop app</a> to search encrypted messages", |     "Use the <a>Desktop app</a> to search encrypted messages": "Use the <a>Desktop app</a> to search encrypted messages", | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue
	
	 David Baker
						David Baker