hedera-web/js/vn/node.js

142 lines
2.9 KiB
JavaScript

module.exports =
{
/**
* Removes all node childs.
*
* @param {Node} node The HTML Node
*/
removeChilds: function (node)
{
var childs = node.childNodes;
if (childs)
while (childs.length > 0)
node.removeChild (childs[0]);
}
/**
* Removes a node from the document.
*
* @param {Node} node The HTML Node
*/
,remove: function (node)
{
if (node.parentNode)
node.parentNode.removeChild (node);
}
/**
* Replaces the node child/s with another one.
*
* @param {Node} node The HTML Node
* @param {Node} child The new child or %null to set an empty node
*/
,setChild: function (node, child)
{
this.removeChilds (node);
if (child)
node.appendChild (child);
}
/**
* Replaces the node text/childs with text.
*
* @param {Node} node The HTML Node
* @param {Node} child The new node text or %null for no text
*/
,setText: function (node, text)
{
this.removeChilds (node);
if (text)
node.appendChild (
node.ownerDocument.createTextNode (text));
}
/**
* Adds a class to the node CSS classes. Note that this
* function doesn't check if the node already has the class.
*
* @param {Node} node The HTML element
* @param {string} className The CSS class name
*/
,addClass: function (node, className)
{
node.className = className +' '+ node.className;
}
/**
* Removes a class from the node CSS classes. This functions
* removes all ocurrences of the class from the node.
*
* @param {Node} node The HTML element
* @param {string} className The CSS class name
*/
,removeClass: function (node, className)
{
var index = 0;
var found = false;
var classes = node.className.split (' ');
while ((index = classes.indexOf (className, index)) != -1)
{
classes.splice (index, 1);
found = true;
}
if (found)
node.className = classes.join (' ');
}
/**
* Hides the node from the document.
*
* @param {Node} node The HTML element
*/
,hide: function (node)
{
node.style.visibility = 'none';
}
/**
* Shows a hidden node.
*
* @param {Node} node The HTML element
* @param {String} displayValue The CSS display value when it's displayed,
* if it isn't specified 'block' is used
*/
,show: function (node, displayValue)
{
node.style.display = displayValue ? displayValue : 'block';
}
/**
* Shows or hides node.
*
* @param {Node} node The HTML element
* @param {Boolean} display Wheter to display the node
* @param {String} displayValue The CSS display value when it's displayed,
* if it isn't specified 'block' is used
*/
,display: function (node, display, displayValue)
{
if (display)
this.show (node, displayValue);
else
this.hide (node);
}
/**
* Shows or hides node.
*
* @param {Node} node The HTML Node
* @param {Boolean} visible Wheter to display the node
*/
,setVisible: function (node, visible)
{
node.style.visibility = visible ? 'visible' : 'hidden';
}
};