mirror of
https://github.com/codex-team/editor.js
synced 2024-05-22 08:16:50 +02:00
8f156a87ea
* the popover component, vertical toolbox * toolbox position improved * popover width improved * always show the plus button * search field added * search input in popover * trying to create mobile toolbox * feat(toolbox): popover adapted for mobile devices (#2004) * FIx mobile popover fixed positioning * Add mobile popover overlay * Hide mobile popover on scroll * Alter toolbox buttons hover * Fix closing popover on overlay click * Tests fix * Fix onchange test * restore focus after toolbox closing by ESC * don't move toolbar by block-hover on mobile Resolves #1972 * popover mobile styles improved * Cleanup * Remove scroll event listener * Lock scroll on mobile * don't show shortcuts in mobile popover * Change data attr name * Remove unused styles * Remove unused listeners * disable hover on mobile popover * Scroll fix * Lint * Revert "Scroll fix" This reverts commit82deae543e
. * Return back background color for active state of toolbox buttons Co-authored-by: Peter Savchenko <specc.dev@gmail.com> * Vertical toolbox fixes (#2017) * Replace visibility property with display for hiding popover * Disable arrow right and left keys for popover * Revert "Replace visibility property with display for hiding popover" This reverts commitaf521cf6f2
. * Hide popover via setting max-height to 0 to fix animation in safari * Remove redundant condition * Extend element interface to avoid ts errors * Do not subscribe to block hovered if mobile * Add unsubscribing from overlay click event * Rename isMobile to isMobileScreen * Cleanup * fix: popover opening direction (#2022) * Change popover opening direction based on available space below it * Update check * Use cacheable decorator * Update src/components/flipper.ts Co-authored-by: George Berezhnoy <gohabereg@users.noreply.github.com> * Fixes * Fix test * Clear search on popover hide * Fix popover width * Fix for tests * Update todos * Linter fixes * rm todo about beforeInsert because I have no idea what does it mean * i18n for search labels done * rm methods for hiding/showing of + * some code style update * Update CHANGELOG.md * make the list items a little bit compact * fix z-index issue caused by block-appearing animation also, improve popover padding for two reasons: - make the popover more consistent with the Table tool popover (in future, it can be done with the same api method) - make popover looks better Co-authored-by: Tanya Fomina <fomina.tatianaaa@yandex.ru> Co-authored-by: George Berezhnoy <gohabereg@users.noreply.github.com>
132 lines
2.7 KiB
TypeScript
132 lines
2.7 KiB
TypeScript
/* eslint-disable @typescript-eslint/no-explicit-any */
|
|
import Header from '@editorjs/header';
|
|
import { nanoid } from 'nanoid';
|
|
|
|
describe.only('Block ids', () => {
|
|
beforeEach(() => {
|
|
if (this && this.editorInstance) {
|
|
this.editorInstance.destroy();
|
|
} else {
|
|
cy.createEditor({
|
|
tools: {
|
|
header: Header,
|
|
},
|
|
}).as('editorInstance');
|
|
}
|
|
});
|
|
|
|
it('Should generate unique block ids for new blocks', () => {
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('div.ce-block')
|
|
.click()
|
|
.type('First block ')
|
|
.type('{enter}')
|
|
.get('div.ce-block')
|
|
.last()
|
|
.type('Second block ')
|
|
.type('{enter}');
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('div.ce-toolbar__plus')
|
|
.click();
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('div.ce-popover__item[data-item-name=header]')
|
|
.click();
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('div.ce-block')
|
|
.last()
|
|
.click()
|
|
.type('Header');
|
|
|
|
cy.get('@editorInstance')
|
|
.then(async (editor: any) => {
|
|
const data = await editor.save();
|
|
|
|
data.blocks.forEach(block => {
|
|
expect(typeof block.id).to.eq('string');
|
|
});
|
|
});
|
|
});
|
|
|
|
it('should preserve passed ids', () => {
|
|
const blocks = [
|
|
{
|
|
id: nanoid(),
|
|
type: 'paragraph',
|
|
data: {
|
|
text: 'First block',
|
|
},
|
|
},
|
|
{
|
|
id: nanoid(),
|
|
type: 'paragraph',
|
|
data: {
|
|
text: 'Second block',
|
|
},
|
|
},
|
|
];
|
|
|
|
cy.get('@editorInstance')
|
|
.render({
|
|
blocks,
|
|
});
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('div.ce-block')
|
|
.first()
|
|
.click()
|
|
.type('{movetoend} Some more text');
|
|
|
|
cy.get('@editorInstance')
|
|
.then(async (editor: any) => {
|
|
const data = await editor.save();
|
|
|
|
data.blocks.forEach((block, index) => {
|
|
expect(block.id).to.eq(blocks[index].id);
|
|
});
|
|
});
|
|
});
|
|
|
|
it('should preserve passed ids if blocks were added', () => {
|
|
const blocks = [
|
|
{
|
|
id: nanoid(),
|
|
type: 'paragraph',
|
|
data: {
|
|
text: 'First block',
|
|
},
|
|
},
|
|
{
|
|
id: nanoid(),
|
|
type: 'paragraph',
|
|
data: {
|
|
text: 'Second block',
|
|
},
|
|
},
|
|
];
|
|
|
|
cy.get('@editorInstance')
|
|
.render({
|
|
blocks,
|
|
});
|
|
|
|
cy.get('[data-cy=editorjs]')
|
|
.get('div.ce-block')
|
|
.first()
|
|
.click()
|
|
.type('{enter}')
|
|
.next()
|
|
.type('Middle block');
|
|
|
|
cy.get('@editorInstance')
|
|
.then(async (editor: any) => {
|
|
const data = await editor.save();
|
|
|
|
expect(data.blocks[0].id).to.eq(blocks[0].id);
|
|
expect(data.blocks[2].id).to.eq(blocks[1].id);
|
|
});
|
|
});
|
|
});
|