mirror of https://github.com/artf/grapesjs.git
nocodeframeworkdrag-and-dropsite-buildersite-generatortemplate-builderui-builderweb-builderweb-builder-frameworkwebsite-builderno-codepage-builder
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
152 lines
5.0 KiB
152 lines
5.0 KiB
import Panels from 'panels';
|
|
import Panel from 'panels/model/Panel';
|
|
import Editor from 'editor/model/Editor';
|
|
|
|
describe('Panels', () => {
|
|
describe('Main', () => {
|
|
var em;
|
|
var obj;
|
|
|
|
beforeEach(() => {
|
|
em = new Editor({});
|
|
obj = new Panels(em);
|
|
});
|
|
|
|
afterEach(() => {
|
|
obj = null;
|
|
});
|
|
|
|
test('Object exists', () => {
|
|
expect(obj).toBeTruthy();
|
|
});
|
|
|
|
test('No panels inside', () => {
|
|
expect(obj.getPanels().length).toEqual(3);
|
|
});
|
|
|
|
test('Adds new panel correctly via object', () => {
|
|
var panel = obj.addPanel({ id: 'test' });
|
|
expect(panel.get('id')).toEqual('test');
|
|
});
|
|
|
|
test('New panel has no buttons', () => {
|
|
var panel = obj.addPanel({ id: 'test' });
|
|
expect(panel.get('buttons').length).toEqual(0);
|
|
});
|
|
|
|
test('Adds new panel correctly via Panel instance', () => {
|
|
var oPanel = new Panel(obj, { id: 'test' });
|
|
var panel = obj.addPanel(oPanel);
|
|
expect(panel).toEqual(oPanel);
|
|
expect(panel.get('id')).toEqual('test');
|
|
});
|
|
|
|
test('getPanel returns null in case there is no requested panel', () => {
|
|
expect(obj.getPanel('test')).toEqual(null);
|
|
});
|
|
|
|
test('getPanel returns correctly the panel', () => {
|
|
var panel = obj.addPanel({ id: 'test' });
|
|
expect(obj.getPanel('test')).toEqual(panel);
|
|
});
|
|
|
|
test("Can't add button to non existent panel", () => {
|
|
expect(obj.addButton('test', { id: 'btn' })).toEqual(null);
|
|
});
|
|
|
|
test('Add button correctly', () => {
|
|
var panel = obj.addPanel({ id: 'test' });
|
|
var btn = obj.addButton('test', { id: 'btn' });
|
|
expect(panel.get('buttons').length).toEqual(1);
|
|
expect(panel.get('buttons').at(0).get('id')).toEqual('btn');
|
|
});
|
|
|
|
test('getButton returns null in case there is no requested panel', () => {
|
|
expect(obj.addButton('test', 'btn')).toEqual(null);
|
|
});
|
|
|
|
test('getButton returns null in case there is no requested button', () => {
|
|
var panel = obj.addPanel({ id: 'test' });
|
|
expect(obj.getButton('test', 'btn')).toEqual(null);
|
|
});
|
|
|
|
test('getButton returns correctly the button', () => {
|
|
var panel = obj.addPanel({ id: 'test' });
|
|
var btn = obj.addButton('test', { id: 'btn' });
|
|
expect(obj.getButton('test', 'btn')).toEqual(btn);
|
|
});
|
|
|
|
test('Renders correctly', () => {
|
|
expect(obj.render()).toBeTruthy();
|
|
});
|
|
|
|
test('Active correctly activable buttons', () => {
|
|
var spy = sinon.spy();
|
|
var panel = obj.addPanel({ id: 'test' });
|
|
var btn = obj.addButton('test', { id: 'btn', active: true });
|
|
btn.on('updateActive', spy);
|
|
obj.active();
|
|
expect(spy.called).toEqual(true);
|
|
});
|
|
|
|
test('Disable correctly buttons flagged as disabled', () => {
|
|
var spy = sinon.spy();
|
|
var panel = obj.addPanel({ id: 'test' });
|
|
var btn = obj.addButton('test', { id: 'btn', disable: true });
|
|
btn.on('change:disable', spy);
|
|
obj.disableButtons();
|
|
expect(spy.called).toEqual(true);
|
|
});
|
|
|
|
test("Can't remove button to non existent panel", () => {
|
|
expect(obj.removeButton('test', { id: 'btn' })).toEqual(null);
|
|
});
|
|
|
|
describe('Removes button', () => {
|
|
test('Remove button correctly with object', () => {
|
|
var panel = obj.addPanel({ id: 'test' });
|
|
var btn = obj.addButton('test', { id: 'btn' });
|
|
expect(panel.get('buttons').length).toEqual(1);
|
|
expect(panel.get('buttons').at(0).get('id')).toEqual('btn');
|
|
expect(obj.removeButton('test', { id: 'btn' })).toEqual(btn);
|
|
expect(panel.get('buttons').length).toEqual(0);
|
|
});
|
|
|
|
test('Remove button correctly with sting', () => {
|
|
var panel = obj.addPanel({ id: 'test' });
|
|
var btn = obj.addButton('test', { id: 'btn' });
|
|
expect(panel.get('buttons').length).toEqual(1);
|
|
expect(panel.get('buttons').at(0).get('id')).toEqual('btn');
|
|
expect(obj.removeButton('test', 'btn')).toEqual(btn);
|
|
expect(panel.get('buttons').length).toEqual(0);
|
|
});
|
|
});
|
|
|
|
describe('Removes Panel', () => {
|
|
test('Removes panel correctly via object', () => {
|
|
var panel = obj.addPanel({ id: 'test' });
|
|
expect(panel.get('id')).toEqual('test');
|
|
obj.removePanel({ id: 'test' });
|
|
expect(panel.get('id')).toEqual('test');
|
|
});
|
|
|
|
test('Removes panel correctly via Panel instance', () => {
|
|
var oPanel = new Panel(obj, { id: 'test' });
|
|
var panel = obj.addPanel(oPanel);
|
|
expect(panel).toEqual(oPanel);
|
|
expect(panel.get('id')).toEqual('test');
|
|
obj.removePanel(oPanel);
|
|
expect(obj.getPanels.length).toEqual(0);
|
|
});
|
|
|
|
test('Removes panel correctly via id', () => {
|
|
var oPanel = new Panel(obj, { id: 'test' });
|
|
var panel = obj.addPanel(oPanel);
|
|
expect(panel).toEqual(oPanel);
|
|
expect(panel.get('id')).toEqual('test');
|
|
obj.removePanel('test');
|
|
expect(obj.getPanels.length).toEqual(0);
|
|
});
|
|
});
|
|
});
|
|
});
|
|
|