mirror of
https://github.com/BookStackApp/BookStack.git
synced 2024-12-02 22:03:48 +08:00
f5e6f9574d
Markdown-related code was growing, representing half of app.js main bundle code while only being needed in one view/scenario. This extracts markdown related code to its own built file. Related to #4858
52 lines
1.3 KiB
JavaScript
52 lines
1.3 KiB
JavaScript
import {Markdown} from './markdown';
|
|
import {Display} from './display';
|
|
import {Actions} from './actions';
|
|
import {Settings} from './settings';
|
|
import {listen} from './common-events';
|
|
import {init as initCodemirror} from './codemirror';
|
|
|
|
/**
|
|
* Initiate a new markdown editor instance.
|
|
* @param {MarkdownEditorConfig} config
|
|
* @returns {Promise<MarkdownEditor>}
|
|
*/
|
|
export async function init(config) {
|
|
/**
|
|
* @type {MarkdownEditor}
|
|
*/
|
|
const editor = {
|
|
config,
|
|
markdown: new Markdown(),
|
|
settings: new Settings(config.settingInputs),
|
|
};
|
|
|
|
editor.actions = new Actions(editor);
|
|
editor.display = new Display(editor);
|
|
editor.cm = await initCodemirror(editor);
|
|
|
|
listen(editor);
|
|
|
|
return editor;
|
|
}
|
|
|
|
/**
|
|
* @typedef MarkdownEditorConfig
|
|
* @property {String} pageId
|
|
* @property {Element} container
|
|
* @property {Element} displayEl
|
|
* @property {HTMLTextAreaElement} inputEl
|
|
* @property {String} drawioUrl
|
|
* @property {HTMLInputElement[]} settingInputs
|
|
* @property {Object<String, String>} text
|
|
*/
|
|
|
|
/**
|
|
* @typedef MarkdownEditor
|
|
* @property {MarkdownEditorConfig} config
|
|
* @property {Display} display
|
|
* @property {Markdown} markdown
|
|
* @property {Actions} actions
|
|
* @property {EditorView} cm
|
|
* @property {Settings} settings
|
|
*/
|