do not show placeholder if non editable

This commit is contained in:
Philipp Kühn 2019-02-06 11:28:40 +01:00
parent 44525063bc
commit 9b90d6437e
3 changed files with 17 additions and 2 deletions

View File

@ -25,6 +25,7 @@ export default {
new Placeholder({
emptyClass: 'is-empty',
emptyNodeText: 'Write something …',
showOnlyWhenEditable: true,
}),
],
}),

View File

@ -11,6 +11,7 @@ export default class Placeholder extends Extension {
return {
emptyNodeClass: 'is-empty',
emptyNodeText: 'Write something...',
showOnlyWhenEditable: true,
}
}
@ -18,7 +19,15 @@ export default class Placeholder extends Extension {
return [
new Plugin({
props: {
decorations: ({ doc }) => {
decorations: ({ doc, plugins }) => {
const editablePlugin = plugins.find(plugin => plugin.key.startsWith('editable$'))
const editable = editablePlugin.props.editable()
const active = editable || !this.options.showOnlyWhenEditable
if (!active) {
return false
}
const decorations = []
const completelyEmpty = doc.textContent === '' && doc.childCount <= 1 && doc.content.size <= 2

View File

@ -1,4 +1,4 @@
import { EditorState, Plugin } from 'prosemirror-state'
import { EditorState, Plugin, PluginKey } from 'prosemirror-state'
import { EditorView } from 'prosemirror-view'
import { Schema, DOMParser, DOMSerializer } from 'prosemirror-model'
import { dropCursor } from 'prosemirror-dropcursor'
@ -162,8 +162,13 @@ export default class Editor {
dropCursor(this.options.dropCursor),
gapCursor(),
new Plugin({
key: new PluginKey('editable'),
props: {
editable: () => this.options.editable,
},
}),
new Plugin({
props: {
attributes: {
tabindex: 0,
},