2016-09-26 09:28:47 +00:00
|
|
|
|
2022-05-28 19:27:36 +00:00
|
|
|
const NodeBuilder = require('../vn/node-builder');
|
2016-10-16 14:16:08 +00:00
|
|
|
|
2022-05-28 15:49:46 +00:00
|
|
|
const Widget = new Class({
|
2016-10-16 14:16:08 +00:00
|
|
|
Extends: NodeBuilder
|
2022-05-28 19:27:36 +00:00
|
|
|
,Properties: {
|
2016-10-16 14:16:08 +00:00
|
|
|
/**
|
|
|
|
* Main HTML node that represents the widget
|
2022-05-24 21:11:12 +00:00
|
|
|
*/
|
|
|
|
node: {
|
2016-10-14 10:58:35 +00:00
|
|
|
type: Object
|
2022-05-24 21:11:12 +00:00
|
|
|
,get: function() {
|
|
|
|
this.renderBase();
|
2016-10-14 10:58:35 +00:00
|
|
|
return this._node;
|
|
|
|
}
|
|
|
|
},
|
2022-05-28 15:49:46 +00:00
|
|
|
/**
|
|
|
|
* CSS syle.
|
|
|
|
*/
|
|
|
|
style: {
|
|
|
|
type: String
|
|
|
|
,set: function(x) {
|
|
|
|
this.node.style = x;
|
|
|
|
}
|
|
|
|
,get: function() {
|
2022-05-28 19:27:36 +00:00
|
|
|
return this._node.style;
|
2022-05-28 15:49:46 +00:00
|
|
|
}
|
|
|
|
},
|
2016-10-16 14:16:08 +00:00
|
|
|
/**
|
|
|
|
* CSS classes to be appendend to the node classes.
|
2022-05-24 21:11:12 +00:00
|
|
|
*/
|
|
|
|
class: {
|
2015-03-06 23:33:54 +00:00
|
|
|
type: String
|
2022-05-24 21:11:12 +00:00
|
|
|
,set: function(x) {
|
2016-05-02 13:05:49 +00:00
|
|
|
this._cssClass = x;
|
2022-05-24 21:11:12 +00:00
|
|
|
this._refreshClass();
|
2015-03-06 23:33:54 +00:00
|
|
|
}
|
2022-05-24 21:11:12 +00:00
|
|
|
,get: function() {
|
2016-10-14 10:58:35 +00:00
|
|
|
return this._node.className;
|
2015-03-06 23:33:54 +00:00
|
|
|
}
|
2022-05-28 00:37:24 +00:00
|
|
|
},
|
2022-05-28 15:49:46 +00:00
|
|
|
/**
|
|
|
|
* CSS class list.
|
|
|
|
*/
|
|
|
|
classList: {
|
|
|
|
type: Object
|
|
|
|
,get: function() {
|
2022-05-28 19:27:36 +00:00
|
|
|
return this._node.classList;
|
2022-05-28 15:49:46 +00:00
|
|
|
}
|
|
|
|
},
|
2022-05-28 00:37:24 +00:00
|
|
|
/**
|
|
|
|
* Title of the element.
|
|
|
|
*/
|
|
|
|
title: {
|
|
|
|
type: String
|
|
|
|
,set: function(x) {
|
2022-05-28 19:27:36 +00:00
|
|
|
this._node.title = x;
|
2022-05-28 00:37:24 +00:00
|
|
|
}
|
|
|
|
,get: function() {
|
2022-05-28 19:27:36 +00:00
|
|
|
return this._node.title;
|
2022-05-28 00:37:24 +00:00
|
|
|
}
|
2022-05-28 19:27:36 +00:00
|
|
|
},
|
|
|
|
/**
|
|
|
|
* The HTML id of the element.
|
|
|
|
*/
|
|
|
|
htmlId:
|
|
|
|
{
|
|
|
|
type: String
|
|
|
|
,set: function(x) {
|
|
|
|
this._htmlId = x;
|
2022-05-30 01:30:33 +00:00
|
|
|
if (this._node)
|
|
|
|
this._node.id = x;
|
2022-05-28 19:27:36 +00:00
|
|
|
}
|
|
|
|
,get: function() {
|
|
|
|
return this._htmlId;
|
|
|
|
}
|
|
|
|
},
|
2015-03-06 23:33:54 +00:00
|
|
|
}
|
2015-01-23 13:09:30 +00:00
|
|
|
|
2016-10-14 10:58:35 +00:00
|
|
|
,_node: null
|
2015-03-06 23:33:54 +00:00
|
|
|
|
2022-05-24 21:11:12 +00:00
|
|
|
,initialize: function(props) {
|
2016-10-16 14:16:08 +00:00
|
|
|
this.doc = document;
|
2022-05-24 21:11:12 +00:00
|
|
|
this.renderBase();
|
|
|
|
this.parent(props);
|
2016-09-26 09:28:47 +00:00
|
|
|
}
|
|
|
|
|
2022-05-24 21:11:12 +00:00
|
|
|
,createRoot: function(tagName) {
|
2022-05-30 01:30:33 +00:00
|
|
|
const node = this._node = this.createElement(tagName);
|
|
|
|
if (this._htmlId) node.id = this._htmlId;
|
|
|
|
return node;
|
2016-09-26 09:28:47 +00:00
|
|
|
}
|
|
|
|
|
2022-05-24 21:11:12 +00:00
|
|
|
,renderBase: function() {
|
2016-10-16 14:16:08 +00:00
|
|
|
if (this._node)
|
|
|
|
return;
|
2016-05-02 13:05:49 +00:00
|
|
|
|
2022-05-24 21:11:12 +00:00
|
|
|
this.render();
|
|
|
|
this._refreshClass();
|
2015-01-23 13:09:30 +00:00
|
|
|
}
|
2016-05-02 13:05:49 +00:00
|
|
|
|
2022-05-24 21:11:12 +00:00
|
|
|
,_refreshClass: function() {
|
2016-10-14 10:58:35 +00:00
|
|
|
if (this._node && this._cssClass)
|
|
|
|
this._node.className = this._cssClass +' '+ this._node.className;
|
2016-05-02 13:05:49 +00:00
|
|
|
}
|
2015-03-15 12:44:57 +00:00
|
|
|
|
2022-05-24 21:11:12 +00:00
|
|
|
,remove: function() {
|
|
|
|
Vn.Node.remove(this._node);
|
2015-03-15 12:44:57 +00:00
|
|
|
}
|
2022-05-28 15:49:46 +00:00
|
|
|
|
|
|
|
,on: function(id, callback, instance) {
|
|
|
|
if (htmlEventMap[id]) {
|
|
|
|
this.node.addEventListener(id,
|
|
|
|
callback.bind(instance, this));
|
|
|
|
} else
|
|
|
|
this.parent(id, callback, instance);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
htmlEventMap = {};
|
|
|
|
htmlEvents = [
|
|
|
|
'click',
|
|
|
|
'dblclick',
|
|
|
|
'keydown',
|
|
|
|
'keypress',
|
|
|
|
'keyup',
|
|
|
|
'mousedown',
|
|
|
|
'mousemove',
|
|
|
|
'mouseout',
|
|
|
|
'mouseover',
|
|
|
|
'mouseup',
|
|
|
|
'mousewheel',
|
|
|
|
'wheel',
|
|
|
|
'focus',
|
|
|
|
'focusout',
|
|
|
|
'focusin'
|
|
|
|
];
|
|
|
|
htmlEvents.forEach(x => htmlEventMap[x] = true);
|
|
|
|
|
|
|
|
htmlMethods = [
|
|
|
|
'addEventListener'
|
|
|
|
];
|
|
|
|
htmlMethods.forEach(method => {
|
|
|
|
Widget[method] = function() {
|
|
|
|
this.node.apply(this.node, arguments);
|
|
|
|
};
|
2015-01-23 13:09:30 +00:00
|
|
|
});
|
2016-09-26 09:28:47 +00:00
|
|
|
|
2022-05-28 15:49:46 +00:00
|
|
|
module.exports = Widget;
|