2021-04-17 06:25:04 +08:00
|
|
|
/// <reference types="cypress" />
|
|
|
|
|
2022-11-24 23:06:42 +08:00
|
|
|
import { Extension } from '@tiptap/core'
|
2021-04-17 06:25:04 +08:00
|
|
|
|
|
|
|
describe('extension options', () => {
|
2021-10-27 00:31:13 +08:00
|
|
|
it('should set options', () => {
|
|
|
|
const extension = Extension.create({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
foo: 1,
|
|
|
|
bar: 1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
expect(extension.options).to.deep.eq({
|
|
|
|
foo: 1,
|
|
|
|
bar: 1,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should pass through', () => {
|
|
|
|
const extension = Extension
|
|
|
|
.create({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
foo: 1,
|
|
|
|
bar: 1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
.extend()
|
|
|
|
.configure()
|
|
|
|
|
|
|
|
expect(extension.options).to.deep.eq({
|
|
|
|
foo: 1,
|
|
|
|
bar: 1,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should be configurable', () => {
|
|
|
|
const extension = Extension
|
|
|
|
.create({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
foo: 1,
|
|
|
|
bar: 1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
.configure({
|
|
|
|
bar: 2,
|
|
|
|
})
|
|
|
|
|
|
|
|
expect(extension.options).to.deep.eq({
|
|
|
|
foo: 1,
|
|
|
|
bar: 2,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should be extendable', () => {
|
|
|
|
const extension = Extension.create({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
foo: 1,
|
|
|
|
bar: 1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
const newExtension = extension.extend({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
...this.parent?.(),
|
|
|
|
baz: 1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
expect(newExtension.options).to.deep.eq({
|
|
|
|
foo: 1,
|
|
|
|
bar: 1,
|
|
|
|
baz: 1,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2024-05-14 20:45:03 +08:00
|
|
|
it('should be extendable multiple times', () => {
|
|
|
|
const extension = Extension.create({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
foo: 1,
|
|
|
|
bar: 1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
}).extend({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
...this.parent?.(),
|
|
|
|
baz: 1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
const newExtension = extension.extend({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
...this.parent?.(),
|
|
|
|
bax: 1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
expect(newExtension.options).to.deep.eq({
|
|
|
|
foo: 1,
|
|
|
|
bar: 1,
|
|
|
|
baz: 1,
|
|
|
|
bax: 1,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2021-10-27 00:31:13 +08:00
|
|
|
it('should be overwritable', () => {
|
|
|
|
const extension = Extension
|
|
|
|
.create({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
foo: 1,
|
|
|
|
bar: 1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
.extend({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
baz: 1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
expect(extension.options).to.deep.eq({
|
|
|
|
baz: 1,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should configure nested objects', () => {
|
|
|
|
const extension = Extension
|
|
|
|
.create<{
|
|
|
|
foo: number[],
|
|
|
|
HTMLAttributes: Record<string, any>,
|
|
|
|
}>({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
foo: [1, 2, 3],
|
|
|
|
HTMLAttributes: {
|
|
|
|
class: 'foo',
|
|
|
|
},
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
.configure({
|
|
|
|
foo: [1],
|
|
|
|
HTMLAttributes: {
|
|
|
|
id: 'bar',
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
expect(extension.options).to.deep.eq({
|
|
|
|
foo: [1],
|
|
|
|
HTMLAttributes: {
|
|
|
|
class: 'foo',
|
|
|
|
id: 'bar',
|
|
|
|
},
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
2024-05-14 20:45:03 +08:00
|
|
|
it('should configure retaining existing config', () => {
|
|
|
|
const extension = Extension.create({
|
|
|
|
name: 'parent',
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
foo: 1,
|
|
|
|
bar: 1,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
const newExtension = extension
|
|
|
|
.configure()
|
|
|
|
|
|
|
|
expect(newExtension.config.name).to.eq('parent')
|
|
|
|
})
|
|
|
|
|
2021-10-27 00:31:13 +08:00
|
|
|
it('should create its own instance on configure', () => {
|
|
|
|
const extension = Extension
|
|
|
|
.create({
|
|
|
|
addOptions() {
|
|
|
|
return {
|
|
|
|
foo: 1,
|
|
|
|
bar: 2,
|
|
|
|
}
|
|
|
|
},
|
|
|
|
})
|
|
|
|
|
|
|
|
const extension1 = extension.configure({
|
|
|
|
foo: 2,
|
|
|
|
bar: 4,
|
|
|
|
})
|
|
|
|
|
|
|
|
const extension2 = extension.configure({
|
|
|
|
foo: 3,
|
|
|
|
})
|
|
|
|
|
|
|
|
expect(extension1.options).to.deep.eq({
|
|
|
|
foo: 2,
|
|
|
|
bar: 4,
|
|
|
|
})
|
|
|
|
|
|
|
|
expect(extension2.options).to.deep.eq({
|
|
|
|
foo: 3,
|
|
|
|
bar: 2,
|
|
|
|
})
|
|
|
|
})
|
2021-04-17 06:25:04 +08:00
|
|
|
})
|