mirror of
https://github.com/ueberdosis/tiptap.git
synced 2025-01-07 20:08:06 +08:00
remove editable prop, fix #223
This commit is contained in:
parent
de624c1d5f
commit
5c81cddff9
@ -417,10 +417,10 @@ export default class IframeNode extends Node {
|
|||||||
// there are some props available
|
// there are some props available
|
||||||
// `node` is a Prosemirror Node Object
|
// `node` is a Prosemirror Node Object
|
||||||
// `updateAttrs` is a function to update attributes defined in `schema`
|
// `updateAttrs` is a function to update attributes defined in `schema`
|
||||||
// `editable` is the global editor prop whether the content can be edited
|
// `view` is the ProseMirror view instance
|
||||||
// `options` is an array of your extension options
|
// `options` is an array of your extension options
|
||||||
// `selected`
|
// `selected`
|
||||||
props: ['node', 'updateAttrs', 'editable'],
|
props: ['node', 'updateAttrs', 'view'],
|
||||||
computed: {
|
computed: {
|
||||||
src: {
|
src: {
|
||||||
get() {
|
get() {
|
||||||
@ -437,7 +437,7 @@ export default class IframeNode extends Node {
|
|||||||
template: `
|
template: `
|
||||||
<div class="iframe">
|
<div class="iframe">
|
||||||
<iframe class="iframe__embed" :src="src"></iframe>
|
<iframe class="iframe__embed" :src="src"></iframe>
|
||||||
<input class="iframe__input" type="text" v-model="src" v-if="editable" />
|
<input class="iframe__input" type="text" v-model="src" v-if="view.editable" />
|
||||||
</div>
|
</div>
|
||||||
`,
|
`,
|
||||||
}
|
}
|
||||||
|
@ -15,7 +15,7 @@ export default class TodoItem extends Node {
|
|||||||
|
|
||||||
get view() {
|
get view() {
|
||||||
return {
|
return {
|
||||||
props: ['node', 'updateAttrs', 'editable'],
|
props: ['node', 'updateAttrs', 'view'],
|
||||||
methods: {
|
methods: {
|
||||||
onChange() {
|
onChange() {
|
||||||
this.updateAttrs({
|
this.updateAttrs({
|
||||||
@ -26,7 +26,7 @@ export default class TodoItem extends Node {
|
|||||||
template: `
|
template: `
|
||||||
<li :data-type="node.type.name" :data-done="node.attrs.done.toString()">
|
<li :data-type="node.type.name" :data-done="node.attrs.done.toString()">
|
||||||
<span class="todo-checkbox" contenteditable="false" @click="onChange"></span>
|
<span class="todo-checkbox" contenteditable="false" @click="onChange"></span>
|
||||||
<div class="todo-content" ref="content" :contenteditable="editable.toString()"></div>
|
<div class="todo-content" ref="content" :contenteditable="view.editable.toString()"></div>
|
||||||
</li>
|
</li>
|
||||||
`,
|
`,
|
||||||
}
|
}
|
||||||
|
@ -156,7 +156,6 @@ export default class Editor extends Emitter {
|
|||||||
return this.extensions.commands({
|
return this.extensions.commands({
|
||||||
schema: this.schema,
|
schema: this.schema,
|
||||||
view: this.view,
|
view: this.view,
|
||||||
editable: this.options.editable,
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -277,12 +276,11 @@ export default class Editor extends Emitter {
|
|||||||
...this.builtInExtensions,
|
...this.builtInExtensions,
|
||||||
...this.options.extensions,
|
...this.options.extensions,
|
||||||
],
|
],
|
||||||
editable: this.options.editable,
|
|
||||||
}),
|
}),
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
initNodeViews({ parent, extensions, editable }) {
|
initNodeViews({ parent, extensions }) {
|
||||||
return extensions
|
return extensions
|
||||||
.filter(extension => ['node', 'mark'].includes(extension.type))
|
.filter(extension => ['node', 'mark'].includes(extension.type))
|
||||||
.filter(extension => extension.view)
|
.filter(extension => extension.view)
|
||||||
@ -291,13 +289,13 @@ export default class Editor extends Emitter {
|
|||||||
const component = extension.view
|
const component = extension.view
|
||||||
|
|
||||||
return new ComponentView(component, {
|
return new ComponentView(component, {
|
||||||
|
editor: this,
|
||||||
extension,
|
extension,
|
||||||
parent,
|
parent,
|
||||||
node,
|
node,
|
||||||
view,
|
view,
|
||||||
getPos,
|
getPos,
|
||||||
decorations,
|
decorations,
|
||||||
editable,
|
|
||||||
})
|
})
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -5,48 +5,46 @@ import { getMarkRange } from 'tiptap-utils'
|
|||||||
export default class ComponentView {
|
export default class ComponentView {
|
||||||
|
|
||||||
constructor(component, {
|
constructor(component, {
|
||||||
|
editor,
|
||||||
extension,
|
extension,
|
||||||
parent,
|
parent,
|
||||||
node,
|
node,
|
||||||
view,
|
view,
|
||||||
getPos,
|
|
||||||
decorations,
|
decorations,
|
||||||
editable,
|
getPos,
|
||||||
}) {
|
}) {
|
||||||
this.component = component
|
this.component = component
|
||||||
|
this.editor = editor
|
||||||
this.extension = extension
|
this.extension = extension
|
||||||
this.parent = parent
|
this.parent = parent
|
||||||
this.node = node
|
this.node = node
|
||||||
this.view = view
|
this.view = view
|
||||||
this.getPos = getPos
|
|
||||||
this.decorations = decorations
|
this.decorations = decorations
|
||||||
this.editable = editable
|
|
||||||
this.selected = false
|
|
||||||
this.isNode = !!this.node.marks
|
this.isNode = !!this.node.marks
|
||||||
this.isMark = !this.isNode
|
this.isMark = !this.isNode
|
||||||
|
this.getPos = this.isMark ? this.getMarkPos : getPos
|
||||||
this.dom = this.createDOM()
|
this.dom = this.createDOM()
|
||||||
this.contentDOM = this.vm.$refs.content
|
this.contentDOM = this.vm.$refs.content
|
||||||
|
|
||||||
if (this.isMark) {
|
|
||||||
this.getPos = this.getMarkPos
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
createDOM() {
|
createDOM() {
|
||||||
const Component = Vue.extend(this.component)
|
const Component = Vue.extend(this.component)
|
||||||
this.vm = new Component({
|
const props = {
|
||||||
parent: this.parent,
|
editor: this.editor,
|
||||||
propsData: {
|
|
||||||
node: this.node,
|
node: this.node,
|
||||||
view: this.view,
|
view: this.view,
|
||||||
getPos: () => this.getPos(),
|
getPos: () => this.getPos(),
|
||||||
decorations: this.decorations,
|
decorations: this.decorations,
|
||||||
editable: this.editable,
|
|
||||||
selected: false,
|
selected: false,
|
||||||
options: this.extension.options,
|
options: this.extension.options,
|
||||||
updateAttrs: attrs => this.updateAttrs(attrs),
|
updateAttrs: attrs => this.updateAttrs(attrs),
|
||||||
},
|
}
|
||||||
|
|
||||||
|
this.vm = new Component({
|
||||||
|
parent: this.parent,
|
||||||
|
propsData: props,
|
||||||
}).$mount()
|
}).$mount()
|
||||||
|
|
||||||
return this.vm.$el
|
return this.vm.$el
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -90,7 +88,7 @@ export default class ComponentView {
|
|||||||
}
|
}
|
||||||
|
|
||||||
updateAttrs(attrs) {
|
updateAttrs(attrs) {
|
||||||
if (!this.editable) {
|
if (!this.view.editable) {
|
||||||
return
|
return
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -134,7 +134,8 @@ export default class ExtensionManager {
|
|||||||
]), [])
|
]), [])
|
||||||
}
|
}
|
||||||
|
|
||||||
commands({ schema, view, editable }) {
|
commands({ schema, view }) {
|
||||||
|
|
||||||
return this.extensions
|
return this.extensions
|
||||||
.filter(extension => extension.commands)
|
.filter(extension => extension.commands)
|
||||||
.reduce((allCommands, extension) => {
|
.reduce((allCommands, extension) => {
|
||||||
@ -148,7 +149,7 @@ export default class ExtensionManager {
|
|||||||
})
|
})
|
||||||
|
|
||||||
const apply = (cb, attrs) => {
|
const apply = (cb, attrs) => {
|
||||||
if (!editable) {
|
if (!view.editable) {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
view.focus()
|
view.focus()
|
||||||
|
Loading…
Reference in New Issue
Block a user