103 lines
3.3 KiB
JavaScript
Executable File
103 lines
3.3 KiB
JavaScript
Executable File
"use strict";
|
|
var KTDatatablesAdvancedRowGrouping = function() {
|
|
|
|
var initTable1 = function() {
|
|
var table = $('#kt_table_1');
|
|
|
|
// begin first table
|
|
table.DataTable({
|
|
responsive: true,
|
|
pageLength: 25,
|
|
order: [[2, 'asc']],
|
|
drawCallback: function(settings) {
|
|
var api = this.api();
|
|
var rows = api.rows({page: 'current'}).nodes();
|
|
var last = null;
|
|
|
|
api.column(2, {page: 'current'}).data().each(function(group, i) {
|
|
if (last !== group) {
|
|
$(rows).eq(i).before(
|
|
'<tr class="group"><td colspan="10">' + group + '</td></tr>',
|
|
);
|
|
last = group;
|
|
}
|
|
});
|
|
},
|
|
columnDefs: [
|
|
{
|
|
// hide columns by index number
|
|
targets: [0, 2],
|
|
visible: false,
|
|
},
|
|
{
|
|
targets: -1,
|
|
title: 'Actions',
|
|
orderable: false,
|
|
render: function(data, type, full, meta) {
|
|
return `
|
|
<span class="dropdown">
|
|
<a href="#" class="btn btn-sm btn-clean btn-icon btn-icon-md" data-toggle="dropdown" aria-expanded="true">
|
|
<i class="la la-ellipsis-h"></i>
|
|
</a>
|
|
<div class="dropdown-menu dropdown-menu-right">
|
|
<a class="dropdown-item" href="#"><i class="la la-edit"></i> Edit Details</a>
|
|
<a class="dropdown-item" href="#"><i class="la la-leaf"></i> Update Status</a>
|
|
<a class="dropdown-item" href="#"><i class="la la-print"></i> Generate Report</a>
|
|
</div>
|
|
</span>
|
|
<a href="#" class="btn btn-sm btn-clean btn-icon btn-icon-md" title="View">
|
|
<i class="la la-edit"></i>
|
|
</a>`;
|
|
},
|
|
},
|
|
{
|
|
targets: 8,
|
|
render: function(data, type, full, meta) {
|
|
var status = {
|
|
1: {'title': 'Pending', 'class': 'kt-badge--brand'},
|
|
2: {'title': 'Delivered', 'class': ' kt-badge--danger'},
|
|
3: {'title': 'Canceled', 'class': ' kt-badge--primary'},
|
|
4: {'title': 'Success', 'class': ' kt-badge--success'},
|
|
5: {'title': 'Info', 'class': ' kt-badge--info'},
|
|
6: {'title': 'Danger', 'class': ' kt-badge--danger'},
|
|
7: {'title': 'Warning', 'class': ' kt-badge--warning'},
|
|
};
|
|
if (typeof status[data] === 'undefined') {
|
|
return data;
|
|
}
|
|
return '<span class="kt-badge ' + status[data].class + ' kt-badge--inline kt-badge--pill">' + status[data].title + '</span>';
|
|
},
|
|
},
|
|
{
|
|
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="kt-badge kt-badge--' + status[data].state + ' kt-badge--dot"></span> ' +
|
|
'<span class="kt-font-bold kt-font-' + status[data].state + '">' + status[data].title + '</span>';
|
|
},
|
|
},
|
|
],
|
|
});
|
|
};
|
|
|
|
return {
|
|
|
|
//main function to initiate the module
|
|
init: function() {
|
|
initTable1();
|
|
},
|
|
|
|
};
|
|
|
|
}();
|
|
|
|
jQuery(document).ready(function() {
|
|
KTDatatablesAdvancedRowGrouping.init();
|
|
}); |