function processTable(tableId, searchTerm, colNumber, hideCallback, showCallBack) {
var mySearchTerm = searchTerm || "",
myTable = document.getElementById(tableId) || document.createElement("TABLE"),
myRowsArray = getElements(null, "TR", myTable), //convert to array
myRowsArrayLength = myRowsArray.length;
var index = 0;
for (var i = myRowsArrayLength; --i;) {
var myTempRowElement = myRowsArray[i],
myTempColArray = getElements(null, "TD", myTempRowElement),
myTempCol = (myTempColArray.length > 0 ? myTempColArray[colNumber - 1] : document.createElement("TD")),
myText = getText(myTempCol);
if (myText === mySearchTerm) {
showCallBack(myTempRowElement);
}
else {
hideCallback(myTempRowElement);
}
}
};
function init() {
var myHandler = function (e) {
var myTermEl = document.getElementById("searchTerm"),
myTextContent = getText(myTermEl) || myTermEl.value || "";
processTable("dataTable", myTextContent, 1,
function hideCallback(el) {
el.style.display = 'none';
},
function showCallBack(el) {
el.style.display = 'table-row';
}
);
};
myHandler();
document.getElementById("searchTerm").onkeyup = myHandler;
document.getElementById("searchTerm").onchange = myHandler;
document.getElementById("searchTerm").onclick = myHandler;
};
(function () {
if (this.addEventListener) {
this.addEventListener("load", init, false)
}
else {
window.onload = init;
}
}());
var isClassMember = function (element, classname) {
var classes = element.className;
if (!classes) {
return false;
};
if (classes == classname) {
return true;
};
var whitespace = /\s+/;
if (!whitespace.test(classes)) {
return false;
};
var c = classes.split(whitespace);
for (var i = 0; i < c.length; i++) {
if (c[i] == classname) {
return true;
};
};
return false;
};
var getElements = function (classname, tagname, root, firstFlag, depth) {
if (!root) {
root = document;
}
else {
if (typeof root == "string") {
root = document.getElementById(root);
};
};
if (!tagname) {
tagname = "*";
};
if (depth) {
var maxRecursion = depth;
var all = (function getChildsElementsLevel(root, tagName, currentLevelNumber) {
var result = [],
currentLevelChilds = (function getLevelChilds(root, tagName) {
var result = [];
var children = root.firstChild;
do {
if (children.nodeName == tagName) {
result.push(children);
};
} while (children = children.nextSibling);
return result;
})(root, tagName),
currentLevelChildsLength = currentLevelChilds.length,
nextLevelNumber = ++currentLevelNumber;
for (var f = currentLevelChildsLength; f--;) {
var currentEl = currentLevelChilds[f];
result.push(currentEl);
if (nextLevelNumber < maxRecursion) {
result.concat(getChildsElementsLevel(currentEl, tagName, nextLevelNumber));
}
}
return result;
})(root, tagname, 0);
}
else {
var all = root.getElementsByTagName(tagname);
}
if (!classname) {
return all;
};
var elements = [],
allLength = all.length,
isMyClass = isClassMember;
if (firstFlag) {
for (var i = 0; i < allLength; i++) {
var element = all[i];
if (isMyClass(element, classname)) {
return element;
};
};
}
else {
for (var i = allLength; i--;) {
var element = all[i];
if (isMyClass(element, classname)) {
elements.push(element);
};
};
}
return elements;
};
var getText = function (n) {
function getStrings(n, strings) {
if (n.nodeType == 3 /* Node.TEXT_NODE */) {
strings.push(n.data);
}
else {
if (n.nodeType == 1 /* Node.ELEMENT_NODE */) {
for (var m = n.firstChild; m != null; m = m.nextSibling) {
getStrings(m, strings);
};
};
};
};
var strings = [];
getStrings(n, strings);
return strings.join("");
};