96 lines
3.0 KiB
JavaScript
96 lines
3.0 KiB
JavaScript
/*
|
|
* This file is part of the Kimai time-tracking app.
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
/*!
|
|
* [KIMAI] KimaiDatatableColumnView: manages the visibility of data-table columns in cookies
|
|
*/
|
|
|
|
import Cookies from 'js-cookie';
|
|
import jQuery from 'jquery';
|
|
import KimaiPlugin from "../KimaiPlugin";
|
|
|
|
export default class KimaiDatatableColumnView extends KimaiPlugin {
|
|
|
|
constructor(dataAttribute) {
|
|
super();
|
|
this.dataAttribute = dataAttribute;
|
|
}
|
|
|
|
getId() {
|
|
return 'datatable-column-visibility';
|
|
}
|
|
|
|
init() {
|
|
let dataTable = document.querySelector('[' + this.dataAttribute + ']');
|
|
if (dataTable === null) {
|
|
return;
|
|
}
|
|
this.id = dataTable.getAttribute(this.dataAttribute);
|
|
this.modal = document.getElementById('modal_' + this.id);
|
|
this.bindButtons();
|
|
}
|
|
|
|
bindButtons() {
|
|
let self = this;
|
|
this.modal.querySelector('button[data-type=save]').addEventListener('click', function() {
|
|
self.saveVisibility();
|
|
});
|
|
this.modal.querySelector('button[data-type=reset]').addEventListener('click', function() {
|
|
self.resetVisibility();
|
|
});
|
|
for (let checkbox of this.modal.querySelectorAll('form input[type=checkbox]')) {
|
|
checkbox.addEventListener('click', function () {
|
|
self.changeVisibility(checkbox.getAttribute('name'));
|
|
});
|
|
}
|
|
}
|
|
|
|
saveVisibility() {
|
|
const form = this.modal.getElementsByTagName('form')[0];
|
|
let settings = {};
|
|
for (let checkbox of form.querySelectorAll('input[type=checkbox]')) {
|
|
settings[checkbox.getAttribute('name')] = checkbox.checked;
|
|
}
|
|
Cookies.set(form.getAttribute('name'), JSON.stringify(settings), {expires: 365});
|
|
jQuery(this.modal).modal('toggle');
|
|
}
|
|
|
|
resetVisibility() {
|
|
const form = this.modal.getElementsByTagName('form')[0];
|
|
Cookies.remove(form.getAttribute('name'));
|
|
for (let checkbox of form.querySelectorAll('input[type=checkbox]')) {
|
|
if (!checkbox.checked) {
|
|
checkbox.click();
|
|
}
|
|
}
|
|
jQuery(this.modal).modal('toggle');
|
|
}
|
|
|
|
changeVisibility(columnName) {
|
|
const table = document.getElementById('datatable_' + this.id).getElementsByClassName('dataTable')[0];
|
|
let column = 0;
|
|
let foundColumn = false;
|
|
for (let columnElement of table.getElementsByTagName('th')) {
|
|
if (columnElement.getAttribute('data-field') === columnName) {
|
|
foundColumn = true;
|
|
break;
|
|
}
|
|
column++;
|
|
}
|
|
|
|
if (!foundColumn) {
|
|
console.error('Could not find column: ' + columnName);
|
|
return;
|
|
}
|
|
|
|
for (let rowElement of table.getElementsByTagName('tr')) {
|
|
rowElement.children[column].classList.toggle('hidden');
|
|
}
|
|
}
|
|
|
|
}
|