Subversion Repositories computer_asset_manager_v1

Rev

Blame | Last modification | View Log | Download | RSS feed

/* 
 * Simple toggle for making a cell clickable on a row to show/hide it's siblings.
 * To uss:
 *  - Add JavaScript file to your html
 *  - Add the class tableClass (defined below) to your table.   
 *  ex: <table widht="100%" cellpadding="0" cellspacing="0" class="table trihilight otherclass">
 *  
 *  - Add the activatorClass to any cell that you wnat to be clickable.
 *  ex:
 *      <tr>
 *          <td class='activator'>Col 1</td>
 *          <td class='hidden'>Col 2</td>
 *          <td class='hidden'>Col 3</td>
 *      </tr>
 *  
 *  You can edit the default class names by changing the constants below.
 */

// Edit these strings to suit the class names used
const tableClass = "sibling-hide";
const activatorClass = "activator";
const hideClass = "hidden";
// End edit area

//Make sure the activator style shows that it can be clicked on.
var style = document.createElement('style');
style.type = 'text/css';
style.innerHTML = '.' + activatorClass + ':hover { cursor: pointer; } .' + hideClass + ' { display: none; }';
document.getElementsByTagName('head')[0].appendChild(style);

console.log("Script loaded.");

//Wait till the page is done loading...
document.addEventListener("DOMContentLoaded", function(){
    var tables = document.getElementsByClassName(tableClass);
    for (y = 0; y < tables.length; y++) {
        var currentTable = tables[y];
        var rows = currentTable.getElementsByTagName("tr");
        for (i = 0; i < rows.length; i++) {
            
            var currentRow = currentTable.rows[i];
            var cols = currentRow.getElementsByTagName("td");
            for (k = 0; k < cols.length; k++) {
                var currentCol = cols[k];
                if(currentCol.classList.contains(activatorClass)) {
                    var createClickHandler = function(col) {
                        return function() {
                            var siblings = col.parentElement.getElementsByTagName("td");
                            for(m = 0; m < siblings.length; m++) {
                                var currentSibling = siblings[m];
                                if(!currentSibling.classList.contains(activatorClass)) {
                                    if(currentSibling.classList.contains(hideClass)) {
                                        currentSibling.classList.remove(hideClass);
                                    } else {
                                        currentSibling.classList.add(hideClass);
                                    }
                                }
                            }
                        }
                    };
                    currentCol.onclick = createClickHandler(currentCol);
                };    
            }
        }
    }
});