mirror of
https://github.com/codex-team/editor.js
synced 2024-05-06 16:36:47 +02:00
581289c03e
* Default tunes to popover * Add the rest of default tunes * Add popover * Cleanup * Rename custom content * Cleanup * Add ability to open block settings upwards * Fix tests * Cleanup default tunes * Rename and cleanup * Add ability to display rendered custom tunes * cleanup * Rename * Add flag to close tunes popover * Cleanup * i18n * Cleanup * Fix build and tests * Fix for iframe * Add comments * Display active item, move closeOnActivate to popover * Add confirmation support to popover * Handle boolean value in confirmation param * Clarify flippable logic in popover * Comments * Pass editor element as a param of popover constructor * Fix readability * Tests * Fix flipper for confirmation element * Update confirmation config structure * Rename onClick to onActivate * Fix tests and build * Make confirmation props optional * Simplify processing tunes * Renamings * Fix text block tunes * Docs * Update event type * Move enabling confirmation state to separate method * move popover types * Unhardcode color * Support toggling * Add support of disabled items * Fix tab in empty block leading to selecting second item in popover * Remove margins for styles api settings button class * Fix arrow navigation between blocks after opening block tunes * Cleaup in default tunes code * Fix chaining confirmations * Colors * Types * Change the way flippable elements of popover custom area are set * Remove borders around popover icons * Fix untabbable inline toolbar * Fix locked scroll after closing tunes popover on mobile * Cleanup * Set max popover width * Make popover icon's border outside * Fix tab issue * Fix focus/hover issue * Reformat * Cleanup * Fix opening block tunes via keyboard * Add disableSpecialHoverAndFocusBehavior * Add deprecated comment * Cleanup * Fix popover active state * Fix checklist deletion with confirmation * Fix checklist deletion 2 * Fix popover focus * Fix popover items being impossible to flip after searching * Fix popover item highlighting issue * Update flipper.spec.ts * Fixes after review * Add Tunes Api tests * Fix multiple popover entries configured by one tune * Add tool's renderSettings() tests * Add popover confirmation state test * Fix popover width on mobile * Add popover tests * Add changelog and update version * Update changelog * Fix block tunes being unable to open after tune activation Co-authored-by: Peter Savchenko <specc.dev@gmail.com>
137 lines
3.3 KiB
TypeScript
137 lines
3.3 KiB
TypeScript
import { TunesMenuConfig } from '../../../../types/tools';
|
|
|
|
/* eslint-disable @typescript-eslint/no-empty-function */
|
|
|
|
describe('Editor Tunes Api', () => {
|
|
it('should render a popover entry for block tune if configured', () => {
|
|
/** Test tune that should appear be rendered in block tunes menu */
|
|
class TestTune {
|
|
/** Set Tool is Tune */
|
|
public static readonly isTune = true;
|
|
|
|
/** Tune's appearance in block settings menu */
|
|
public render(): TunesMenuConfig {
|
|
return {
|
|
icon: 'ICON',
|
|
label: 'Test tune',
|
|
name: 'testTune',
|
|
|
|
onActivate: (): void => { },
|
|
};
|
|
}
|
|
|
|
/** Save method stub */
|
|
public save(): void {}
|
|
}
|
|
|
|
cy.createEditor({
|
|
tools: {
|
|
testTune: TestTune,
|
|
},
|
|
tunes: [ 'testTune' ],
|
|
}).as('editorInstance');
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('div.ce-block')
|
|
.type('some text')
|
|
.click();
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('.ce-toolbar__settings-btn')
|
|
.click();
|
|
|
|
cy.get('[data-item-name=testTune]').should('exist');
|
|
});
|
|
|
|
it('should render several popover entries for block tune if configured', () => {
|
|
/** Test tune that should appear be rendered in block tunes menu */
|
|
class TestTune {
|
|
/** Set Tool is Tune */
|
|
public static readonly isTune = true;
|
|
|
|
/** Tune's appearance in block settings menu */
|
|
public render(): TunesMenuConfig {
|
|
return [
|
|
{
|
|
icon: 'ICON1',
|
|
label: 'Tune entry 1',
|
|
name: 'testTune1',
|
|
|
|
onActivate: (): void => { },
|
|
}, {
|
|
icon: 'ICON2',
|
|
label: 'Tune entry 2',
|
|
name: 'testTune2',
|
|
|
|
onActivate: (): void => { },
|
|
},
|
|
];
|
|
}
|
|
|
|
/** Save method stub */
|
|
public save(): void {}
|
|
}
|
|
|
|
cy.createEditor({
|
|
tools: {
|
|
testTune: TestTune,
|
|
},
|
|
tunes: [ 'testTune' ],
|
|
}).as('editorInstance');
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('div.ce-block')
|
|
.type('some text')
|
|
.click();
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('.ce-toolbar__settings-btn')
|
|
.click();
|
|
|
|
cy.get('[data-item-name=testTune1]').should('exist');
|
|
cy.get('[data-item-name=testTune2]').should('exist');
|
|
});
|
|
|
|
it('should display custom html returned by tune\'s render() method inside tunes menu', () => {
|
|
const sampleText = 'sample text';
|
|
|
|
/** Test tune that should appear be rendered in block tunes menu */
|
|
class TestTune {
|
|
/** Set Tool is Tune */
|
|
public static readonly isTune = true;
|
|
|
|
/** Tune's appearance in block settings menu */
|
|
public render(): HTMLElement {
|
|
const element = document.createElement('div');
|
|
|
|
element.textContent = sampleText;
|
|
|
|
return element;
|
|
}
|
|
|
|
/** Save method stub */
|
|
public save(): void {}
|
|
}
|
|
|
|
cy.createEditor({
|
|
tools: {
|
|
testTune: TestTune,
|
|
},
|
|
tunes: [ 'testTune' ],
|
|
}).as('editorInstance');
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('div.ce-block')
|
|
.type('some text')
|
|
.click();
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('.ce-toolbar__settings-btn')
|
|
.click();
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('.ce-popover')
|
|
.should('contain.text', sampleText);
|
|
});
|
|
});
|