mirror of
https://github.com/TryGhost/Ghost.git
synced 2024-12-23 10:53:34 +03:00
77fa4439de
no issue - allows specifying Koenig-specific card options via `createComponentCard` - respect `hasEditMode` and `selectAfterInsert` options when inserting cards via the (+) and / menus - do not select divider card after insertion
48 lines
1.4 KiB
JavaScript
48 lines
1.4 KiB
JavaScript
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;
|
|
}
|
|
};
|
|
}
|