maquetador-graficas/app/Http/Controllers/Dashboard/HistoryLogController.php
Juan Felipe Zapata Moreno c6c2f78d16 Initial Commit
2025-08-12 09:36:02 -06:00

68 lines
2.1 KiB
PHP

<?php namespace App\Http\Controllers\Dashboard;
/**
* @copyright Copyright (c) 2023 Notsoweb (https://notsoweb.com) - All rights reserved.
*/
use App\Models\HistoryLog;
use Notsoweb\Core\Http\Controllers\VueController;
/**
* Controla el historial de acciones de los usuarios
*
* Permite ver los registros de las acciones de los usuarios.
*
* @author Moisés de Jesús Cortés Castellanos <ing.moisesdejesuscortesc@notsoweb.com>
*
* @version 1.0.0
*/
class HistoryLogController extends VueController
{
/**
* Constructor
*/
public function __construct()
{
$this->vueRoot('dashboard');
}
/**
* Listar historial de acciones
*
* @return \Illuminate\Http\Response
*/
public function index()
{
$historyEvent = request()->get('historyEvent');
$dateStart = request()->get('dateStart');
$dateEnd = request()->get('dateEnd');
if($dateEnd) {
$dateEnd = date('Y-m-d', strtotime("{$dateEnd} + 1 day"));
}
$searcher = HistoryLog::join('users', 'users.id', '=', 'history_logs.user_id')
->where(function($query) use ($historyEvent) {
$query->where('history_logs.action', 'LIKE', "%{$historyEvent}%");
$query->orWhere('history_logs.message', 'LIKE', "%{$historyEvent}%");
});
if($dateStart && $dateEnd) {
$searcher = $searcher->whereBetween('history_logs.created_at', [$dateStart, $dateEnd]);
} elseif($dateStart && !$dateEnd) {
$searcher = $searcher->where('history_logs.created_at', '>=', $dateStart);
} elseif (!$dateStart && $dateEnd) {
$searcher = $searcher->where('history_logs.created_at', '<=', $dateEnd);
}
return $this->vuew('history-log' , [
'histories' => $searcher ->select([
'history_logs.*',
'users.name',
'users.paternal',
])
->orderBy('created_at', 'Desc')
->paginate(config('app.pagination'))
]);
}
}