@milkdown-lab/plugin-split-editing
v1.3.1
Published
The plugin adds split editing view to milkdown
Downloads
645
Readme
@milkdown-lab/plugin-split-editing
Plugin add split editing view
or saying two-columns editing view
, you can edit each pane individually. Both panes have synced content.
That raw content view editor is render by codemirror
Preview
Usage
pnpm add @milkdown-lab/plugin-split-editing
import { splitEditing } from '@milkdown-lab/plugin-split-editing'
// ...
const editor = await Editor.make()
.config(() => {
ctx.set(rootCtx, document.querySelector('#app'))
})
.use(splitEditing)
.create()
Options
@milkdown-lab/plugin-split-editing
is now headless as same as milkdown
v7, see here for reason, so you need styling by yourself.
there are some selector necessary, for example:
.split-editor {
display: grid;
grid-template-columns: repeat(2, 1fr);
grid-template-rows: 1fr;
}
.split-editor:has(.milkdown-split-editor.hidden) {
grid-template-columns: repeat(1, 1fr);
}
.milkdown-split-editor.hidden {
display: none;
}
Adding custom attributes
You can also add attributes to split edit view element if you want to build your own style logic or using atom css library like tailwindcss.
import { splitEditing, splitEditingOptionsCtx } from '@milkdown-lab/plugin-split-editing'
// ...
const editor = await Editor.make()
.config(() => {
ctx.set(splitEditingOptionsCtx.key, {
wrapperAttributes: { class: 'grid grid-cols-2 grid-rows-none' },
attributes: { class: 'bg-#eee' },
hiddenAttribute: { class: 'hidden' },
hiddenWrapperAttributes: { class: 'grid-cols-none' },
})
ctx.set(rootCtx, document.querySelector('#app'))
})
.use(splitEditing)
.create()