mirror of
https://github.com/TriliumNext/Notes.git
synced 2025-07-27 10:02:59 +08:00
154 lines
5.0 KiB
TypeScript
154 lines
5.0 KiB
TypeScript
import { ClassicEditor as ClassicTestEditor, Essentials, Paragraph, WidgetToolbarRepository, _setModelData as setData } from 'ckeditor5';
|
||
|
||
import Mermaid from '../src/mermaid.js';
|
||
import { afterEach, beforeEach, describe, it } from 'vitest';
|
||
import { expect } from 'vitest';
|
||
|
||
/* global document */
|
||
|
||
describe( 'MermaidToolbar', () => {
|
||
let editor, domElement, widgetToolbarRepository, balloon, toolbar, model;
|
||
|
||
beforeEach( () => {
|
||
domElement = document.createElement( 'div' );
|
||
document.body.appendChild( domElement );
|
||
|
||
return ClassicTestEditor.create( domElement, {
|
||
licenseKey: "GPL",
|
||
plugins: [ Essentials, Paragraph, Mermaid ],
|
||
mermaid: {
|
||
toolbar: [ 'fake_button' ]
|
||
}
|
||
} ).then( newEditor => {
|
||
editor = newEditor;
|
||
model = newEditor.model;
|
||
widgetToolbarRepository = editor.plugins.get( WidgetToolbarRepository );
|
||
toolbar = widgetToolbarRepository._toolbarDefinitions.get( 'mermaidToolbar' ).view;
|
||
balloon = editor.plugins.get( 'ContextualBalloon' );
|
||
} );
|
||
} );
|
||
|
||
afterEach( () => {
|
||
domElement.remove();
|
||
return editor.destroy();
|
||
} );
|
||
|
||
describe( 'toolbar', () => {
|
||
it( 'should be initialized with expected buttons', () => {
|
||
editor.ui.focusTracker.isFocused = true;
|
||
|
||
setData( model, '<mermaid displayMode="split" source="">[]</mermaid>' );
|
||
|
||
expect( toolbar.items ).to.have.length( 5 );
|
||
expect( toolbar.items.get( 0 ).label ).to.equal( 'Source view' );
|
||
expect( toolbar.items.get( 1 ).label ).to.equal( 'Split view' );
|
||
expect( toolbar.items.get( 2 ).label ).to.equal( 'Preview' );
|
||
expect( toolbar.items.get( 4 ).label ).to.equal( 'Read more about Mermaid diagram syntax' );
|
||
} );
|
||
} );
|
||
|
||
describe( 'integration with the editor focus', () => {
|
||
it( 'should show the toolbar when the editor gains focus and the mermaid widget is selected', () => {
|
||
setData( model,
|
||
'[<mermaid source="flowchart TB\nA --> B\nB --> C"></mermaid>]'
|
||
);
|
||
|
||
expect( balloon.visibleView ).to.be.null;
|
||
// @todo: remove me
|
||
// expect( balloon.visibleView === null, 'balloon.visibleView === null' ).to.be.true;
|
||
|
||
editor.ui.focusTracker.isFocused = true;
|
||
expect( balloon.visibleView ).to.equal( toolbar );
|
||
// @todo: remove me
|
||
// expect( balloon.visibleView === toolbar, 'balloon.visibleView === toolbar' ).to.be.true;
|
||
} );
|
||
|
||
it( 'should hide the toolbar when the editor loses focus and the mermaid widget is selected', () => {
|
||
setData( model,
|
||
'[<mermaid source="flowchart TB\nA --> B\nB --> C"></mermaid>]'
|
||
);
|
||
|
||
editor.ui.focusTracker.isFocused = true;
|
||
expect( balloon.visibleView ).to.equal( toolbar );
|
||
|
||
editor.ui.focusTracker.isFocused = false;
|
||
expect( balloon.visibleView ).to.be.null;
|
||
} );
|
||
} );
|
||
|
||
describe( 'integration with the editor selection', () => {
|
||
beforeEach( () => {
|
||
editor.ui.focusTracker.isFocused = true;
|
||
} );
|
||
|
||
it( 'should show the toolbar on ui#update when the mermaid widget is selected', () => {
|
||
setData( model,
|
||
'<paragraph>[foo]</paragraph>' +
|
||
'<mermaid source="flowchart TB\nA --> B\nB --> C"></mermaid>'
|
||
);
|
||
|
||
expect( balloon.visibleView ).to.be.null;
|
||
|
||
editor.ui.fire( 'update' );
|
||
|
||
expect( balloon.visibleView ).to.be.null;
|
||
|
||
model.change( writer => {
|
||
// Set selection to the [<mermaid source="flowchart TB\nA --> B\nB --> C"></mermaid>]
|
||
writer.setSelection( model.document.getRoot().getChild( 1 ), 'on' );
|
||
} );
|
||
|
||
expect( balloon.visibleView ).to.equal( toolbar );
|
||
|
||
// Make sure successive change does not throw, e.g. attempting
|
||
// to insert the toolbar twice.
|
||
editor.ui.fire( 'update' );
|
||
|
||
expect( balloon.visibleView ).to.equal( toolbar );
|
||
} );
|
||
|
||
it( 'should hide the toolbar on ui#update if the mermaid widget is de–selected', () => {
|
||
setData( model,
|
||
'<paragraph>foo</paragraph>' +
|
||
'[<mermaid source="flowchart TB\nA --> B\nB --> C"></mermaid>]'
|
||
);
|
||
expect( balloon.visibleView ).to.equal( toolbar );
|
||
|
||
model.change( writer => {
|
||
// Select the <paragraph>[foo]</paragraph>
|
||
writer.setSelection( model.document.getRoot().getChild( 0 ), 'in' );
|
||
} );
|
||
|
||
expect( balloon.visibleView ).to.be.null;
|
||
|
||
// Make sure successive change does not throw, e.g. attempting
|
||
// to remove the toolbar twice.
|
||
editor.ui.fire( 'update' );
|
||
|
||
expect( balloon.visibleView ).to.be.null;
|
||
} );
|
||
|
||
it( 'should not hide the toolbar on ui#update when the selection is being moved from one mermaid widget to another', () => {
|
||
setData( model,
|
||
'[<mermaid source="flowchart TB\nA --> B\nB --> C"></mermaid>]' +
|
||
'<mermaid source="flowchart TB\nA --> B\nB --> C"></mermaid>'
|
||
);
|
||
|
||
expect( balloon.visibleView ).to.equal( toolbar );
|
||
|
||
model.change( writer => {
|
||
// Set selection to the second <mermaid></mermaid>
|
||
writer.setSelection( model.document.selection.getSelectedElement().nextSibling, 'on' );
|
||
} );
|
||
|
||
expect( balloon.visibleView ).to.equal( toolbar );
|
||
|
||
// Make sure successive change does not throw, e.g. attempting
|
||
// to insert the toolbar twice.
|
||
editor.ui.fire( 'update' );
|
||
|
||
expect( balloon.visibleView ).to.equal( toolbar );
|
||
} );
|
||
} );
|
||
} );
|