import * as Sentry from '@sentry/browser'; import Component from '@glimmer/component'; import React, {Suspense} from 'react'; import {action} from '@ember/object'; import {inject as service} from '@ember/service'; class ErrorHandler extends React.Component { state = { hasError: false }; static getDerivedStateFromError() { return {hasError: true}; } render() { if (this.state.hasError) { return (

Loading has failed. Try refreshing the browser!

); } return this.props.children; } } const fetchKoenig = function () { let status = 'pending'; let response; const fetchPackage = async () => { if (window['@tryghost/koenig-lexical']) { return window['@tryghost/koenig-lexical']; } // the manual specification of the protocol in the import template string is // required to work around ember-auto-import complaining about an unknown dynamic import // during the build step const GhostAdmin = window.GhostAdmin || window.Ember.Namespace.NAMESPACES.find(ns => ns.name === 'ghost-admin'); const urlTemplate = GhostAdmin.__container__.lookup('service:config').get('editor.url'); const urlVersion = GhostAdmin.__container__.lookup('service:config').get('editor.version'); const url = new URL(urlTemplate.replace('{version}', urlVersion)); if (url.protocol === 'http:') { await import(`http://${url.host}${url.pathname}`); } else { await import(`https://${url.host}${url.pathname}`); } return window['@tryghost/koenig-lexical']; }; const suspender = fetchPackage().then( (res) => { status = 'success'; response = res; }, (err) => { status = 'error'; response = err; } ); const read = () => { switch (status) { case 'pending': throw suspender; case 'error': throw response; default: return response; } }; return {read}; }; const editorResource = fetchKoenig(); const KoenigComposer = (props) => { const {KoenigComposer: _KoenigComposer} = editorResource.read(); return <_KoenigComposer {...props} />; }; const KoenigEditor = (props) => { const {KoenigEditor: _KoenigEditor} = editorResource.read(); return <_KoenigEditor {...props} />; }; export default class KoenigLexicalEditor extends Component { @service config; @action onError(error) { // ensure we're still showing errors in development console.error(error); // eslint-disable-line if (this.config.get('sentry_dsn')) { Sentry.captureException(error, { tags: { lexical: true } }); } // don't rethrow, Lexical will attempt to gracefully recover } ReactComponent = () => { return (
Loading editor...

}>
); }; }