201 lines
7.0 KiB
JavaScript
Vendored
201 lines
7.0 KiB
JavaScript
Vendored
"use strict";
|
|
var KTDatatablesExtensionsKeytable = function() {
|
|
|
|
var initTable1 = function() {
|
|
// begin first table
|
|
var table = $('#kt_datatable_1').DataTable({
|
|
responsive: true,
|
|
select: true,
|
|
columnDefs: [
|
|
{
|
|
targets: -1,
|
|
title: 'Actions',
|
|
orderable: false,
|
|
render: function(data, type, full, meta) {
|
|
return '\
|
|
<div class="dropdown dropdown-inline">\
|
|
<a href="javascript:;" class="btn btn-sm btn-clean btn-icon" data-toggle="dropdown">\
|
|
<i class="la la-cog"></i>\
|
|
</a>\
|
|
<div class="dropdown-menu dropdown-menu-sm dropdown-menu-right">\
|
|
<ul class="nav nav-hoverable flex-column">\
|
|
<li class="nav-item"><a class="nav-link" href="#"><i class="nav-icon la la-edit"></i><span class="nav-text">Edit Details</span></a></li>\
|
|
<li class="nav-item"><a class="nav-link" href="#"><i class="nav-icon la la-leaf"></i><span class="nav-text">Update Status</span></a></li>\
|
|
<li class="nav-item"><a class="nav-link" href="#"><i class="nav-icon la la-print"></i><span class="nav-text">Print</span></a></li>\
|
|
</ul>\
|
|
</div>\
|
|
</div>\
|
|
<a href="javascript:;" class="btn btn-sm btn-clean btn-icon" title="Edit details">\
|
|
<i class="la la-edit"></i>\
|
|
</a>\
|
|
<a href="javascript:;" class="btn btn-sm btn-clean btn-icon" title="Delete">\
|
|
<i class="la la-trash"></i>\
|
|
</a>\
|
|
';
|
|
},
|
|
},
|
|
{
|
|
width: '75px',
|
|
targets: 8,
|
|
render: function(data, type, full, meta) {
|
|
var status = {
|
|
1: {'title': 'Pending', 'class': 'label-light-primary'},
|
|
2: {'title': 'Delivered', 'class': ' label-light-danger'},
|
|
3: {'title': 'Canceled', 'class': ' label-light-primary'},
|
|
4: {'title': 'Success', 'class': ' label-light-success'},
|
|
5: {'title': 'Info', 'class': ' label-light-info'},
|
|
6: {'title': 'Danger', 'class': ' label-light-danger'},
|
|
7: {'title': 'Warning', 'class': ' label-light-warning'},
|
|
};
|
|
if (typeof status[data] === 'undefined') {
|
|
return data;
|
|
}
|
|
return '<span class="label label-lg font-weight-bold' + status[data].class + ' label-inline">' + status[data].title + '</span>';
|
|
},
|
|
},
|
|
{
|
|
width: '75px',
|
|
targets: 9,
|
|
render: function(data, type, full, meta) {
|
|
var status = {
|
|
1: {'title': 'Online', 'state': 'danger'},
|
|
2: {'title': 'Retail', 'state': 'primary'},
|
|
3: {'title': 'Direct', 'state': 'success'},
|
|
};
|
|
if (typeof status[data] === 'undefined') {
|
|
return data;
|
|
}
|
|
return '<span class="label label-' + status[data].state + ' label-dot mr-2"></span>' +
|
|
'<span class="font-weight-bold text-' + status[data].state + '">' + status[data].title + '</span>';
|
|
},
|
|
},
|
|
],
|
|
});
|
|
|
|
};
|
|
|
|
var initTable2 = function() {
|
|
// begin first table
|
|
var table = $('#kt_datatable_2').DataTable({
|
|
responsive: true,
|
|
select: {
|
|
style: 'multi',
|
|
selector: 'td:first-child .checkable',
|
|
},
|
|
headerCallback: function(thead, data, start, end, display) {
|
|
thead.getElementsByTagName('th')[0].innerHTML = `
|
|
<label class="checkbox checkbox-single checkbox-solid checkbox-primary mb-0">
|
|
<input type="checkbox" value="" class="group-checkable"/>
|
|
<span></span>
|
|
</label>`;
|
|
},
|
|
columnDefs: [
|
|
{
|
|
targets: 0,
|
|
orderable: false,
|
|
render: function(data, type, full, meta) {
|
|
return `
|
|
<label class="checkbox checkbox-single checkbox-primary mb-0">
|
|
<input type="checkbox" value="" class="checkable"/>
|
|
<span></span>
|
|
</label>`;
|
|
},
|
|
},
|
|
{
|
|
targets: -1,
|
|
title: 'Actions',
|
|
orderable: false,
|
|
render: function(data, type, full, meta) {
|
|
return '\
|
|
<div class="dropdown dropdown-inline">\
|
|
<a href="javascript:;" class="btn btn-sm btn-clean btn-icon" data-toggle="dropdown">\
|
|
<i class="la la-cog"></i>\
|
|
</a>\
|
|
<div class="dropdown-menu dropdown-menu-sm dropdown-menu-right">\
|
|
<ul class="nav nav-hoverable flex-column">\
|
|
<li class="nav-item"><a class="nav-link" href="#"><i class="nav-icon la la-edit"></i><span class="nav-text">Edit Details</span></a></li>\
|
|
<li class="nav-item"><a class="nav-link" href="#"><i class="nav-icon la la-leaf"></i><span class="nav-text">Update Status</span></a></li>\
|
|
<li class="nav-item"><a class="nav-link" href="#"><i class="nav-icon la la-print"></i><span class="nav-text">Print</span></a></li>\
|
|
</ul>\
|
|
</div>\
|
|
</div>\
|
|
<a href="javascript:;" class="btn btn-sm btn-clean btn-icon" title="Edit details">\
|
|
<i class="la la-edit"></i>\
|
|
</a>\
|
|
<a href="javascript:;" class="btn btn-sm btn-clean btn-icon" title="Delete">\
|
|
<i class="la la-trash"></i>\
|
|
</a>\
|
|
';
|
|
},
|
|
},
|
|
{
|
|
width: '75px',
|
|
targets: 8,
|
|
render: function(data, type, full, meta) {
|
|
var status = {
|
|
1: {'title': 'Pending', 'class': 'label-light-primary'},
|
|
2: {'title': 'Delivered', 'class': ' label-light-danger'},
|
|
3: {'title': 'Canceled', 'class': ' label-light-primary'},
|
|
4: {'title': 'Success', 'class': ' label-light-success'},
|
|
5: {'title': 'Info', 'class': ' label-light-info'},
|
|
6: {'title': 'Danger', 'class': ' label-light-danger'},
|
|
7: {'title': 'Warning', 'class': ' label-light-warning'},
|
|
};
|
|
if (typeof status[data] === 'undefined') {
|
|
return data;
|
|
}
|
|
return '<span class="label label-lg font-weight-bold' + status[data].class + ' label-inline">' + status[data].title + '</span>';
|
|
},
|
|
},
|
|
{
|
|
width: '75px',
|
|
targets: 9,
|
|
render: function(data, type, full, meta) {
|
|
var status = {
|
|
1: {'title': 'Online', 'state': 'danger'},
|
|
2: {'title': 'Retail', 'state': 'primary'},
|
|
3: {'title': 'Direct', 'state': 'success'},
|
|
};
|
|
if (typeof status[data] === 'undefined') {
|
|
return data;
|
|
}
|
|
return '<span class="label label-' + status[data].state + ' label-dot mr-2"></span>' +
|
|
'<span class="font-weight-bold text-' + status[data].state + '">' + status[data].title + '</span>';
|
|
},
|
|
},
|
|
],
|
|
});
|
|
|
|
table.on('change', '.group-checkable', function() {
|
|
var set = $(this).closest('table').find('td:first-child .checkable');
|
|
var checked = $(this).is(':checked');
|
|
|
|
$(set).each(function() {
|
|
if (checked) {
|
|
$(this).prop('checked', true);
|
|
table.rows($(this).closest('tr')).select();
|
|
}
|
|
else {
|
|
$(this).prop('checked', false);
|
|
table.rows($(this).closest('tr')).deselect();
|
|
}
|
|
});
|
|
});
|
|
};
|
|
|
|
return {
|
|
|
|
//main function to initiate the module
|
|
init: function() {
|
|
initTable1();
|
|
initTable2();
|
|
},
|
|
|
|
};
|
|
|
|
}();
|
|
|
|
jQuery(document).ready(function() {
|
|
KTDatatablesExtensionsKeytable.init();
|
|
});
|