Merge branch 'add/ajustar_margen' of https://git.imnavajas.es/jjimenez/safekat into add/ajustar_margen

This commit is contained in:
2025-04-03 23:37:20 +02:00
12 changed files with 260 additions and 204 deletions

View File

@ -51,6 +51,8 @@ class Proveedores extends \App\Controllers\BaseResourceController {
public function index() { public function index() {
checkPermission('proveedores.menu');
$viewData = [ $viewData = [
'currentModule' => static::$controllerSlug, 'currentModule' => static::$controllerSlug,
'pageSubTitle' => lang('Basic.global.ManageAllRecords', [lang('Proveedores.proveedor')]), 'pageSubTitle' => lang('Basic.global.ManageAllRecords', [lang('Proveedores.proveedor')]),
@ -67,9 +69,7 @@ class Proveedores extends \App\Controllers\BaseResourceController {
public function add() { public function add() {
checkPermission('proveedores.create');
if ($this->request->getPost()) : if ($this->request->getPost()) :
@ -139,6 +139,8 @@ class Proveedores extends \App\Controllers\BaseResourceController {
public function edit($requestedId = null) { public function edit($requestedId = null) {
checkPermission('proveedores.edit');
if ($requestedId == null) : if ($requestedId == null) :
return $this->redirect2listView(); return $this->redirect2listView();
endif; endif;

View File

@ -41,6 +41,7 @@ class Facturas extends \App\Controllers\BaseResourceController
public function index() public function index()
{ {
checkPermission('facturas.menu');
if (auth()->user()->inGroup('cliente-admin') || auth()->user()->inGroup('cliente-editor')) { if (auth()->user()->inGroup('cliente-admin') || auth()->user()->inGroup('cliente-editor')) {
// Se obtiene el cliente ID a partir del usuario de la sesion // Se obtiene el cliente ID a partir del usuario de la sesion
@ -62,6 +63,7 @@ class Facturas extends \App\Controllers\BaseResourceController
public function list() public function list()
{ {
checkGroups(['admin', 'cliente-admin', 'cliente-editor', 'contabilidad']);
$viewData = [ $viewData = [
'currentModule' => static::$controllerSlug, 'currentModule' => static::$controllerSlug,
@ -103,8 +105,8 @@ class Facturas extends \App\Controllers\BaseResourceController
public function add() public function add()
{ {
if(!auth()->user()->can('facturas.create')) checkPermission('facturas.create');
return $this->failForbidden(lang('Basic.global.noPermission'), 403);
if ($this->request->getPost()): if ($this->request->getPost()):
$nullIfEmpty = true; // !(phpversion() >= '8.1'); $nullIfEmpty = true; // !(phpversion() >= '8.1');
@ -202,9 +204,7 @@ class Facturas extends \App\Controllers\BaseResourceController
public function edit($id = null) public function edit($id = null)
{ {
checkPermission('facturas.edit');
if(!auth()->user()->can('facturas.edit'))
return $this->failForbidden(lang('Basic.global.noPermission'), 403);
if ($id == null): if ($id == null):
return $this->redirect2listView(); return $this->redirect2listView();

View File

@ -35,6 +35,7 @@ class Actividad extends BaseResourceController
public function index() public function index()
{ {
checkPermission('actividad.menu');
$viewData = [ $viewData = [

View File

@ -40,6 +40,7 @@ class Ajustes extends BaseResourceController
public function settings() public function settings()
{ {
checkPermission('ajustes.menu');
$id = 1; $id = 1;
$settingsEntity = $this->model->find($id); $settingsEntity = $this->model->find($id);

View File

@ -44,7 +44,7 @@ class Ticketcontroller extends \App\Controllers\BaseResourceController
public function index() public function index()
{ {
//checkPermission('tickets.menu'); checkPermission('tickets.menu');
$viewData = [ $viewData = [
'currentModule' => static::$controllerSlug, 'currentModule' => static::$controllerSlug,
@ -69,7 +69,7 @@ class Ticketcontroller extends \App\Controllers\BaseResourceController
public function add() public function add()
{ {
//checkPermission('tickets.create', $this->indexRoute); checkPermission('tickets.create');
if ($this->request->getPost()): if ($this->request->getPost()):
@ -145,6 +145,9 @@ class Ticketcontroller extends \App\Controllers\BaseResourceController
public function edit($requestedId = null) public function edit($requestedId = null)
{ {
checkPermission('tickets.edit');
$modelRespuesta = new \App\Models\Soporte\TicketRespuestaModel(); $modelRespuesta = new \App\Models\Soporte\TicketRespuestaModel();
if ($requestedId == null): if ($requestedId == null):

View File

@ -120,3 +120,37 @@ if (!function_exists('checkPermission')) {
} }
} }
if (!function_exists('checkGroups')) {
/**
* Verifica si el usuario pertenece a alguno de los grupos especificados.
*
* @param array $groups Lista de grupos permitidos.
* @param string|null $redirectRoute Ruta de redirección si no pertenece a ningún grupo.
* @return \CodeIgniter\HTTP\RedirectResponse|null
*/
function checkGroups(array $groups, string $redirectRoute = null)
{
$session = \Config\Services::session();
$response = \Config\Services::response();
$auth = auth(); // Shield auth service
$user = $auth->user();
$inGroup = false;
foreach ($groups as $group) {
if ($user->inGroup($group)) {
$inGroup = true;
break;
}
}
if (!$inGroup) {
$session->setFlashdata('errorMessage', 'No tiene permisos de acceso.');
$route = $redirectRoute ?? 'home';
return $response->redirect(route_to($route));
}
return null;
}
}

View File

@ -2,35 +2,45 @@
/** /**
* MENU COMPRAS * MENU COMPRAS
*/ */
if (auth()->user()->inGroup('beta')) { if (
?> auth()->user()->can('proveedores.menu') ||
<!-- BUY --> auth()->user()->inGroup('beta')
<li class="menu-item"> ) {
<a href="javascript:void(0);" class="menu-link menu-toggle">
<i class="menu-icon tf-icons ti ti-shopping-cart"></i> ?>
<?= lang("App.menu_compras") ?> <!-- COMPRAS -->
</a> <li class="menu-item">
<ul class="menu-sub"> <a href="javascript:void(0);" class="menu-link menu-toggle">
<li class="menu-item"> <i class="menu-icon tf-icons ti ti-shopping-cart"></i>
<a href="<?= site_url("servicios/compras") ?>" class="menu-link"> <?= lang("App.menu_compras") ?>
<?= lang("App.menu_compras") ?> </a>
</a> <ul class="menu-sub">
</li> <?php if (auth()->user()->can('proveedores.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= site_url("servicios/productos") ?>" class="menu-link"> <a href="<?= site_url("compras/proveedores") ?>" class="menu-link">
<?= lang("App.menu_productos") ?> <?= lang("App.menu_proveedores") ?>
</a> </a>
</li> </li>
<li class="menu-item"> <?php } ?>
<a href="<?= site_url("compras/proveedores") ?>" class="menu-link">
<?= lang("App.menu_proveedores") ?> <?php if (auth()->user()->inGroup('beta')) { ?>
</a> <li class="menu-item">
</li> <a href="<?= site_url("servicios/compras") ?>" class="menu-link">
<li class="menu-item"> <?= lang("App.menu_compras") ?>
<a href="<?= site_url("servicios/compras/ajustes") ?>" class="menu-link"> </a>
<?= lang("App.menu_compras_ajustes") ?> </li>
</a> <li class="menu-item">
</li> <a href="<?= site_url("servicios/productos") ?>" class="menu-link">
</ul> <?= lang("App.menu_productos") ?>
</li> </a>
</li>
<li class="menu-item">
<a href="<?= site_url("servicios/compras/ajustes") ?>" class="menu-link">
<?= lang("App.menu_compras_ajustes") ?>
</a>
</li>
<?php } ?>
</ul>
</li>
<?php } ?> <?php } ?>

View File

@ -6,127 +6,127 @@
if ( if (
auth()->user()->can('paises.menu') || auth()->user()->can('paises.menu') ||
auth()->user()->can('formas-pago.menu') || auth()->user()->can('formas-pago.menu') ||
auth()->user()->can('papel-genericosk .menu') || auth()->user()->can('papel-generico.menu') ||
auth()->user()->can('papel-impresion.menu') || auth()->user()->can('papel-impresion.menu') ||
auth()->user()->can('maquinas.menu') || auth()->user()->can('maquinas.menu') ||
auth()->user()->can('maquinas-defecto.menu') || auth()->user()->can('maquinas-defecto.menu') ||
auth()->user()->can('usuarios.menu') || auth()->user()->can('usuarios.menu') ||
auth()->user()->can('roles-permisos.menu') auth()->user()->can('roles-permisos.menu')
) { ) {
?> ?>
<li class="menu-item"> <li class="menu-item">
<a href="javascript:void(0);" class="menu-link menu-toggle"> <a href="javascript:void(0);" class="menu-link menu-toggle">
<i class="menu-icon tf-icons ti ti-adjustments-horizontal"></i> <i class="menu-icon tf-icons ti ti-adjustments-horizontal"></i>
<?= lang("App.menu_configuration") ?> <?= lang("App.menu_configuration") ?>
</a> </a>
<ul class="menu-sub"> <ul class="menu-sub">
<?php if (auth()->user()->can('paises.menu')) { ?> <?php if (auth()->user()->can('paises.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= route_to('paisList') ?>" class="menu-link"> <a href="<?= route_to('paisList') ?>" class="menu-link">
<?= lang("App.menu_paises") ?> <?= lang("App.menu_paises") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->can('formas-pago.menu')) { ?> <?php if (auth()->user()->can('formas-pago.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= route_to('formasPagoList') ?>" class="menu-link"> <a href="<?= route_to('formasPagoList') ?>" class="menu-link">
<?= lang("App.menu_formas_pago") ?> <?= lang("App.menu_formas_pago") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->can('papel-generico.menu')) { ?> <?php if (auth()->user()->can('papel-generico.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= site_url("configuracion/papelesgenericos") ?>" class="menu-link"> <a href="<?= site_url("configuracion/papelesgenericos") ?>" class="menu-link">
<?= lang("App.menu_papelgenerico") ?> <?= lang("App.menu_papelgenerico") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->can('papel-impresion.menu')) { ?> <?php if (auth()->user()->can('papel-impresion.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= site_url("configuracion/papelesimpresion") ?>" class="menu-link"> <a href="<?= site_url("configuracion/papelesimpresion") ?>" class="menu-link">
<?= lang("App.menu_papelimpresion") ?> <?= lang("App.menu_papelimpresion") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->can('maquinas.menu')) { ?> <?php if (auth()->user()->can('maquinas.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= site_url("configuracion/maquinas") ?>" class="menu-link"> <a href="<?= site_url("configuracion/maquinas") ?>" class="menu-link">
<?= lang("App.menu_maquina") ?> <?= lang("App.menu_maquina") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->can('maquinas-defecto.menu')) { ?> <?php if (auth()->user()->can('maquinas-defecto.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= site_url("configuracion/maquinasdefecto") ?>" class="menu-link"> <a href="<?= site_url("configuracion/maquinasdefecto") ?>" class="menu-link">
<?= lang("App.menu_maquina_defecto") ?> <?= lang("App.menu_maquina_defecto") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->inGroup('admin') || auth()->user()->inGroup('beta')) { ?> <?php if (auth()->user()->inGroup('admin')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= route_to("maquinaTareaList") ?>" class="menu-link"> <a href="<?= route_to("maquinaTareaList") ?>" class="menu-link">
<?= lang("App.menu_maquina_tareas") ?> <?= lang("App.menu_maquina_tareas") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->can('usuarios.menu')) { ?> <?php if (auth()->user()->can('usuarios.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= site_url("configuracion/users") ?>" class="menu-link"> <a href="<?= site_url("configuracion/users") ?>" class="menu-link">
<?= lang("App.menu_users") ?> <?= lang("App.menu_users") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->can('roles-permisos.menu')) { ?> <?php if (auth()->user()->can('roles-permisos.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= site_url("configuracion/group") ?>" class="menu-link"> <a href="<?= site_url("configuracion/group") ?>" class="menu-link">
<?= lang("App.menu_permission_group") ?> <?= lang("App.menu_permission_group") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->can('proveedores.menu')) { ?> <?php if (auth()->user()->can('proveedores.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= route_to("proveedorList") ?>" class="menu-link"> <a href="<?= route_to("proveedorList") ?>" class="menu-link">
<?= lang("App.menu_proveedores") ?> <?= lang("App.menu_proveedores") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->can('ubicaciones.menu')) { ?> <?php if (auth()->user()->can('ubicaciones.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= route_to("ubicacionesList") ?>" class="menu-link"> <a href="<?= route_to("ubicacionesList") ?>" class="menu-link">
<?= lang("App.menu_ubicaciones") ?> <?= lang("App.menu_ubicaciones") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->can('series-facturas.menu')) { ?> <?php if (auth()->user()->can('series-facturas.menu')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= route_to("seriesFacturasList") ?>" class="menu-link"> <a href="<?= route_to("seriesFacturasList") ?>" class="menu-link">
<?= lang("App.menu_series_facturas") ?> <?= lang("App.menu_series_facturas") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->inGroup('admin') || auth()->user()->inGroup('beta')) { ?> <?php if (auth()->user()->inGroup('admin')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= route_to('erroresPresupuestoIndex') ?>" class="menu-link"> <a href="<?= route_to('erroresPresupuestoIndex') ?>" class="menu-link">
<?= lang("App.menu_error_presupuesto") ?> <?= lang("App.menu_error_presupuesto") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->inGroup('admin') || auth()->user()->inGroup('beta')) { ?> <?php if (auth()->user()->inGroup('admin')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= route_to('variablesIndex') ?>" class="menu-link"> <a href="<?= route_to('variablesIndex') ?>" class="menu-link">
<?= lang("App.menu_variables") ?> <?= lang("App.menu_variables") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
<?php if (auth()->user()->inGroup('admin') || auth()->user()->inGroup('beta')) { ?> <?php if (auth()->user()->inGroup('admin')) { ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= route_to('configMessagesIndex') ?>" class="menu-link"> <a href="<?= route_to('configMessagesIndex') ?>" class="menu-link">
<?= lang("App.menu_config_messages") ?> <?= lang("App.menu_config_messages") ?>
</a> </a>
</li> </li>
<?php } ?> <?php } ?>
</ul> </ul>
</li> </li>
<?php } ?> <?php } ?>

View File

@ -12,15 +12,10 @@ if (auth()->user()->inGroup('cliente-admin') || auth()->user()->inGroup('cliente
</a> </a>
<ul class="menu-sub"> <ul class="menu-sub">
<li class="menu-item"> <li class="menu-item">
<a href="<?= site_url("facturas/list") ?>" class="menu-link"> <a href="<?= route_to('facturasList') ?>" class="menu-link">
<?= lang("App.menu_facturas") ?> <?= lang("App.menu_facturas") ?>
</a> </a>
</li> </li>
<li class="menu-item">
<a href="<?= site_url("facturas/albaranes") ?>" class="menu-link">
<?= lang("App.menu_albaran") ?>
</a>
</li>
</ul> </ul>
</li> </li>
<?php } ?> <?php } ?>

View File

@ -2,39 +2,34 @@
/** /**
* MENU FACTURACION * MENU FACTURACION
*/ */
if (auth()->user()->inGroup('beta') || auth()->user()->can('facturas.menu')) { if (auth()->user()->can('facturas.menu')) {
?> ?>
<!-- Invoicing --> <!-- FACTURACION -->
<li class="menu-item"> <li class="menu-item">
<a href="javascript:void(0);" class="menu-link menu-toggle"> <a href="javascript:void(0);" class="menu-link menu-toggle">
<i class="menu-icon tf-icons ti ti-file-dollar"></i> <i class="menu-icon tf-icons ti ti-file-dollar"></i>
<?= lang("App.menu_facturación") ?> <?= lang("App.menu_facturación") ?>
</a> </a>
<ul class="menu-sub"> <ul class="menu-sub">
<?php if(auth()->user()->can('facturas.create')): ?> <?php if (auth()->user()->can('facturas.create')): ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= route_to('newFactura') ?>" class="menu-link"> <a href="<?= route_to('newFactura') ?>" class="menu-link">
<?= lang("App.menu_facturas_nueva") ?> <?= lang("App.menu_facturas_nueva") ?>
</a> </a>
</li> </li>
<?php endif; ?> <?php endif; ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= site_url("facturas/list") ?>" class="menu-link"> <a href="<?= route_to('facturasList') ?>" class="menu-link">
<?= lang("App.menu_facturas") ?> <?= lang("App.menu_facturas") ?>
</a> </a>
</li> </li>
<?php if(auth()->user()->can('facturas.vencimientos')): ?> <?php if (auth()->user()->can('facturas.vencimientos')): ?>
<li class="menu-item"> <li class="menu-item">
<a href="<?= site_url("facturas/vencimientos") ?>" class="menu-link"> <a href="<?= site_url("facturas/vencimientos") ?>" class="menu-link">
<?= lang("App.menu_facturas_vencimiento") ?> <?= lang("App.menu_facturas_vencimiento") ?>
</a> </a>
</li> </li>
<?php endif; ?> <?php endif; ?>
<li class="menu-item">
<a href="<?= site_url("facturas/albaranes") ?>" class="menu-link">
<?= lang("App.menu_albaran") ?>
</a>
</li>
</ul> </ul>
</li> </li>
<?php } ?> <?php } ?>

View File

@ -2,9 +2,9 @@
/** /**
* MENU MENSAJES * MENU MENSAJES
*/ */
if (auth()->user()->inGroup('beta') || auth()->user()->inGroup('cliente-editor')) { if (auth()->user()->inGroup('cliente-editor')) {
?> ?>
<!-- Messages --> <!-- Mensajeria -->
<li class="menu-item"> <li class="menu-item">
<a href="<?= route_to('mensajeriaView') ?>" class="menu-link"> <a href="<?= route_to('mensajeriaView') ?>" class="menu-link">
<i class="menu-icon tf-icons ti ti-message"></i> <i class="menu-icon tf-icons ti ti-message"></i>

View File

@ -1,22 +1,37 @@
<!-- Soporte --> <?php
<li class="menu-item"> /**
<a href="javascript:void(0);" class="menu-link menu-toggle"> * MENU SOPORTE
<i class="menu-icon tf-icons ti ti-help"></i> */
<?= lang("App.menu_soporte") ?> if (
</a> auth()->user()->can('tickets.menu')
<ul class="menu-sub"> ) {
?>
<li class="menu-item"> <!-- Soporte -->
<a href="<?= route_to("NewTicket") ?>" class="menu-link"> <li class="menu-item">
<?= lang("App.menu_soporte_new_ticket") ?> <a href="javascript:void(0);" class="menu-link menu-toggle">
</a> <i class="menu-icon tf-icons ti ti-help"></i>
</li> <?= lang("App.menu_soporte") ?>
</a>
<ul class="menu-sub">
<li class="menu-item"> <?php if (auth()->user()->can('tickets.create')) { ?>
<a href="<?= route_to("TicketIndex") ?>" class="menu-link"> <li class="menu-item">
<?= lang("App.menu_soporte_ticket_list") ?> <a href="<?= route_to("NewTicket") ?>" class="menu-link">
</a> <?= lang("App.menu_soporte_new_ticket") ?>
</li> </a>
</li>
<?php } ?>
</ul> <?php if (auth()->user()->can('tickets.edit')) { ?>
</li> <li class="menu-item">
<a href="<?= route_to("TicketIndex") ?>" class="menu-link">
<?= lang("App.menu_soporte_ticket_list") ?>
</a>
</li>
<?php } ?>
</ul>
</li>
<?php } ?>