Implementado listado visual de los usuarios que pertenecen a un rol

This commit is contained in:
imnavajas
2025-07-16 11:05:13 +02:00
parent d1cbb8eb24
commit 4ffd280302
3 changed files with 97 additions and 59 deletions

View File

@ -101,6 +101,20 @@ function getGravatarURL(int $size = 30)
{ {
return "https://gravatar.com/avatar/".md5(auth()->user()->getEmail())."?s=".$size; return "https://gravatar.com/avatar/".md5(auth()->user()->getEmail())."?s=".$size;
} }
if (!function_exists('gravatar_url')) {
function gravatar_url(?string $email, int $size = 40): string
{
if (!$email) {
return "https://www.gravatar.com/avatar/?s={$size}&d=mp";
}
return "https://www.gravatar.com/avatar/" . md5(strtolower(trim($email))) . "?s={$size}&d=identicon";
}
}
function getAllClassFolder($folder = null){ function getAllClassFolder($folder = null){
try { try {
helper('filesystem'); helper('filesystem');

View File

@ -100,6 +100,18 @@ class GroupModel extends \App\Models\BaseModel
->countAllResults(); ->countAllResults();
} }
public function getUsersByRol(string $groupKeyWord)
{
return $this->db
->table('auth_groups_users agu')
->select('u.id, ai.secret as email, u.first_name, u.last_name')
->join('users u', 'u.id = agu.user_id')
->join('auth_identities ai', 'ai.user_id = u.id AND ai.type = "email_password"', 'left')
->where('agu.group', $groupKeyWord)
->get()
->getResult();
}
public function getUsersRoles($userId) public function getUsersRoles($userId)
{ {

View File

@ -1,82 +1,94 @@
<?= $this->include('themes/_commonPartialsBs/datatables') ?> <?= $this->include('themes/_commonPartialsBs/datatables') ?>
<?= $this->extend('themes/vuexy/main/defaultlayout') ?> <?= $this->extend('themes/vuexy/main/defaultlayout') ?>
<?= $this->section('content'); ?> <?= $this->section('content'); ?>
<div class="row"> <div class="row">
<div class="col-md-12"> <div class="col-md-12">
<div class="card card-info"> <div class="card card-info">
<div class="card-header"> <div class="card-header">
<h3 class="card-title"><?= lang('RolesPermisos.pageTitle') ?></h3> <h3 class="card-title"><?= lang('RolesPermisos.pageTitle') ?></h3>
</div><!--//.card-header --> </div><!--//.card-header -->
<div class="card-body"> <div class="card-body">
<div class="container-xxl flex-grow-1 container-p-y"> <div class="container-xxl flex-grow-1 container-p-y">
<!-- Role cards --> <!-- Role cards -->
<div class="row g-4"> <div class="row g-4">
<div class="col-xl-4 col-lg-6 col-md-6"> <div class="col-xl-4 col-lg-6 col-md-6">
<div class="card h-100"> <div class="card h-100">
<div class="row h-100"> <div class="row h-100">
<div class="col-sm-5"> <div class="col-sm-5">
<div class="d-flex align-items-end h-100 justify-content-center mt-sm-0 mt-3"> <div class="d-flex align-items-end h-100 justify-content-center mt-sm-0 mt-3">
<img <img src="<?= site_url('themes/vuexy/img/illustrations/add-new-roles.png') ?>"
src="<?= site_url('themes/vuexy/img/illustrations/add-new-roles.png') ?>" class="img-fluid mt-sm-4 mt-md-0" alt="add-new-roles" width="83" />
class="img-fluid mt-sm-4 mt-md-0"
alt="add-new-roles"
width="83"/>
</div>
</div> </div>
<div class="col-sm-7"> </div>
<div class="card-body text-sm-end text-center ps-sm-0"> <div class="col-sm-7">
<button <div class="card-body text-sm-end text-center ps-sm-0">
onclick="window.location='<?= route_to('newGroup') ?>'" <button onclick="window.location='<?= route_to('newGroup') ?>'"
class="btn btn-primary mb-2 text-nowrap add-new-role" class="btn btn-primary mb-2 text-nowrap add-new-role">
> <?= lang('Basic.global.addNew') ?>
<?= lang('Basic.global.addNew') ?> </button>
</button> <p class="mb-0 mt-1"><?= lang("RolesPermisos.addRol") ?></p>
<p class="mb-0 mt-1"><?= lang("RolesPermisos.addRol") ?></p>
</div>
</div> </div>
</div> </div>
</div> </div>
</div> </div>
</div>
<?php foreach ($userGroupList as $item) : ?> <?php foreach ($userGroupList as $item): ?>
<div class="col-xl-4 col-lg-6 col-md-6"> <?php $item->users = $model->getUsersByRol($item->keyword); ?>
<div class="card"> <div class="col-xl-4 col-lg-6 col-md-6">
<div class="card-body"> <div class="card">
<div class="d-flex justify-content-between"> <div class="card-body">
<h6 class="fw-normal mb-2"><?= $model->getUsersWithRol($item->keyword); ?><?= lang("RolesPermisos.totalUsers") ?></h6> <div class="d-flex justify-content-between">
<h6 class="fw-normal mb-2">
<?= $model->getUsersWithRol($item->keyword); ?>
<?= lang("RolesPermisos.totalUsers") ?>
</h6>
<ul class="list-unstyled d-flex align-items-center avatar-group mb-0">
<?php foreach ($item->users as $user): ?>
<li data-bs-toggle="tooltip" data-popup="tooltip-custom" data-bs-placement="top"
title="<?= esc($user->first_name . ' ' . $user->last_name) ?>"
class="avatar avatar-sm pull-up">
<img class="rounded-circle" src="<?= gravatar_url($user->email, 30) ?>"
alt="<?= esc($user->email) ?>" />
</li>
<?php endforeach; ?>
</ul>
</div>
<div class="d-flex justify-content-between align-items-end mt-1">
<div class="role-heading">
<h4 class="mb-1"><?= esc($item->title) ?></h4>
<a href="<?= route_to('editGroup', $item->id) ?>">
<span><?= lang('Basic.global.edit') ?></span>
</a>
</div> </div>
<div class="d-flex justify-content-between align-items-end mt-1"> <?=
<div class="role-heading"> anchor(
<h4 class="mb-1"><?= esc($item->title) ?></h4> '#confirm2delete',
<a href="<?= route_to('editGroup', $item->id) ?>"> "<i class='ti ti-trash ti-md'></i>",
<span><?= lang('Basic.global.edit') ?></span>
</a>
</div>
<?=
anchor('#confirm2delete', "<i class='ti ti-trash ti-md'></i>",
[ [
'class' => 'text-muted', 'class' => 'text-muted',
'data-href' => route_to('deleteGroup', $item->id), 'data-href' => route_to('deleteGroup', $item->id),
'data-bs-toggle' => 'modal', 'data-bs-toggle' => 'modal',
'data-bs-target' => '#confirm2delete' 'data-bs-target' => '#confirm2delete'
]); ]
?> );
</div> ?>
</div> </div>
</div> </div>
</div> </div>
<?php endforeach; ?> </div>
</div> <?php endforeach; ?>
<!--/ Role cards -->
</div> </div>
<?= view('themes/_commonPartialsBs/_alertBoxes'); ?> <!--/ Role cards -->
</div>
<?= view('themes/_commonPartialsBs/_alertBoxes'); ?>
</div><!--//.card-body --> </div><!--//.card-body -->
<div class="card-footer"> <div class="card-footer">
</div><!--//.card-footer --> </div><!--//.card-footer -->
</div><!--//.card --> </div><!--//.card -->
</div><!--//.col --> </div><!--//.col -->
</div><!--//.row --> </div><!--//.row -->
<?= $this->endSection() ?> <?= $this->endSection() ?>