grapesjs-clot
Version:
Free and Open Source Web Builder Framework
43 lines (35 loc) • 985 B
JavaScript
import { isString } from 'underscore';
import TraitView from './TraitView';
export default TraitView.extend({
eventCapture: ['click button'],
templateInput: '',
onChange() {
this.handleClick();
},
handleClick() {
const { model, em } = this;
const command = model.get('command');
if (command) {
if (isString(command)) {
em.get('Commands').run(command);
} else {
command(em.get('Editor'), model);
}
}
},
renderLabel() {
if (this.model.get('label')) {
TraitView.prototype.renderLabel.apply(this, arguments);
}
},
getInputEl() {
const { model, ppfx } = this;
const { labelButton, text, full } = model.props();
const label = labelButton || text;
const className = `${ppfx}btn`;
const input = `<button type="button" class="${className}-prim${
full ? ` ${className}--full` : ''
}">${label}</button>`;
return input;
}
});