709 lines
35 KiB
PHP
709 lines
35 KiB
PHP
<div>
|
|
<div class="users-index alert-errors">{!! $indexAlert !!}</div>
|
|
|
|
<!-- Users List Table -->
|
|
<div class="card" wire:ignore>
|
|
<div class="card-datatable table-responsive">
|
|
<table class="datatables-users table">
|
|
<thead class="border-top">
|
|
<tr>
|
|
<th></th>
|
|
<th>Id</th>
|
|
<th>Usuario</th>
|
|
<th>Roles</th>
|
|
<th>Estatus</th>
|
|
<th>Creado</th>
|
|
<th>Acciones</th>
|
|
</tr>
|
|
</thead>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Offcanvas to add new user -->
|
|
<div class="offcanvas offcanvas-end" tabindex="-1" id="offcanvasUser" aria-labelledby="offcanvasLabel">
|
|
<div class="offcanvas-header border-bottom">
|
|
<h5 id="offcanvasLabel" class="offcanvas-title">{{ $modalTitle }}</h5>
|
|
<button type="button" class="btn-close text-reset" data-bs-dismiss="offcanvas" aria-label="Close"></button>
|
|
</div>
|
|
<div class="offcanvas-body mx-0 flex-grow-0 p-6 h-100">
|
|
<form class="pt-0" id="userForm" autocomplete='off'>
|
|
<input type="hidden" name="id" wire:model.defer='userId' />
|
|
|
|
<div class="mb-3">
|
|
<label for="name" class="form-label">Nombre completo</label>
|
|
<div class="input-group input-group-merge">
|
|
<span class="input-group-text"><i class="ti ti-user"></i></span>
|
|
<input type="text" name="name" wire:model.defer='name' id="name" class="form-control" placeholder="Pepe Pecas" />
|
|
</div>
|
|
<div class="error-message"></div>
|
|
</div>
|
|
<div class="mb-3">
|
|
<label for="email" class="form-label">Correo electrónico</label>
|
|
<div class="input-group input-group-merge">
|
|
<span class="input-group-text"><i class="ti ti-mail"></i></span>
|
|
<input type="text" name="email" wire:model.defer='email' id="email" class="form-control" placeholder="picapapas@mail.com" />
|
|
</div>
|
|
<div class="error-message"></div>
|
|
</div>
|
|
<div class="mb-3">
|
|
<label for="password" class="form-label">Contraseña</label>
|
|
<div class="input-group input-group-merge form-password-toggle">
|
|
<span class="input-group-text"><i class="ti ti-key"></i></span>
|
|
<input type="password" name="password" wire:model.defer='password' class="form-control form-control-merge" id="password" placeholder="············" />
|
|
<span class="input-group-text cursor-pointer"><i class="ti ti-eye"></i></span>
|
|
</div>
|
|
<div class="error-message"></div>
|
|
</div>
|
|
<div class="mb-3">
|
|
<label for="roles" class="form-label">Roles del usuario</label>
|
|
<x-form.select
|
|
id="roles"
|
|
name="roles[]"
|
|
wire:model.defer='roles'
|
|
:options="$roles_options"
|
|
multiple
|
|
class="select2 form-select" />
|
|
</div>
|
|
<div class="mb-3">
|
|
<label for="status" class="form-label">Estatus</label>
|
|
<div class="input-group input-group-merge">
|
|
<span class="input-group-text"><i class="ti ti-alert-triangle"></i></span>
|
|
<x-form.select
|
|
id="status"
|
|
name="status"
|
|
wire:model.defer='status'
|
|
:options="$status_options"
|
|
class="form-select" />
|
|
</div>
|
|
</div>
|
|
<div class="mb-3">
|
|
<label for="photo" class="form-label">Imagen de perfil</label>
|
|
<div class="image-wrapper mb-1">
|
|
<img id="user-image" class="max-w-full" src="{{ $src_photo }}" alt="">
|
|
</div>
|
|
<input type="file" name="photo" id="photo" class='form-control' accept='image/*' />
|
|
</div>
|
|
|
|
<div class="alert-errors"></div>
|
|
|
|
<button type="submit" class="btn btn-primary me-3 data-submit">{{ $btnSubmitTxt }}</button>
|
|
<button type="reset" class="btn btn-label-danger" data-bs-dismiss="offcanvas">Cancelar</button>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Delete User Modal -->
|
|
<div class="modal fade" id="deleteUserModal" tabindex="-1" aria-hidden="true" wire:ignore>
|
|
<div class="modal-dialog modal-dialog-centered modal-simple">
|
|
<div class="modal-content p-3 p-md-5">
|
|
<div class="modal-body">
|
|
<button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button>
|
|
<div class="text-center mb-4">
|
|
<h3 class="mb-2">Eliminar usuario</h3>
|
|
<p class="text-muted">El proceso de eliminación es definitivo e irreversible</p>
|
|
</div>
|
|
<form class="row g-3">
|
|
<div class="col-12">
|
|
<p class="name text-center font-bold"></p>
|
|
</div>
|
|
<div class="col-12 text-center">
|
|
<button type="submit" class="btn btn-primary me-sm-3 me-1 btn-submit">Eliminar usuario</button>
|
|
<button type="reset" class="btn btn-secondary btn-reset" data-bs-dismiss="modal" aria-label="Close">Cancelar</button>
|
|
</div>
|
|
</form>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!--/ Delete User Modal -->
|
|
</div>
|
|
|
|
@section('page-script')
|
|
<script type="text/javascript">
|
|
document.addEventListener("DOMContentLoaded", function() {
|
|
const store_route = '{{ route('admin.system.users.store') }}',
|
|
update_route = '{{ route('admin.system.users.update-ajax', '0~0') }}',
|
|
show_route = '{{ route('admin.system.users.show', '0~0') }}',
|
|
destroy_route = '{{ route('admin.system.users.destroy', '0~0') }}';
|
|
|
|
var statusObj = <?= json_encode($statuses) ?>,
|
|
$usersIndexAlert = $('.users-index.alert-errors'),
|
|
$dt_user_table = $('.datatables-users'),
|
|
dt_user;
|
|
|
|
var offcanvasElement = document.getElementById('offcanvasUser'),
|
|
offcanvasUser = new bootstrap.Offcanvas(offcanvasElement);
|
|
|
|
|
|
load_js_form = () => {
|
|
$('#userForm .select2')
|
|
.each(function() {
|
|
var $this = $(this)
|
|
|
|
$this.wrap('<div class="position-relative"></div>')
|
|
|
|
$this.select2({
|
|
dropdownAutoWidth: true,
|
|
width: '100%',
|
|
dropdownParent: $this.parent()
|
|
});
|
|
});
|
|
|
|
|
|
// Previo de imagenes
|
|
document.getElementById("photo").addEventListener('change', updatePreviewImage);
|
|
|
|
|
|
// Reset form
|
|
$("#userForm")
|
|
.on('reset', function(){
|
|
setTimeout(function(){
|
|
$('#roles').trigger('change');
|
|
}, 250)
|
|
|
|
$('#user-image').prop("src", "");
|
|
|
|
$('#userForm .alert-errors').html('');
|
|
});
|
|
|
|
|
|
$("#userForm")
|
|
.validate({
|
|
errorClass: 'error',
|
|
highlight: function(element, errorClass, validClass) {
|
|
// Agrega la clase de error a la fila (contenedor del campo)
|
|
$(element).closest('.mb-3').addClass('has-error');
|
|
},
|
|
unhighlight: function(element, errorClass, validClass) {
|
|
// Elimina la clase de error de la fila (contenedor del campo)
|
|
$(element).closest('.mb-3').removeClass('has-error');
|
|
},
|
|
errorPlacement: function(error, element) {
|
|
// Controla dónde se colocan los mensajes de error
|
|
error.appendTo(element.closest('.mb-3').find('.error-message'));
|
|
},
|
|
rules: {
|
|
name: {
|
|
required: true,
|
|
minlength: 8
|
|
},
|
|
email: {
|
|
required: true,
|
|
email: true
|
|
},
|
|
password: {
|
|
required: function(element) {
|
|
return !$("#userForm input[name=id]").val();
|
|
},
|
|
minlength: 6
|
|
}
|
|
},
|
|
messages: {
|
|
name: {
|
|
required: "Por favor ingrese su nombre completo",
|
|
minlength: "El nombre completo debe tener al menos 8 caracteres"
|
|
},
|
|
email: {
|
|
required: "Por favor ingrese su correo electrónico",
|
|
email: "El valor no es una dirección de correo válida"
|
|
},
|
|
password: {
|
|
required: "La contraseña es obligatoria para nuevos usuarios",
|
|
minlength: "La contraseña debe tener al menos 6 caracteres"
|
|
}
|
|
},
|
|
submitHandler: function(form) {
|
|
// Aquí puedes agregar lo que deseas hacer al enviar el formulario
|
|
console.log("Formulario válido y enviado");
|
|
|
|
//$('#userForm .alert-errors').html('');
|
|
var form = $("#userForm")[0],
|
|
data = new FormData(form);
|
|
|
|
$('#userForm :input').prop('disabled', true);
|
|
|
|
var url = $(form.id).val() ?
|
|
update_route.replace('0~0', $(form.id).val()) :
|
|
store_route;
|
|
|
|
$.ajax({
|
|
url: url,
|
|
method: 'POST',
|
|
headers: {
|
|
'X-CSRF-TOKEN': $('meta[name="csrf-token"]').attr('content')
|
|
},
|
|
data: data,
|
|
contentType: false,
|
|
processData: false,
|
|
cache: false,
|
|
timeout: 3000,
|
|
success: function(data) {
|
|
$('#userForm :input').prop('disabled', false);
|
|
|
|
if (data.errors) {
|
|
$('#userForm .alert-errors').html('<div class="alert alert-danger alert-dismissible fade show" role="alert">' +
|
|
'<div class="alert-body">' + data.errors + '</div>' +
|
|
'<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>' +
|
|
'</div>');
|
|
|
|
} else {
|
|
$usersIndexAlert.html('<div class="alert alert-success alert-dismissible fade show" role="alert">' +
|
|
'<div class="alert-body">' +
|
|
'<p class="mb-0"><strong>' + data.success + '</strong></p>' +
|
|
'</div>' +
|
|
'<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>' +
|
|
'</div>');
|
|
|
|
$('#userForm button[type=reset]').trigger('click');
|
|
|
|
//@this.call('refreshUserCount');
|
|
|
|
dt_user.ajax.reload();
|
|
}
|
|
},
|
|
error: function(e) {
|
|
$('#userForm :input').prop('disabled', false);
|
|
|
|
$('#userForm .alert-errors').html('<div class="alert alert-danger alert-dismissible fade show" role="alert">' +
|
|
'<div class="alert-body">' + e.responseJSON.message + '</div>' +
|
|
'<button type="button" class="btn-close" data-bs-dismiss="alert" aria-label="Close"></button>' +
|
|
'</div>');
|
|
}
|
|
});
|
|
}
|
|
});
|
|
|
|
}
|
|
|
|
|
|
// Previo de imagen de perfil
|
|
updatePreviewImage = (event) => {
|
|
var file = event.target.files[0],
|
|
reader = new FileReader();
|
|
|
|
reader.onload = event => {
|
|
document.getElementById('user-image').setAttribute('src', event.target.result);
|
|
};
|
|
|
|
reader.readAsDataURL(file);
|
|
}
|
|
|
|
// Add User
|
|
add_user = () => {
|
|
let $offcanvasUser = $('#offcanvasUser');
|
|
|
|
$('.offcanvas-title', $offcanvasUser).html('Crear usuario nuevo');
|
|
$('.btn-submit', $offcanvasUser).html('Crear usuario');
|
|
|
|
if ($('input[name=id]', $offcanvasUser).val()){
|
|
document.getElementById('userForm').reset();
|
|
|
|
$('input[name=id]', $offcanvasUser).val('');
|
|
|
|
$('#roles').trigger('change');
|
|
|
|
$('#user-image').prop("src", "");
|
|
|
|
$('.alert-errors', $offcanvasUser).html('');
|
|
}
|
|
}
|
|
|
|
|
|
Livewire.on('openModal', () => {
|
|
setTimeout(() =>{
|
|
offcanvasUser.show();
|
|
|
|
load_js_form();
|
|
|
|
dt_user.ajax.reload();
|
|
}, 1)
|
|
});
|
|
|
|
Livewire.on('afterDelete', () => {
|
|
setTimeout(() =>{
|
|
var modalElement = document.getElementById('deleteUserModal'),
|
|
modalDelete = bootstrap.Modal.getInstance(modalElement);
|
|
|
|
modalDelete.hide();
|
|
|
|
load_js_form();
|
|
|
|
dt_user.ajax.reload();
|
|
}, 1)
|
|
});
|
|
|
|
|
|
// (jquery)
|
|
$(function () {
|
|
let borderColor, bodyBg, headingColor;
|
|
|
|
if (isDarkStyle) {
|
|
borderColor = config.colors_dark.borderColor;
|
|
bodyBg = config.colors_dark.bodyBg;
|
|
headingColor = config.colors_dark.headingColor;
|
|
} else {
|
|
borderColor = config.colors.borderColor;
|
|
bodyBg = config.colors.bodyBg;
|
|
headingColor = config.colors.headingColor;
|
|
}
|
|
|
|
// Users datatable
|
|
dt_user = $dt_user_table.DataTable({
|
|
ajax: '{{ url()->current() }}',
|
|
columns: [
|
|
// columns according to JSON
|
|
{ data: 'id' },
|
|
{ data: 'id' },
|
|
{ data: 'name' },
|
|
{ data: 'roles' },
|
|
{ data: 'status' },
|
|
{ data: 'created_at' },
|
|
{ data: 'action' }
|
|
],
|
|
columnDefs: [
|
|
{
|
|
// For Responsive
|
|
className: 'control',
|
|
searchable: false,
|
|
orderable: false,
|
|
responsivePriority: 2,
|
|
targets: 0,
|
|
render: function (data, type, full, meta) {
|
|
return '';
|
|
}
|
|
},
|
|
{
|
|
// User name and email
|
|
targets: 2,
|
|
responsivePriority: 3,
|
|
render: function (data, type, full, meta) {
|
|
var $name = full['name'],
|
|
$email = full['email'],
|
|
$image = full['avatar'];
|
|
|
|
if ($image) {
|
|
// For Avatar image
|
|
var $output =
|
|
'<img src="' + $image + '" alt="Avatar" class="rounded-circle">';
|
|
} else {
|
|
// For Avatar badge
|
|
var $name = full['full_name'],
|
|
$initials = $name.match(/\b\w/g) || [];
|
|
$initials = (($initials.shift() || '') + ($initials.pop() || '')).toUpperCase();
|
|
$output = '<span class="avatar-initial rounded-circle>' + $initials + '</span>';
|
|
}
|
|
|
|
// Creates full output for row
|
|
var $row_output =
|
|
'<div class="d-flex justify-content-start align-items-center user-name">' +
|
|
'<div class="avatar-wrapper">' +
|
|
'<div class="avatar avatar-sm me-4">' + $output + '</div>' +
|
|
'</div>' +
|
|
'<div class="d-flex flex-column">' +
|
|
'<a href="' + show_route.replace('0~0', full['id']) + '" class="text-heading text-truncate"><span class="fw-medium">' + $name + '</span></a>' +
|
|
'<small>' + $email + '</small>' +
|
|
'</div>' +
|
|
'</div>';
|
|
|
|
return $row_output;
|
|
}
|
|
},
|
|
{
|
|
// User Role
|
|
targets: 3,
|
|
render: function(data, type, full, meta) {
|
|
var $assignedTo = full['roles'],
|
|
$output = '',
|
|
roleBadgeObj = <?= json_encode($rows_roles) ?>;
|
|
|
|
for (var i = 0; i < $assignedTo.length; i++) {
|
|
var val = $assignedTo[i];
|
|
|
|
$output += roleBadgeObj[val];
|
|
}
|
|
|
|
return $output;
|
|
}
|
|
},
|
|
{
|
|
// User Status
|
|
targets: 4,
|
|
render: function (data, type, full, meta) {
|
|
var $status = full['status'];
|
|
|
|
return ('<span class="badge rounded-pill ' + statusObj[$status].class + '" text-capitalized>' + statusObj[$status].title + '</span>');
|
|
|
|
}
|
|
},
|
|
{
|
|
// Created
|
|
targets: 5,
|
|
render: function (data, type, full, meta) {
|
|
return full['created_at'];
|
|
}
|
|
},
|
|
{
|
|
// Actions
|
|
targets: -1,
|
|
title: 'Acciones',
|
|
searchable: false,
|
|
orderable: false,
|
|
render: function (data, type, full, meta) {
|
|
return ('<div class="d-flex align-items-center">' +
|
|
'<a href="' + show_route.replace('0~0', full['id']) + '" class="btn btn-icon btn-text-secondary waves-effect waves-light rounded-pill"><i class="ti ti-eye ti-md"></i></a>' +
|
|
'<a href="javascript:;"" wire:click.prevent="edit(' + full['id'] + ')" class="btn btn-icon btn-text-secondary waves-effect waves-light rounded-pill"><i class="ti ti-edit ti-md"></i></a>' +
|
|
@can('system.users.destroy')
|
|
'<a href="javascript:;" class="btn btn-icon btn-text-secondary waves-effect waves-light rounded-pill dropdown-toggle hide-arrow" data-bs-toggle="dropdown"><i class="ti ti-dots-vertical ti-md"></i></a>' +
|
|
'<div class="dropdown-menu dropdown-menu-end m-0">' +
|
|
'<a href="javascript:;" class="dropdown-item delete-record">Eliminar</a>' +
|
|
'</div>' +
|
|
@endcan
|
|
'</div>');
|
|
}
|
|
}
|
|
],
|
|
order: [[2, 'desc']],
|
|
dom:
|
|
'<"row"' +
|
|
'<"col-md-2"<"ms-n2"l>>' +
|
|
'<"col-md-10"<"dt-action-buttons text-xl-end text-lg-start text-md-end text-start d-flex align-items-center justify-content-end flex-md-row flex-column mb-6 mb-md-0 mt-n6 mt-md-0"<"user_role dataTables_filter">fB>>' +
|
|
'>t' +
|
|
'<"row"' +
|
|
'<"col-sm-12 col-md-6"i>' +
|
|
'<"col-sm-12 col-md-6"p>' +
|
|
'>',
|
|
language: $.fn.dataTable.ext.datatable_spanish_default,
|
|
// Buttons with Dropdown
|
|
buttons: [
|
|
{
|
|
extend: 'collection',
|
|
className: 'btn btn-label-secondary dropdown-toggle mx-4 waves-effect waves-light',
|
|
text: '<i class="ti ti-upload me-2 ti-xs"></i>Exportar',
|
|
buttons: [
|
|
{
|
|
extend: 'print',
|
|
text: '<i class="ti ti-printer me-2" ></i>Imprimir',
|
|
className: 'dropdown-item',
|
|
exportOptions: {
|
|
columns: [1, 2, 3, 4, 5],
|
|
// prevent avatar to be print
|
|
format: {
|
|
body: function (inner, coldex, rowdex) {
|
|
if (inner.length <= 0) return inner;
|
|
var el = $.parseHTML(inner);
|
|
var result = '';
|
|
$.each(el, function (index, item) {
|
|
if (item.classList !== undefined && item.classList.contains('user-name')) {
|
|
result = result + item.lastChild.firstChild.textContent;
|
|
} else if (item.innerText === undefined) {
|
|
result = result + item.textContent;
|
|
} else result = result + item.innerText;
|
|
});
|
|
return result;
|
|
}
|
|
}
|
|
},
|
|
customize: function (win) {
|
|
//customize print view for dark
|
|
$(win.document.body)
|
|
.css('color', headingColor)
|
|
.css('border-color', borderColor)
|
|
.css('background-color', bodyBg);
|
|
$(win.document.body)
|
|
.find('table')
|
|
.addClass('compact')
|
|
.css('color', 'inherit')
|
|
.css('border-color', 'inherit')
|
|
.css('background-color', 'inherit');
|
|
}
|
|
},
|
|
{
|
|
extend: 'csv',
|
|
text: '<i class="ti ti-file-text me-2" ></i>Csv',
|
|
className: 'dropdown-item',
|
|
exportOptions: {
|
|
columns: [1, 2, 3, 4, 5],
|
|
// prevent avatar to be display
|
|
format: {
|
|
body: function (inner, coldex, rowdex) {
|
|
if (inner.length <= 0) return inner;
|
|
var el = $.parseHTML(inner);
|
|
var result = '';
|
|
$.each(el, function (index, item) {
|
|
if (item.classList !== undefined && item.classList.contains('user-name')) {
|
|
result = result + item.lastChild.firstChild.textContent;
|
|
} else if (item.innerText === undefined) {
|
|
result = result + item.textContent;
|
|
} else result = result + item.innerText;
|
|
});
|
|
return result;
|
|
}
|
|
}
|
|
}
|
|
},
|
|
{
|
|
extend: 'excel',
|
|
text: '<i class="ti ti-file-spreadsheet me-2"></i>Excel',
|
|
className: 'dropdown-item',
|
|
exportOptions: {
|
|
columns: [1, 2, 3, 4, 5],
|
|
// prevent avatar to be display
|
|
format: {
|
|
body: function (inner, coldex, rowdex) {
|
|
if (inner.length <= 0) return inner;
|
|
var el = $.parseHTML(inner);
|
|
var result = '';
|
|
$.each(el, function (index, item) {
|
|
if (item.classList !== undefined && item.classList.contains('user-name')) {
|
|
result = result + item.lastChild.firstChild.textContent;
|
|
} else if (item.innerText === undefined) {
|
|
result = result + item.textContent;
|
|
} else result = result + item.innerText;
|
|
});
|
|
return result;
|
|
}
|
|
}
|
|
}
|
|
},
|
|
/*
|
|
{
|
|
extend: 'pdf',
|
|
text: '<i class="ti ti-file-code-2 me-2"></i>Pdf',
|
|
className: 'dropdown-item',
|
|
exportOptions: {
|
|
columns: [1, 2, 3, 4, 5],
|
|
// prevent avatar to be display
|
|
format: {
|
|
body: function (inner, coldex, rowdex) {
|
|
if (inner.length <= 0) return inner;
|
|
var el = $.parseHTML(inner);
|
|
var result = '';
|
|
$.each(el, function (index, item) {
|
|
if (item.classList !== undefined && item.classList.contains('user-name')) {
|
|
result = result + item.lastChild.firstChild.textContent;
|
|
} else if (item.innerText === undefined) {
|
|
result = result + item.textContent;
|
|
} else result = result + item.innerText;
|
|
});
|
|
return result;
|
|
}
|
|
}
|
|
}
|
|
},
|
|
*/
|
|
{
|
|
extend: 'copy',
|
|
text: '<i class="ti ti-copy me-2" ></i>Copiar',
|
|
className: 'dropdown-item',
|
|
exportOptions: {
|
|
columns: [1, 2, 3, 4, 5],
|
|
// prevent avatar to be display
|
|
format: {
|
|
body: function (inner, coldex, rowdex) {
|
|
if (inner.length <= 0) return inner;
|
|
var el = $.parseHTML(inner);
|
|
var result = '';
|
|
$.each(el, function (index, item) {
|
|
if (item.classList !== undefined && item.classList.contains('user-name')) {
|
|
result = result + item.lastChild.firstChild.textContent;
|
|
} else if (item.innerText === undefined) {
|
|
result = result + item.textContent;
|
|
} else result = result + item.innerText;
|
|
});
|
|
return result;
|
|
}
|
|
}
|
|
}
|
|
}
|
|
]
|
|
},
|
|
@can('system.users.create') {
|
|
text: '<i class="ti ti-plus me-0 me-sm-1 ti-xs"></i><span class="d-none d-sm-inline-block">Nuevo usuario</span>',
|
|
className: 'add-new btn btn-primary waves-effect waves-light',
|
|
attr: {
|
|
'onclick': 'add_user()',
|
|
'data-bs-toggle': 'offcanvas',
|
|
'data-bs-target': '#offcanvasUser'
|
|
}
|
|
}
|
|
@endcan
|
|
],
|
|
// For responsive popup
|
|
responsive: {
|
|
details: {
|
|
display: $.fn.dataTable.Responsive.display.modal({
|
|
header: function (row) {
|
|
var data = row.data();
|
|
return 'Details of ' + data['full_name'];
|
|
}
|
|
}),
|
|
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)
|
|
? '<tr data-dt-row="' + col.rowIndex + '" data-dt-column="' + col.columnIndex + '">' +
|
|
'<td>' + col.title + ':' + '</td> ' +
|
|
'<td>' + col.data + '</td>' +
|
|
'</tr>'
|
|
: '';
|
|
}).join('');
|
|
|
|
return data ? $('<table class="table"/><tbody />').append(data) : false;
|
|
}
|
|
}
|
|
},
|
|
initComplete: function () {
|
|
this.api()
|
|
.columns(3)
|
|
.every(function () {
|
|
var column = this,
|
|
select = $('{!! $roles_html_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-users tbody')
|
|
.on('click', '.delete-record', function () {
|
|
var tr = $(this).closest('tr'),
|
|
data = dt_user.row(tr).data();
|
|
|
|
$('#deleteUserModal').modal('show');
|
|
$('#deleteUserModal .name').html(data.id + ': ' + data.name);
|
|
|
|
$('#deleteUserModal').data('userId', data.id);
|
|
});
|
|
|
|
|
|
// Attach the event listener to the submit button
|
|
$('#deleteUserModal .btn-submit')
|
|
.on('click', function (e) {
|
|
e.preventDefault();
|
|
|
|
@this.call('delete', $('#deleteUserModal').data('userId'));
|
|
});
|
|
|
|
|
|
// 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);
|
|
|
|
|
|
load_js_form();
|
|
});
|
|
|
|
});
|
|
</script>
|
|
@endsection
|