2020-11-03 05:17:39 +08:00
|
|
|
/// <reference types="cypress" />
|
|
|
|
|
2022-11-24 23:06:42 +08:00
|
|
|
import { mergeAttributes } from '@tiptap/core'
|
2020-11-03 05:17:39 +08:00
|
|
|
|
|
|
|
describe('mergeAttributes', () => {
|
|
|
|
it('should merge two objects', () => {
|
|
|
|
const value = mergeAttributes({ id: 1 }, { class: 'foo' })
|
|
|
|
|
|
|
|
expect(value).to.deep.eq({
|
|
|
|
id: 1,
|
|
|
|
class: 'foo',
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should merge multiple objects', () => {
|
|
|
|
const value = mergeAttributes({ id: 1 }, { class: 'foo' }, { title: 'bar' })
|
|
|
|
|
|
|
|
expect(value).to.deep.eq({
|
|
|
|
id: 1,
|
|
|
|
class: 'foo',
|
|
|
|
title: 'bar',
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should overwrite values', () => {
|
|
|
|
const value = mergeAttributes({ id: 1 }, { id: 2 })
|
|
|
|
|
|
|
|
expect(value).to.deep.eq({
|
|
|
|
id: 2,
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should merge classes', () => {
|
|
|
|
const value = mergeAttributes({ class: 'foo' }, { class: 'bar' })
|
|
|
|
|
|
|
|
expect(value).to.deep.eq({
|
|
|
|
class: 'foo bar',
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should merge styles', () => {
|
|
|
|
const value = mergeAttributes({ style: 'color: red' }, { style: 'background: green' })
|
|
|
|
|
|
|
|
expect(value).to.deep.eq({
|
|
|
|
style: 'color: red; background: green',
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should merge classes and styles', () => {
|
|
|
|
const value = mergeAttributes(
|
|
|
|
{ class: 'foo', style: 'color: red' },
|
|
|
|
{ class: 'bar', style: 'background: green' },
|
|
|
|
)
|
|
|
|
|
|
|
|
expect(value).to.deep.eq({
|
|
|
|
class: 'foo bar',
|
|
|
|
style: 'color: red; background: green',
|
|
|
|
})
|
|
|
|
})
|
2020-11-15 00:27:59 +08:00
|
|
|
|
|
|
|
it('should ignore falsy values', () => {
|
|
|
|
const value = mergeAttributes(undefined, { class: 'foo' })
|
|
|
|
|
|
|
|
expect(value).to.deep.eq({
|
|
|
|
class: 'foo',
|
|
|
|
})
|
|
|
|
})
|
2024-08-22 04:39:58 +08:00
|
|
|
|
|
|
|
it('should overwrite styles', () => {
|
|
|
|
const value = mergeAttributes({ style: 'color: red' }, { style: 'color: green' })
|
|
|
|
|
|
|
|
expect(value).to.deep.eq({
|
|
|
|
style: 'color: green',
|
|
|
|
})
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should merge several styles', () => {
|
|
|
|
const value = mergeAttributes({ style: 'color: red; background-color: red' }, { style: 'color: green; background-color: red; margin-left: 30px' })
|
|
|
|
|
|
|
|
expect(value).to.deep.eq({
|
|
|
|
style: 'color: green; background-color: red; margin-left: 30px',
|
|
|
|
})
|
|
|
|
})
|
2020-11-03 05:17:39 +08:00
|
|
|
})
|