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

73 lines
1.3 KiB
JavaScript
Raw Normal View History

2016-09-26 09:28:47 +00:00
2022-05-21 21:31:56 +00:00
module.exports = new Class({
Extends: Htk.Field
,Tag: 'htk-button'
,Properties:
{
2022-05-21 21:31:56 +00:00
image: {
type: String
2022-05-21 21:31:56 +00:00
,set: function(x) {
this.span.innerText = x;
}
2016-09-19 06:40:18 +00:00
},
2022-05-21 21:31:56 +00:00
icon: {
2016-09-19 06:40:18 +00:00
type: String
2022-05-21 21:31:56 +00:00
,set: function(x) {
this.span.innerText = x;
2016-09-19 06:40:18 +00:00
}
},
2022-05-21 21:31:56 +00:00
tip: {
type: String
2022-05-21 21:31:56 +00:00
,set: function(x) {
if (x) {
this.node.title = _(x);
2022-05-21 21:31:56 +00:00
this.span.title = _(x);
}
2015-09-16 16:11:15 +00:00
2022-05-21 21:31:56 +00:00
this.renderContent();
2015-09-16 16:11:15 +00:00
}
2022-05-21 21:31:56 +00:00
,get: function() {
2015-09-16 16:11:15 +00:00
return this.node.title;
}
},
2022-05-21 21:31:56 +00:00
showText: {
2015-09-16 16:11:15 +00:00
type: Boolean
2022-05-21 21:31:56 +00:00
,set: function(x) {
2015-09-16 16:11:15 +00:00
this._showText = x;
2022-05-21 21:31:56 +00:00
this.renderContent();
2015-09-16 16:11:15 +00:00
}
2022-05-21 21:31:56 +00:00
,get: function() {
2015-09-16 16:11:15 +00:00
return this._showText;
}
}
}
2015-09-16 16:11:15 +00:00
,_showText: false
2022-05-21 21:31:56 +00:00
,render: function() {
var node = this.createRoot('button');
2016-10-16 14:16:08 +00:00
node.className = 'htk-button';
2022-05-21 21:31:56 +00:00
node.addEventListener('click', this.onClick.bind(this));
2015-11-09 08:14:33 +00:00
2022-05-21 21:31:56 +00:00
this.span = this.createElement('span');
this.span.className = 'material-symbols-rounded icon';
node.appendChild(this.span);
}
2015-09-16 16:11:15 +00:00
2022-05-21 21:31:56 +00:00
,renderContent: function() {
2015-09-16 16:11:15 +00:00
if (this._textNode)
2022-05-21 21:31:56 +00:00
Vn.Node.remove(this._textNode);
2015-09-16 16:11:15 +00:00
2022-05-21 21:31:56 +00:00
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);
2015-09-16 16:11:15 +00:00
}
}
2022-05-21 21:31:56 +00:00
,onClick: function() {
this.signalEmit('click', this._form);
}
});