create TableController to access more easy to table info

This commit is contained in:
RubenPX 2022-04-29 11:36:55 +02:00
parent 962f7cb94c
commit f26b441fef
2 changed files with 35 additions and 2 deletions

View file

@ -27,7 +27,8 @@
"strict": "off",
"class-methods-use-this": "off",
"eqeqeq": "warn",
"radix": "warn"
"radix": "warn",
"max-classes-per-file": ["error", 2]
},
"globals": {
"API_URLS": true,

View file

@ -17,6 +17,38 @@ $(document).ready(() => {
// $('#selectLot').selectpicker();
})
class TableController {
static #tableRows = table.rows().dt.activeRows;
/**
* @returns This will return all input attributes from selected devices
*/
static getSelectedDevices() {
return this.#ProcessTR(this.#tableRows.filter(element => element.querySelector("input").checked))
}
/**
* @returns This will return all input attributes from all devices in list
*/
static getAllDevices() {
return this.#ProcessTR(this.#tableRows)
}
/**
*
* @param {HTMLElement} DOMElements
* @returns Procesed input atributes to an Object class
*/
static #ProcessTR(DOMElements) {
return DOMElements.map(element => {
const info = {}
info.checked = element.querySelector("input").checked
Object.values(element.querySelector("input").attributes).forEach(attrib => {info[attrib.nodeName] = attrib.nodeValue})
return info
})
}
}
function deviceSelect() {
const devices_count = $(".deviceSelect").filter(":checked").length;
get_device_list();
@ -340,7 +372,7 @@ async function processSelectedDevices() {
const listHTML = $("#LotsSelector")
// Get selected devices
const selectedDevicesID = table.rows().dt.activeRows.filter(item => item.querySelector("input").checked).map(item => item.querySelector("input").attributes.data.value)
const selectedDevicesID = TableController.getSelectedDevices().map(item => item.data)
if (selectedDevicesID.length <= 0) {
listHTML.html("<li style=\"color: red; text-align: center\">No devices selected</li>");