hedera-web/js/htk/field/button.js

67 lines
1.2 KiB
JavaScript

module.exports = new Class({
Extends: Htk.Field
,Tag: 'htk-button'
,Properties: {
image: {
type: String
,set: function(x) {
this.iconNode.name = x;
}
},
icon: {
type: String
,set: function(x) {
this.iconNode.name = x;
}
},
tip: {
type: String
,set: function(x) {
this.node.title = x ? _(x) : '';
this.renderContent();
}
,get: function() {
return this.node.title;
}
},
showText: {
type: Boolean
,set: function(x) {
this._showText = x;
this.renderContent();
}
,get: function() {
return this._showText;
}
}
}
,_showText: false
,render: function() {
var node = this.createRoot('button');
node.className = 'htk-button';
node.addEventListener('click', this.onClick.bind(this));
this.iconNode = new Htk.Icon();
node.appendChild(this.iconNode.node);
}
,renderContent: function() {
if (this._textNode)
Vn.Node.remove(this._textNode);
if (this._showText && this.node.title) {
this._textNode = this.createElement('span');
this._textNode.className = 'text';
this._textNode.appendChild(this.createTextNode(this.node.title));
this.node.appendChild(this._textNode);
}
}
,onClick: function() {
this.signalEmit('click', this._form);
}
});