/** * App user list */ $(function () { 'use strict'; var dataTablePermissions = $('.datatables-permissions'), assetPath = '../../../app-assets/', dt_permission, userList = 'app-user-list.html'; if ($('body').attr('data-framework') === 'laravel') { assetPath = $('body').attr('data-asset-path'); userList = assetPath + 'app/user/list'; } // Users List datatable if (dataTablePermissions.length) { dt_permission = dataTablePermissions.DataTable({ ajax: assetPath + 'data/permissions-list.json', // JSON file to add data columns: [ // columns according to JSON { data: '' }, { data: 'id' }, { data: 'name' }, { data: 'assigned_to' }, { data: 'created_date' }, { data: '' } ], columnDefs: [ { // For Responsive className: 'control', orderable: false, responsivePriority: 2, targets: 0, render: function (data, type, full, meta) { return ''; } }, { targets: 1, visible: false }, { // remove ordering from Name targets: 2, orderable: false }, { // User Role targets: 3, orderable: false, render: function (data, type, full, meta) { var $assignedTo = full['assigned_to'], $output = ''; var roleBadgeObj = { Admin: 'Administrator', Manager: 'Manager', Users: 'Users', Support: 'Support', Restricted: 'Restricted User' }; for (var i = 0; i < $assignedTo.length; i++) { var val = $assignedTo[i]; $output += roleBadgeObj[val]; } return $output; } }, { // Actions targets: -1, title: 'Actions', orderable: false, render: function (data, type, full, meta) { return ( '' + '' ); } } ], order: [[1, 'asc']], dom: '<"d-flex justify-content-between align-items-center header-actions text-nowrap mx-1 row mt-75"' + '<"col-sm-12 col-lg-4 d-flex justify-content-center justify-content-lg-start" l>' + '<"col-sm-12 col-lg-8"<"dt-action-buttons d-flex align-items-center justify-content-lg-end justify-content-center flex-md-nowrap flex-wrap"<"me-1"f><"user_role mt-50 width-200 me-1">B>>' + '><"text-nowrap" t>' + '<"d-flex justify-content-between mx-2 row mb-1"' + '<"col-sm-12 col-md-6"i>' + '<"col-sm-12 col-md-6"p>' + '>', language: { sLengthMenu: 'Show _MENU_', search: 'Search', searchPlaceholder: 'Search..' }, // Buttons with Dropdown buttons: [ { text: 'Add Permission', className: 'add-new btn btn-primary mt-50', attr: { 'data-bs-toggle': 'modal', 'data-bs-target': '#addPermissionModal' }, init: function (api, node, config) { $(node).removeClass('btn-secondary'); } } ], // For responsive popup responsive: { details: { display: $.fn.dataTable.Responsive.display.modal({ header: function (row) { var data = row.data(); return 'Details of Permission'; } }), type: 'column', renderer: function (api, rowIdx, columns) { var data = $.map(columns, function (col, i) { return col.title !== '' // ? Do not show row in modal popup if title is blank (for check box) ? '' + '' + col.title + ':' + ' ' + '' + col.data + '' + '' : ''; }).join(''); return data ? $('').append(data) : false; } } }, language: { paginate: { // remove previous & next text from pagination previous: ' ', next: ' ' } }, initComplete: function () { // Adding role filter once table initialized this.api() .columns(3) .every(function () { var column = this; var select = $( '' ) .appendTo('.user_role') .on('change', function () { var val = $.fn.dataTable.util.escapeRegex($(this).val()); column.search(val ? val : '', true, false).draw(); }); }); } }); } // Delete Record $('.datatables-permissions tbody').on('click', '.delete-record', function () { dt_permission.row($(this).parents('tr')).remove().draw(); }); // Filter form control to default size // ? setTimeout used for multilingual table initialization setTimeout(() => { $('.dataTables_filter .form-control').removeClass('form-control-sm'); $('.dataTables_length .form-select').removeClass('form-select-sm'); }, 300); });