mirror of
https://github.com/cwinfo/powerdns-admin.git
synced 2025-01-25 03:04:39 +00:00
621 lines
24 KiB
JavaScript
621 lines
24 KiB
JavaScript
|
var TableManaged = function () {
|
||
|
|
||
|
var initTableDomain = function () {
|
||
|
|
||
|
var table = $('#tb_domain_list');
|
||
|
|
||
|
// begin first table
|
||
|
table.dataTable({
|
||
|
|
||
|
// Internationalisation. For more info refer to http://datatables.net/manual/i18n
|
||
|
"language": {
|
||
|
"aria": {
|
||
|
"sortAscending": ": activate to sort column ascending",
|
||
|
"sortDescending": ": activate to sort column descending"
|
||
|
},
|
||
|
"emptyTable": "No data available in table",
|
||
|
"info": "Showing _START_ to _END_ of _TOTAL_ domains",
|
||
|
"infoEmpty": "No domains found",
|
||
|
"infoFiltered": "(filtered1 from _MAX_ total domains)",
|
||
|
"lengthMenu": "Show _MENU_ domains",
|
||
|
"search": "Search:",
|
||
|
"zeroRecords": "No matching records found"
|
||
|
},
|
||
|
|
||
|
// Or you can use remote translation file
|
||
|
//"language": {
|
||
|
// url: '//cdn.datatables.net/plug-ins/3cfcc339e89/i18n/Portuguese.json'
|
||
|
//},
|
||
|
|
||
|
// Uncomment below line("dom" parameter) to fix the dropdown overflow issue in the datatable cells. The default datatable layout
|
||
|
// setup uses scrollable div(table-scrollable) with overflow:auto to enable vertical scroll(see: assets/global/plugins/datatables/plugins/bootstrap/dataTables.bootstrap.js).
|
||
|
// So when dropdowns used the scrollable div should be removed.
|
||
|
//"dom": "<'row'<'col-md-6 col-sm-12'l><'col-md-6 col-sm-12'f>r>t<'row'<'col-md-5 col-sm-12'i><'col-md-7 col-sm-12'p>>",
|
||
|
|
||
|
"bStateSave": true, // save datatable state(pagination, sort, etc) in cookie.
|
||
|
|
||
|
"columns": [{
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": false
|
||
|
}],
|
||
|
"lengthMenu": [
|
||
|
[5, 15, 20, -1],
|
||
|
[5, 15, 20, "All"] // change per page values here
|
||
|
],
|
||
|
// set the initial value
|
||
|
"pageLength": 5,
|
||
|
"pagingType": "bootstrap_full_number",
|
||
|
"language": {
|
||
|
"search": "My search: ",
|
||
|
"lengthMenu": " _MENU_ records",
|
||
|
"paginate": {
|
||
|
"previous":"Prev",
|
||
|
"next": "Next",
|
||
|
"last": "Last",
|
||
|
"first": "First"
|
||
|
}
|
||
|
},
|
||
|
"columnDefs": [{ // set default column settings
|
||
|
'orderable': false,
|
||
|
'targets': [0]
|
||
|
}, {
|
||
|
"searchable": false,
|
||
|
"targets": [0]
|
||
|
}],
|
||
|
"order": [
|
||
|
[1, "asc"]
|
||
|
] // set first column as a default sort by asc
|
||
|
});
|
||
|
|
||
|
var tableWrapper = jQuery('#tb_domain_list_wrapper');
|
||
|
|
||
|
table.find('.group-checkable').change(function () {
|
||
|
var set = jQuery(this).attr("data-set");
|
||
|
var checked = jQuery(this).is(":checked");
|
||
|
jQuery(set).each(function () {
|
||
|
if (checked) {
|
||
|
$(this).attr("checked", true);
|
||
|
$(this).parents('tr').addClass("active");
|
||
|
} else {
|
||
|
$(this).attr("checked", false);
|
||
|
$(this).parents('tr').removeClass("active");
|
||
|
}
|
||
|
});
|
||
|
jQuery.uniform.update(set);
|
||
|
});
|
||
|
|
||
|
table.on('change', 'tbody tr .checkboxes', function () {
|
||
|
$(this).parents('tr').toggleClass("active");
|
||
|
});
|
||
|
|
||
|
tableWrapper.find('.dataTables_length select').addClass("form-control input-xsmall input-inline"); // modify table per page dropdown
|
||
|
}
|
||
|
|
||
|
var initTableConfig = function () {
|
||
|
|
||
|
var table = $('#tb_config_list');
|
||
|
|
||
|
// begin first table
|
||
|
table.dataTable({
|
||
|
|
||
|
// Internationalisation. For more info refer to http://datatables.net/manual/i18n
|
||
|
"language": {
|
||
|
"aria": {
|
||
|
"sortAscending": ": activate to sort column ascending",
|
||
|
"sortDescending": ": activate to sort column descending"
|
||
|
},
|
||
|
"emptyTable": "No data available in table",
|
||
|
"info": "Showing _START_ to _END_ of _TOTAL_ configs",
|
||
|
"infoEmpty": "No configs found",
|
||
|
"infoFiltered": "(filtered1 from _MAX_ total configs)",
|
||
|
"lengthMenu": "Show _MENU_ configs",
|
||
|
"search": "Search:",
|
||
|
"zeroRecords": "No matching configs found"
|
||
|
},
|
||
|
|
||
|
// Or you can use remote translation file
|
||
|
//"language": {
|
||
|
// url: '//cdn.datatables.net/plug-ins/3cfcc339e89/i18n/Portuguese.json'
|
||
|
//},
|
||
|
|
||
|
// Uncomment below line("dom" parameter) to fix the dropdown overflow issue in the datatable cells. The default datatable layout
|
||
|
// setup uses scrollable div(table-scrollable) with overflow:auto to enable vertical scroll(see: assets/global/plugins/datatables/plugins/bootstrap/dataTables.bootstrap.js).
|
||
|
// So when dropdowns used the scrollable div should be removed.
|
||
|
//"dom": "<'row'<'col-md-6 col-sm-12'l><'col-md-6 col-sm-12'f>r>t<'row'<'col-md-5 col-sm-12'i><'col-md-7 col-sm-12'p>>",
|
||
|
|
||
|
"bStateSave": true, // save datatable state(pagination, sort, etc) in cookie.
|
||
|
|
||
|
"columns": [{
|
||
|
"orderable": false
|
||
|
}, {
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": true
|
||
|
}],
|
||
|
"lengthMenu": [
|
||
|
[5, 15, 20, -1],
|
||
|
[5, 15, 20, "All"] // change per page values here
|
||
|
],
|
||
|
// set the initial value
|
||
|
"pageLength": 20,
|
||
|
"pagingType": "bootstrap_full_number",
|
||
|
"language": {
|
||
|
"search": "Search: ",
|
||
|
"lengthMenu": " _MENU_ configs",
|
||
|
"paginate": {
|
||
|
"previous":"Prev",
|
||
|
"next": "Next",
|
||
|
"last": "Last",
|
||
|
"first": "First"
|
||
|
}
|
||
|
},
|
||
|
"columnDefs": [{ // set default column settings
|
||
|
'orderable': false,
|
||
|
'targets': [0]
|
||
|
}, {
|
||
|
"searchable": false,
|
||
|
"targets": [0]
|
||
|
}],
|
||
|
"order": [
|
||
|
[2, "asc"]
|
||
|
] // set first column as a default sort by asc
|
||
|
});
|
||
|
|
||
|
var tableWrapper = jQuery('#tb_config_list_wrapper');
|
||
|
|
||
|
table.find('.group-checkable').change(function () {
|
||
|
var set = jQuery(this).attr("data-set");
|
||
|
var checked = jQuery(this).is(":checked");
|
||
|
jQuery(set).each(function () {
|
||
|
if (checked) {
|
||
|
$(this).attr("checked", true);
|
||
|
$(this).parents('tr').addClass("active");
|
||
|
} else {
|
||
|
$(this).attr("checked", false);
|
||
|
$(this).parents('tr').removeClass("active");
|
||
|
}
|
||
|
});
|
||
|
jQuery.uniform.update(set);
|
||
|
});
|
||
|
|
||
|
table.on('change', 'tbody tr .checkboxes', function () {
|
||
|
$(this).parents('tr').toggleClass("active");
|
||
|
});
|
||
|
|
||
|
tableWrapper.find('.dataTables_length select').addClass("form-control input-xsmall input-inline"); // modify table per page dropdown
|
||
|
}
|
||
|
|
||
|
var initTableStastic = function () {
|
||
|
|
||
|
var table = $('#tb_stastic_list');
|
||
|
|
||
|
// begin first table
|
||
|
table.dataTable({
|
||
|
|
||
|
// Internationalisation. For more info refer to http://datatables.net/manual/i18n
|
||
|
"language": {
|
||
|
"aria": {
|
||
|
"sortAscending": ": activate to sort column ascending",
|
||
|
"sortDescending": ": activate to sort column descending"
|
||
|
},
|
||
|
"emptyTable": "No data available in table",
|
||
|
"info": "Showing _START_ to _END_ of _TOTAL_ stastics",
|
||
|
"infoEmpty": "No stastics found",
|
||
|
"infoFiltered": "(filtered1 from _MAX_ total stastics)",
|
||
|
"lengthMenu": "Show _MENU_ stastics",
|
||
|
"search": "Search:",
|
||
|
"zeroRecords": "No matching stastics found"
|
||
|
},
|
||
|
|
||
|
// Or you can use remote translation file
|
||
|
//"language": {
|
||
|
// url: '//cdn.datatables.net/plug-ins/3cfcc339e89/i18n/Portuguese.json'
|
||
|
//},
|
||
|
|
||
|
// Uncomment below line("dom" parameter) to fix the dropdown overflow issue in the datatable cells. The default datatable layout
|
||
|
// setup uses scrollable div(table-scrollable) with overflow:auto to enable vertical scroll(see: assets/global/plugins/datatables/plugins/bootstrap/dataTables.bootstrap.js).
|
||
|
// So when dropdowns used the scrollable div should be removed.
|
||
|
//"dom": "<'row'<'col-md-6 col-sm-12'l><'col-md-6 col-sm-12'f>r>t<'row'<'col-md-5 col-sm-12'i><'col-md-7 col-sm-12'p>>",
|
||
|
|
||
|
"bStateSave": true, // save datatable state(pagination, sort, etc) in cookie.
|
||
|
|
||
|
"columns": [{
|
||
|
"orderable": false
|
||
|
}, {
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": true
|
||
|
}],
|
||
|
"lengthMenu": [
|
||
|
[5, 15, 20, -1],
|
||
|
[5, 15, 20, "All"] // change per page values here
|
||
|
],
|
||
|
// set the initial value
|
||
|
"pageLength": 20,
|
||
|
"pagingType": "bootstrap_full_number",
|
||
|
"language": {
|
||
|
"search": "Search: ",
|
||
|
"lengthMenu": " _MENU_ stastics",
|
||
|
"paginate": {
|
||
|
"previous":"Prev",
|
||
|
"next": "Next",
|
||
|
"last": "Last",
|
||
|
"first": "First"
|
||
|
}
|
||
|
},
|
||
|
"columnDefs": [{ // set default column settings
|
||
|
'orderable': false,
|
||
|
'targets': [0]
|
||
|
}, {
|
||
|
"searchable": false,
|
||
|
"targets": [0]
|
||
|
}],
|
||
|
"order": [
|
||
|
[2, "asc"]
|
||
|
] // set first column as a default sort by asc
|
||
|
});
|
||
|
|
||
|
var tableWrapper = jQuery('#tb_stastic_list_wrapper');
|
||
|
|
||
|
table.find('.group-checkable').change(function () {
|
||
|
var set = jQuery(this).attr("data-set");
|
||
|
var checked = jQuery(this).is(":checked");
|
||
|
jQuery(set).each(function () {
|
||
|
if (checked) {
|
||
|
$(this).attr("checked", true);
|
||
|
$(this).parents('tr').addClass("active");
|
||
|
} else {
|
||
|
$(this).attr("checked", false);
|
||
|
$(this).parents('tr').removeClass("active");
|
||
|
}
|
||
|
});
|
||
|
jQuery.uniform.update(set);
|
||
|
});
|
||
|
|
||
|
table.on('change', 'tbody tr .checkboxes', function () {
|
||
|
$(this).parents('tr').toggleClass("active");
|
||
|
});
|
||
|
|
||
|
tableWrapper.find('.dataTables_length select').addClass("form-control input-xsmall input-inline"); // modify table per page dropdown
|
||
|
}
|
||
|
|
||
|
var initTableUser = function () {
|
||
|
|
||
|
function applyChanges(data, url, showResult){
|
||
|
$.ajax({
|
||
|
type: "POST",
|
||
|
url: url,
|
||
|
data: JSON.stringify(data),// now data come in this function
|
||
|
contentType: "application/json; charset=utf-8",
|
||
|
crossDomain: true,
|
||
|
dataType: "json",
|
||
|
success: function (data, status, jqXHR) {
|
||
|
if (showResult){
|
||
|
bootbox.alert("Applied changes successfully.");
|
||
|
}
|
||
|
else{
|
||
|
console.log("Applied changes successfully.")
|
||
|
}
|
||
|
},
|
||
|
|
||
|
error: function (jqXHR, status) {
|
||
|
// error handler
|
||
|
console.log(jqXHR);
|
||
|
a = jqXHR;
|
||
|
bootbox.alert(jqXHR["responseText"]);
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
|
||
|
var table = $('#tbl_user_manage');
|
||
|
|
||
|
// begin first table
|
||
|
table.dataTable({
|
||
|
|
||
|
// Internationalisation. For more info refer to http://datatables.net/manual/i18n
|
||
|
"language": {
|
||
|
"aria": {
|
||
|
"sortAscending": ": activate to sort column ascending",
|
||
|
"sortDescending": ": activate to sort column descending"
|
||
|
},
|
||
|
"emptyTable": "No data available in table",
|
||
|
"info": "Showing _START_ to _END_ of _TOTAL_ users",
|
||
|
"infoEmpty": "No users found",
|
||
|
"infoFiltered": "(filtered1 from _MAX_ total users)",
|
||
|
"lengthMenu": "Show _MENU_ users",
|
||
|
"search": "Search:",
|
||
|
"zeroRecords": "No matching users found"
|
||
|
},
|
||
|
|
||
|
// Or you can use remote translation file
|
||
|
//"language": {
|
||
|
// url: '//cdn.datatables.net/plug-ins/3cfcc339e89/i18n/Portuguese.json'
|
||
|
//},
|
||
|
|
||
|
// Uncomment below line("dom" parameter) to fix the dropdown overflow issue in the datatable cells. The default datatable layout
|
||
|
// setup uses scrollable div(table-scrollable) with overflow:auto to enable vertical scroll(see: assets/global/plugins/datatables/plugins/bootstrap/dataTables.bootstrap.js).
|
||
|
// So when dropdowns used the scrollable div should be removed.
|
||
|
//"dom": "<'row'<'col-md-6 col-sm-12'l><'col-md-6 col-sm-12'f>r>t<'row'<'col-md-5 col-sm-12'i><'col-md-7 col-sm-12'p>>",
|
||
|
|
||
|
"bStateSave": true, // save datatable state(pagination, sort, etc) in cookie.
|
||
|
|
||
|
"columns": [{
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": false
|
||
|
}, {
|
||
|
"orderable": false
|
||
|
}, {
|
||
|
"orderable": false
|
||
|
}],
|
||
|
"lengthMenu": [
|
||
|
[5, 15, 20, -1],
|
||
|
[5, 15, 20, "All"] // change per page values here
|
||
|
],
|
||
|
// set the initial value
|
||
|
"pageLength": 5,
|
||
|
"pagingType": "bootstrap_full_number",
|
||
|
"language": {
|
||
|
"search": "Search: ",
|
||
|
"lengthMenu": " _MENU_ users",
|
||
|
"paginate": {
|
||
|
"previous":"Prev",
|
||
|
"next": "Next",
|
||
|
"last": "Last",
|
||
|
"first": "First"
|
||
|
}
|
||
|
},
|
||
|
"columnDefs": [{ // set default column settings
|
||
|
'orderable': false,
|
||
|
'targets': [0]
|
||
|
}, {
|
||
|
"searchable": true,
|
||
|
"targets": [0]
|
||
|
}],
|
||
|
"order": [
|
||
|
[1, "asc"]
|
||
|
] // set first column as a default sort by asc
|
||
|
});
|
||
|
|
||
|
var tableWrapper = jQuery('#tb_user_manage_wrapper');
|
||
|
|
||
|
table.find('.group-checkable').change(function () {
|
||
|
var set = jQuery(this).attr("data-set");
|
||
|
var checked = jQuery(this).is(":checked");
|
||
|
jQuery(set).each(function () {
|
||
|
if (checked) {
|
||
|
$(this).attr("checked", true);
|
||
|
$(this).parents('tr').addClass("active");
|
||
|
} else {
|
||
|
$(this).attr("checked", false);
|
||
|
$(this).parents('tr').removeClass("active");
|
||
|
}
|
||
|
});
|
||
|
jQuery.uniform.update(set);
|
||
|
});
|
||
|
|
||
|
table.on('change', 'tbody tr .checkboxes', function () {
|
||
|
$(this).parents('tr').toggleClass("active");
|
||
|
});
|
||
|
|
||
|
tableWrapper.find('.dataTables_length select').addClass("form-control input-xsmall input-inline"); // modify table per page dropdown
|
||
|
|
||
|
|
||
|
// Buton action handling
|
||
|
table.on('click', '.revoke', function (e) {
|
||
|
e.preventDefault();
|
||
|
|
||
|
var nRow = $(this).parents('tr')[0];
|
||
|
var username = nRow.cells.item(0).innerText;
|
||
|
|
||
|
bootbox.confirm("Are you sure to revoke all " + username+ "'s privileges?. He will not able to access to any domain.", function(result) {
|
||
|
if (result == true){
|
||
|
var postdata = {'action': 'revoke_user_privielges', 'data': username}
|
||
|
applyChanges(postdata, '/admin/manageuser');
|
||
|
}
|
||
|
});
|
||
|
});
|
||
|
|
||
|
table.on('click', '.delete', function (e) {
|
||
|
e.preventDefault();
|
||
|
|
||
|
var nRow = $(this).parents('tr')[0];
|
||
|
var username = nRow.cells.item(0).innerText;
|
||
|
|
||
|
bootbox.confirm("Are you sure to delete user " + username + "?", function(result) {
|
||
|
if (result == true){
|
||
|
var postdata = {'action': 'delete_user', 'data': username}
|
||
|
applyChanges(postdata, '/admin/manageuser');
|
||
|
}
|
||
|
});
|
||
|
});
|
||
|
|
||
|
table.on('change', '.ck_admin', function (e) {
|
||
|
e.preventDefault();
|
||
|
|
||
|
var nRow = $(this).parents('tr')[0];
|
||
|
var username = nRow.cells.item(0).innerText;
|
||
|
var ckadmin = document.getElementById("ck_admin_" + username).checked;
|
||
|
|
||
|
if (ckadmin){
|
||
|
postdata = {'action': 'set_admin', 'data': {'username': username, 'is_admin': true}};
|
||
|
applyChanges(postdata, '/admin/manageuser');
|
||
|
}
|
||
|
else{
|
||
|
postdata = {'action': 'set_admin', 'data': {'username': username, 'is_admin': false}};
|
||
|
applyChanges(postdata, '/admin/manageuser');
|
||
|
}
|
||
|
});
|
||
|
|
||
|
}
|
||
|
|
||
|
var initTableHistory = function () {
|
||
|
|
||
|
function applyChanges(data, url, showResult){
|
||
|
$.ajax({
|
||
|
type: "POST",
|
||
|
url: url,
|
||
|
data: JSON.stringify(data),// now data come in this function
|
||
|
contentType: "application/json; charset=utf-8",
|
||
|
crossDomain: true,
|
||
|
dataType: "json",
|
||
|
success: function (data, status, jqXHR) {
|
||
|
if (showResult){
|
||
|
bootbox.alert("Applied changes successfully.");
|
||
|
}
|
||
|
else{
|
||
|
console.log("Applied changes successfully.")
|
||
|
}
|
||
|
},
|
||
|
|
||
|
error: function (jqXHR, status) {
|
||
|
// error handler
|
||
|
console.log(jqXHR);
|
||
|
a = jqXHR;
|
||
|
bootbox.alert(jqXHR["responseText"]);
|
||
|
}
|
||
|
});
|
||
|
}
|
||
|
|
||
|
var table = $('#tbl_history');
|
||
|
|
||
|
// begin first table
|
||
|
table.dataTable({
|
||
|
|
||
|
// Internationalisation. For more info refer to http://datatables.net/manual/i18n
|
||
|
"language": {
|
||
|
"aria": {
|
||
|
"sortAscending": ": activate to sort column ascending",
|
||
|
"sortDescending": ": activate to sort column descending"
|
||
|
},
|
||
|
"emptyTable": "No data available in table",
|
||
|
"info": "Showing _START_ to _END_ of _TOTAL_ histories",
|
||
|
"infoEmpty": "No histories found",
|
||
|
"infoFiltered": "(filtered1 from _MAX_ total histories)",
|
||
|
"lengthMenu": "Show _MENU_ histories",
|
||
|
"search": "Search:",
|
||
|
"zeroRecords": "No matching histories found"
|
||
|
},
|
||
|
|
||
|
// Or you can use remote translation file
|
||
|
//"language": {
|
||
|
// url: '//cdn.datatables.net/plug-ins/3cfcc339e89/i18n/Portuguese.json'
|
||
|
//},
|
||
|
|
||
|
// Uncomment below line("dom" parameter) to fix the dropdown overflow issue in the datatable cells. The default datatable layout
|
||
|
// setup uses scrollable div(table-scrollable) with overflow:auto to enable vertical scroll(see: assets/global/plugins/datatables/plugins/bootstrap/dataTables.bootstrap.js).
|
||
|
// So when dropdowns used the scrollable div should be removed.
|
||
|
//"dom": "<'row'<'col-md-6 col-sm-12'l><'col-md-6 col-sm-12'f>r>t<'row'<'col-md-5 col-sm-12'i><'col-md-7 col-sm-12'p>>",
|
||
|
|
||
|
"bStateSave": true, // save datatable state(pagination, sort, etc) in cookie.
|
||
|
|
||
|
"columns": [{
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": true
|
||
|
}, {
|
||
|
"orderable": false
|
||
|
}],
|
||
|
"lengthMenu": [
|
||
|
[5, 15, 20, -1],
|
||
|
[5, 15, 20, "All"] // change per page values here
|
||
|
],
|
||
|
// set the initial value
|
||
|
"pageLength": 20,
|
||
|
"pagingType": "bootstrap_full_number",
|
||
|
"language": {
|
||
|
"search": "Search: ",
|
||
|
"lengthMenu": " _MENU_ histories",
|
||
|
"paginate": {
|
||
|
"previous":"Prev",
|
||
|
"next": "Next",
|
||
|
"last": "Last",
|
||
|
"first": "First"
|
||
|
}
|
||
|
},
|
||
|
"columnDefs": [{ // set default column settings
|
||
|
'orderable': false,
|
||
|
'targets': [0]
|
||
|
}, {
|
||
|
"searchable": true,
|
||
|
"targets": [0]
|
||
|
}],
|
||
|
"order": [
|
||
|
[2 , "desc"]
|
||
|
] // set first time column as a default sort by desc
|
||
|
});
|
||
|
|
||
|
var tableWrapper = jQuery('#tbl_history_wrapper');
|
||
|
|
||
|
table.find('.group-checkable').change(function () {
|
||
|
var set = jQuery(this).attr("data-set");
|
||
|
var checked = jQuery(this).is(":checked");
|
||
|
jQuery(set).each(function () {
|
||
|
if (checked) {
|
||
|
$(this).attr("checked", true);
|
||
|
$(this).parents('tr').addClass("active");
|
||
|
} else {
|
||
|
$(this).attr("checked", false);
|
||
|
$(this).parents('tr').removeClass("active");
|
||
|
}
|
||
|
});
|
||
|
jQuery.uniform.update(set);
|
||
|
});
|
||
|
|
||
|
table.on('change', 'tbody tr .checkboxes', function () {
|
||
|
$(this).parents('tr').toggleClass("active");
|
||
|
});
|
||
|
|
||
|
tableWrapper.find('.dataTables_length select').addClass("form-control input-xsmall input-inline"); // modify table per page dropdown
|
||
|
|
||
|
table.on('click', '.history_detail', function (e) {
|
||
|
e.preventDefault();
|
||
|
var nRow = $(this).parents('tr')[0];
|
||
|
var detail = nRow.cells.item(3).children[0].value;
|
||
|
bootbox.alert(detail);
|
||
|
});
|
||
|
|
||
|
$('#tbl_history_clear').click(function (e) {
|
||
|
e.preventDefault();
|
||
|
bootbox.confirm("Are you sure you want to remove all history?", function(result) {
|
||
|
if (result == true){
|
||
|
applyChanges('', '/admin/history');
|
||
|
location.reload();
|
||
|
}
|
||
|
});
|
||
|
});
|
||
|
|
||
|
}
|
||
|
|
||
|
|
||
|
return {
|
||
|
|
||
|
//main function to initiate the module
|
||
|
init: function () {
|
||
|
if (!jQuery().dataTable) {
|
||
|
return;
|
||
|
}
|
||
|
|
||
|
initTableDomain();
|
||
|
initTableConfig();
|
||
|
initTableStastic();
|
||
|
initTableUser();
|
||
|
initTableHistory();
|
||
|
}
|
||
|
|
||
|
};
|
||
|
|
||
|
}();
|