Ghost/ghost/admin/lib/koenig-editor/addon/utils/create-component-card.js

48 lines
1.4 KiB
JavaScript
Raw Normal View History

import {
ADD_CARD_HOOK,
REMOVE_CARD_HOOK
} from '../components/koenig-editor';
import {assign} from '@ember/polyfills';
const RENDER_TYPE = 'dom';
const DEFAULT_KOENIG_OPTIONS = {
hasEditMode: true,
selectAfterInsert: true
};
function renderFallback(doc) {
let element = doc.createElement('div');
let text = doc.createTextNode('[placeholder for Ember component card]');
element.appendChild(text);
return element;
}
// sets up boilerplate for an Ember component card
export default function createComponentCard(name, koenigOptions, doc = window.document) {
return {
name,
type: RENDER_TYPE,
// Called when the card is added to a mobiledoc document.
// The `cardArg.options` object contains the methods that were set up
// on the `cardOptions` property of the editor in `{{koenig-editor}}`,
// by calling those hooks we set up everything needed for rendering
// ember components as cards
render(cardArg) {
let {env, options} = cardArg;
let kgOptions = assign({}, DEFAULT_KOENIG_OPTIONS, koenigOptions);
if (!options[ADD_CARD_HOOK]) {
return renderFallback(doc);
}
let {card, element} = options[ADD_CARD_HOOK](cardArg, kgOptions);
let {onTeardown} = env;
onTeardown(() => options[REMOVE_CARD_HOOK](card));
return element;
}
};
}