mirror of
				https://github.com/TriliumNext/Notes.git
				synced 2025-10-27 01:51:34 +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 );
 | ||
| 		} );
 | ||
| 	} );
 | ||
| } );
 | 
