Skip to content

Laravel Pulse

Introducción

Laravel Pulse ofrece una visión rápida del rendimiento y uso de tu aplicación. Con Pulse, puedes identificar cuellos de botella como trabajos y puntos finales lentos, encontrar a tus usuarios más activos y más. Para una depuración exhaustiva de eventos individuales, consulta Laravel Telescope.

Instalación

exclamation

La implementación de almacenamiento de primera parte de Pulse actualmente requiere una base de datos MySQL, MariaDB o PostgreSQL. Si estás utilizando un motor de base de datos diferente, necesitarás una base de datos MySQL, MariaDB o PostgreSQL por separado para tus datos de Pulse. Puedes instalar Pulse usando el gestor de paquetes Composer:

composer require laravel/pulse

A continuación, deberías publicar los archivos de configuración y migración de Pulse utilizando el comando Artisan vendor:publish:

php artisan vendor:publish --provider="Laravel\Pulse\PulseServiceProvider"

Finalmente, debes ejecutar el comando migrate para crear las tablas necesarias para almacenar los datos de Pulse:

php artisan migrate

Una vez que se hayan ejecutado las migraciones de la base de datos de Pulse, puedes acceder al dashboard de Pulse a través de la ruta /pulse.

lightbulb

Si no deseas almacenar los datos de Pulse en la base de datos principal de tu aplicación, puedes especificar una conexión a una base de datos dedicada.

Configuración

Muchas de las opciones de configuración de Pulse se pueden controlar utilizando variables de entorno. Para ver las opciones disponibles, registrar nuevos grabadores o configurar opciones avanzadas, puedes publicar el archivo de configuración config/pulse.php:

php artisan vendor:publish --tag=pulse-config

Panel de control

Autorización

El dashboard de Pulse se puede acceder a través de la ruta /pulse. Por defecto, solo podrás acceder a este dashboard en el entorno local, por lo que necesitarás configurar la autorización para tus entornos de producción personalizando el gate de autorización 'viewPulse'. Puedes lograr esto dentro del archivo app/Providers/AppServiceProvider.php de tu aplicación:

use App\Models\User;
use Illuminate\Support\Facades\Gate;

/**
 * Bootstrap any application services.
 */
public function boot(): void
{
    Gate::define('viewPulse', function (User $user) {
        return $user->isAdmin();
    });

    // ...
}

Personalización

Las tarjetas y el diseño del dashboard de Pulse pueden configurarse publicando la vista del dashboard. La vista del dashboard se publicará en resources/views/vendor/pulse/dashboard.blade.php:

php artisan vendor:publish --tag=pulse-dashboard

El panel de control está impulsado por Livewire, y te permite personalizar las tarjetas y el diseño sin necesidad de reconstruir ningún recurso de JavaScript. Dentro de este archivo, el componente <x-pulse> es responsable de renderizar el panel y proporciona un diseño de cuadrícula para las tarjetas. Si deseas que el panel ocupe todo el ancho de la pantalla, puedes proporcionar la prop full-width al componente:

<x-pulse full-width>
    ...
</x-pulse>

Por defecto, el componente <x-pulse> creará una cuadrícula de 12 columnas, pero puedes personalizar esto utilizando la prop cols:

<x-pulse cols="16">
    ...
</x-pulse>

Cada tarjeta acepta una prop cols y rows para controlar el espacio y la posición:

<livewire:pulse.usage cols="4" rows="2" />

La mayoría de las tarjetas también aceptan una prop expand para mostrar la tarjeta completa en lugar de desplazarse:

<livewire:pulse.slow-queries expand />

Resolviendo Usuarios

Para las tarjetas que muestran información sobre tus usuarios, como la tarjeta de Uso de la Aplicación, Pulse solo registrará la ID del usuario. Al renderizar el panel, Pulse resolverá los campos name y email de tu modelo Authenticatable predeterminado y mostrará avatares utilizando el servicio web Gravatar. Puedes personalizar los campos y el avatar invocando el método Pulse::user dentro de la clase App\Providers\AppServiceProvider de tu aplicación. El método user acepta una función anónima que recibirá el modelo Authenticatable que se mostrará y debe devolver un array que contenga información de name, extra y avatar para el usuario:

use Laravel\Pulse\Facades\Pulse;

/**
 * Bootstrap any application services.
 */
public function boot(): void
{
    Pulse::user(fn ($user) => [
        'name' => $user->name,
        'extra' => $user->email,
        'avatar' => $user->avatar_url,
    ]);

    // ...
}
lightbulb

Puedes personalizar completamente cómo se captura y recupera el usuario autenticado implementando el contrato Laravel\Pulse\Contracts\ResolvesUsers y vinculándolo en el contenedor de servicios de Laravel.

Tarjetas

La tarjeta <livewire:pulse.servers /> muestra el uso de recursos del sistema para todos los servidores que ejecutan el comando pulse:check. Por favor, consulta la documentación sobre el grabador de servidores para obtener más información sobre el informe de recursos del sistema. Si reemplazas un servidor en tu infraestructura, es posible que desees dejar de mostrar el servidor inactivo en el tablero de Pulse después de una duración determinada. Puedes lograr esto utilizando la prop ignore-after, que acepta el número de segundos después de los cuales los servidores inactivos deben ser eliminados del tablero de Pulse. Alternativamente, puedes proporcionar una cadena de tiempo relativa formateada, como 1 hora o 3 días y 1 hora:

<livewire:pulse.servers ignore-after="3 hours" />

Uso de la Aplicación

La tarjeta <livewire:pulse.usage /> muestra los 10 principales usuarios que realizan solicitudes a tu aplicación, despachando trabajos y experimentando solicitudes lentas. Si deseas ver todas las métricas de uso en pantalla al mismo tiempo, puedes incluir la tarjeta múltiples veces y especificar el atributo type:

<livewire:pulse.usage type="requests" />
<livewire:pulse.usage type="slow_requests" />
<livewire:pulse.usage type="jobs" />

Para aprender cómo personalizar la forma en que Pulse recupera y muestra la información del usuario, consulta nuestra documentación sobre resolución de usuarios.

lightbulb

Si tu aplicación recibe muchas solicitudes o despacha muchos trabajos, es posible que desees habilitar muestreo. Consulta la documentación del grabador de solicitudes de usuario, grabador de trabajos de usuario y grabador de trabajos lentos para obtener más información.

La tarjeta <livewire:pulse.exceptions /> muestra la frecuencia y la recencia de las excepciones que ocurren en tu aplicación. Por defecto, las excepciones se agrupan según la clase de excepción y la ubicación donde ocurrió. Consulta la documentación del grabador de excepciones para obtener más información.

La card <livewire:pulse.queues /> muestra el rendimiento de las colas en tu aplicación, incluyendo el número de trabajos en cola, en procesamiento, procesados, liberados y fallidos. Consulta la documentación del grabador de colas para obtener más información.

La tarjeta <livewire:pulse.slow-requests /> muestra las solicitudes entrantes a tu aplicación que superan el umbral configurado, que es de 1,000 ms por defecto. Consulta la documentación del grabador de solicitudes lentas para obtener más información.

La tarjeta <livewire:pulse.slow-jobs /> muestra los trabajos en cola en tu aplicación que superan el umbral configurado, que es de 1,000 ms por defecto. Consulta la documentación del grabador de trabajos lentos para más información.

La tarjeta <livewire:pulse.slow-queries /> muestra las consultas a la base de datos en tu aplicación que exceden el umbral configurado, que es de 1,000 ms por defecto. Por defecto, las consultas lentas se agrupan según la consulta SQL (sin enlaces) y la ubicación donde ocurrieron, pero puedes optar por no capturar la ubicación si deseas agrupar solo en la consulta SQL. Si encuentras problemas de rendimiento de representación debido a consultas SQL extremadamente grandes que reciben resaltado de sintaxis, puedes desactivar el resaltado añadiendo el prop without-highlighting:

<livewire:pulse.slow-queries without-highlighting />

Consulta la documentación del grabador de consultas lentas para obtener más información.

La tarjeta <livewire:pulse.slow-outgoing-requests /> muestra las solicitudes salientes realizadas utilizando el cliente HTTP de Laravel que superan el umbral configurado, que es de 1,000 ms por defecto. Por defecto, las entradas se agruparán por la URL completa. Sin embargo, es posible que desees normalizar o agrupar solicitudes salientes similares utilizando expresiones regulares. Consulta la documentación del grabador de solicitudes salientes lentas para obtener más información.

Caché

La tarjeta <livewire:pulse.cache /> muestra las estadísticas de aciertos y fallos de caché para tu aplicación, tanto de forma global como para claves individuales. Por defecto, las entradas se agruparán por clave. Sin embargo, es posible que desees normalizar o agrupar claves similares utilizando expresiones regulares. Consulta la documentación del grabador de interacciones de caché para obtener más información.

Capturando Entradas

La mayoría de los grabadores de Pulse capturarán automáticamente las entradas basadas en eventos de framework despachados por Laravel. Sin embargo, el grabador de servidores y algunas tarjetas de terceros deben sondear información de manera regular. Para usar estas tarjetas, debes ejecutar el daemon pulse:check en todos tus servidores de aplicación individuales:

php artisan pulse:check
lightbulb

Para mantener el proceso pulse:check en ejecución de forma permanente en segundo plano, debes usar un monitor de procesos como Supervisor para asegurar que el comando no deje de ejecutarse. Dado que el comando pulse:check es un proceso de larga duración, no verá cambios en tu base de código sin ser reiniciado. Debes reiniciar el comando de manera controlada llamando al comando pulse:restart durante el proceso de despliegue de tu aplicación:

Grabadores

Los grabadores son responsables de capturar las entradas de tu aplicación para ser registradas en la base de datos de Pulse. Los grabadores se registran y configuran en la sección recorders del archivo de configuración de Pulse.

Interacciones de Caché

El grabador CacheInteractions captura información sobre los aciertos y fallos de caché que ocurren en tu aplicación para su visualización en la tarjeta Cache. Puedes ajustar opcionalmente la tasa de muestreo y los patrones de clave ignorados. También puedes configurar el agrupamiento de claves para que claves similares se agrupen como una sola entrada. Por ejemplo, es posible que desees eliminar ID únicos de claves que almacenan el mismo tipo de información. Los grupos se configuran utilizando una expresión regular para "buscar y reemplazar" partes de la clave. Se incluye un ejemplo en el archivo de configuración:

Recorders\CacheInteractions::class => [
    // ...
    'groups' => [
        // '/:\d+/' => ':*',
    ],
],

El primer patrón que coincida será utilizado. Si no coinciden patrones, entonces la clave será capturada tal como está.

Excepciones

El grabador de Exceptions captura información sobre las excepciones reportables que ocurren en tu aplicación para su visualización en la tarjeta de Exceptions. Puedes ajustar opcionalmente la tasa de muestreo y los patrones de excepciones ignoradas. También puedes configurar si deseas capturar la ubicación de donde se originó la excepción. La ubicación capturada se mostrará en el panel de Pulse, lo que puede ayudar a rastrear el origen de la excepción; sin embargo, si la misma excepción ocurre en múltiples ubicaciones, aparecerá múltiples veces para cada ubicación única.

Colas

El grabador Queues captura información sobre las colas de tus aplicaciones para su visualización en el Queues. Puedes ajustar opcionalmente la tasa de muestreo y los patrones de trabajos ignorados.

Trabajos Lentos

El grabador SlowJobs captura información sobre trabajos lentos que ocurren en tu aplicación para su visualización en la tarjeta Slow Jobs. Puedes ajustar opcionalmente el umbral de trabajos lentos, la frecuencia de muestreo y los patrones de trabajos ignorados. Es posible que tengas algunos trabajos que esperas que tomen más tiempo que otros. En esos casos, puedes configurar umbrales por trabajo:

Recorders\SlowJobs::class => [
    // ...
    'threshold' => [
        '#^App\\Jobs\\GenerateYearlyReports$#' => 5000,
        'default' => env('PULSE_SLOW_JOBS_THRESHOLD', 1000),
    ],
],

Si no hay patrones de expresión regular que coincidan con el nombre de clase del trabajo, entonces se utilizará el valor 'default'.

Solicitudes Salientes Lentas

El registrador SlowOutgoingRequests captura información sobre las solicitudes HTTP salientes realizadas utilizando el cliente HTTP de Laravel que superan el umbral configurado para su visualización en la tarjeta de Solicitudes Salientes Lentas. Puedes ajustar opcionalmente el umbral de solicitud saliente lenta, la tasa de muestreo y los patrones de URL ignorados. Puede que tengas algunas solicitudes salientes que esperas que tomen más tiempo que otras. En esos casos, puedes configurar umbrales por solicitud:

Recorders\SlowOutgoingRequests::class => [
    // ...
    'threshold' => [
        '#backup.zip$#' => 5000,
        'default' => env('PULSE_SLOW_OUTGOING_REQUESTS_THRESHOLD', 1000),
    ],
],

También puedes configurar el agrupamiento de URL para que las URL similares se agrupen como una sola entrada. Por ejemplo, es posible que desees eliminar identificadores únicos de las rutas de URL o agrupar solo por dominio. Los grupos se configuran utilizando una expresión regular para "encontrar y reemplazar" partes de la URL. Algunos ejemplos se incluyen en el archivo de configuración:

Recorders\SlowOutgoingRequests::class => [
    // ...
    'groups' => [
        // '#^https://api\.github\.com/repos/.*$#' => 'api.github.com/repos/*',
        // '#^https?://([^/]*).*$#' => '\1',
        // '#/\d+#' => '/*',
    ],
],

El primer patrón que coincida será utilizado. Si no coinciden patrones, entonces la URL será capturada tal como está.

Consultas Lentas

El grabador SlowQueries captura cualquier consulta a la base de datos en tu aplicación que supere el umbral configurado para su visualización en la tarjeta de Consultas Lentas. Puedes ajustar opcionalmente el umbral de consulta lenta, la tasa de muestreo y los patrones de consulta ignorados. También puedes configurar si deseas capturar la ubicación de la consulta. La ubicación capturada se mostrará en el panel de Pulse, lo que puede ayudar a rastrear el origen de la consulta; sin embargo, si se realiza la misma consulta en múltiples ubicaciones, aparecerá múltiples veces por cada ubicación única. Es posible que tengas algunas consultas que esperas que tomen más tiempo que otras. En esos casos, puedes configurar umbrales por consulta:

Recorders\SlowQueries::class => [
    // ...
    'threshold' => [
        '#^insert into `yearly_reports`#' => 5000,
        'default' => env('PULSE_SLOW_QUERIES_THRESHOLD', 1000),
    ],
],

Si no coinciden patrones de expresión regular con el SQL de la consulta, entonces se utilizará el valor 'default'.

Solicitudes Lentas

El grabador de Requests captura información sobre las solicitudes realizadas a tu aplicación para su visualización en las tarjetas Solicitudes Lentas y Uso de la Aplicación. Puedes ajustar opcionalmente el umbral de la ruta lenta, la tasa de muestreo y las rutas ignoradas. Es posible que tengas algunas solicitudes que esperas que tarden más que otras. En esos casos, puedes configurar umbrales por solicitud:

Recorders\SlowRequests::class => [
    // ...
    'threshold' => [
        '#^/admin/#' => 5000,
        'default' => env('PULSE_SLOW_REQUESTS_THRESHOLD', 1000),
    ],
],

Si no hay patrones de expresión regular que coincidan con la URL de la solicitud, entonces se utilizará el valor 'default'.

Servidores

El grabador Servers captura el uso de CPU, memoria y almacenamiento de los servidores que impulsan tu aplicación para mostrarse en la tarjeta Servers. Este grabador requiere que el comando pulse:check esté en ejecución en cada uno de los servidores que deseas monitorear. Cada servidor de informes debe tener un nombre único. Por defecto, Pulse utilizará el valor devuelto por la función gethostname de PHP. Si deseas personalizar esto, puedes establecer la variable de entorno PULSE_SERVER_NAME:

PULSE_SERVER_NAME=load-balancer

El archivo de configuración de Pulse también te permite personalizar los directorios que se supervisan.

Trabajos de Usuario

El registrador UserJobs captura información sobre los usuarios que despachan trabajos en tu aplicación para su visualización en el card Uso de la Aplicación. Puedes ajustar opcionalmente el tasa de muestreo y los patrones de trabajo ignorados.

Solicitudes de Usuario

El grabador UserRequests captura información sobre los usuarios que realizan solicitudes a tu aplicación para su visualización en la tarjeta Application Usage. Puedes ajustar opcionalmente la tasa de muestreo y los patrones de URL ignorados.

Filtrado

Como hemos visto, muchos grabadores ofrecen la capacidad de, a través de la configuración, "ignorar" entradas entrantes en función de su valor, como la URL de una solicitud. Pero, a veces puede ser útil filtrar registros en función de otros factores, como el usuario autenticado actualmente. Para filtrar estos registros, puedes pasar una función anónima al método filter de Pulse. Típicamente, el método filter debe invocarse dentro del método boot del AppServiceProvider de tu aplicación:

use Illuminate\Support\Facades\Auth;
use Laravel\Pulse\Entry;
use Laravel\Pulse\Facades\Pulse;
use Laravel\Pulse\Value;

/**
 * Bootstrap any application services.
 */
public function boot(): void
{
    Pulse::filter(function (Entry|Value $entry) {
        return Auth::user()->isNotAdmin();
    });

    // ...
}

Rendimiento

Pulse ha sido diseñado para integrarse en una aplicación existente sin requerir infraestructura adicional. Sin embargo, para aplicaciones de alto tráfico, hay varias formas de eliminar cualquier impacto que Pulse pueda tener en el rendimiento de tu aplicación.

Usando una Base de Datos Diferente

Para aplicaciones de alto tráfico, es posible que prefieras usar una conexión de base de datos dedicada para Pulse para evitar afectar la base de datos de tu aplicación. Puedes personalizar la conexión a la base de datos utilizada por Pulse configurando la variable de entorno PULSE_DB_CONNECTION.

PULSE_DB_CONNECTION=pulse

Ingesta de Redis

exclamation

El Ingesta de Redis requiere Redis 6.2 o superior y phpredis o predis como el driver del cliente Redis configurado de la aplicación. Por defecto, Pulse almacenará las entradas directamente en la conexión a la base de datos configurada después de que se haya enviado la respuesta HTTP al cliente o se haya procesado un trabajo; sin embargo, puedes usar el driver de ingestión de Redis de Pulse para enviar las entradas a un flujo de Redis en su lugar. Esto se puede habilitar configurando la variable de entorno PULSE_INGEST_DRIVER:

PULSE_INGEST_DRIVER=redis

Pulse utilizará tu conexión Redis predeterminada por defecto, pero puedes personalizar esto a través de la variable de entorno PULSE_REDIS_CONNECTION:

PULSE_REDIS_CONNECTION=pulse

Al utilizar la ingestión de Redis, necesitarás ejecutar el comando pulse:work para supervisar el flujo y mover las entradas de Redis a las tablas de la base de datos de Pulse.

php artisan pulse:work
lightbulb

Para mantener el proceso pulse:work funcionando de manera permanente en segundo plano, debes usar un monitor de procesos como Supervisor para asegurarte de que el trabajador de Pulse no deje de funcionar. Como el comando pulse:work es un proceso de larga duración, no verá cambios en tu base de código sin ser reiniciado. Debes reiniciar el comando de manera elegante llamando al comando pulse:restart durante el proceso de despliegue de tu aplicación:

php artisan pulse:restart
lightbulb

Pulse utiliza la cache para almacenar señales de reinicio, así que debes verificar que un driver de caché esté configurado correctamente para tu aplicación antes de usar esta función.

Muestreo

Por defecto, Pulse capturará cada evento relevante que ocurra en tu aplicación. Para aplicaciones de alto tráfico, esto puede resultar en la necesidad de agregar millones de filas de base de datos en el panel, especialmente para períodos de tiempo más largos. Puedes elegir activar "muestreo" en ciertos grabadores de datos Pulse. Por ejemplo, configurar la tasa de muestreo a 0.1 en el grabador User Requests significará que solo grabas aproximadamente el 10% de las solicitudes a tu aplicación. En el panel de control, los valores se escalarán y se les añadirá un ~ para indicar que son una aproximación. En general, cuanto más entradas tengas para una métrica particular, más bajo puedes ajustar la tasa de muestreo sin sacrificar demasiada precisión.

Recorte

Pulse recortará automáticamente sus entradas almacenadas una vez que estén fuera de la ventana del panel. El recorte ocurre al ingerir datos utilizando un sistema de lotería que se puede personalizar en el archivo de configuración de Pulse.

Manejo de Excepciones de Pulse

Si ocurre una excepción al capturar datos de Pulse, como no poder conectarse a la base de datos de almacenamiento, Pulse fallará en silencio para evitar afectar tu aplicación. Si deseas personalizar cómo se manejan estas excepciones, puedes proporcionar una función anónima al método handleExceptionsUsing:

use Laravel\Pulse\Facades\Pulse;
use Illuminate\Support\Facades\Log;

Pulse::handleExceptionsUsing(function ($e) {
    Log::debug('An exception happened in Pulse', [
        'message' => $e->getMessage(),
        'stack' => $e->getTraceAsString(),
    ]);
});

Tarjetas Personalizadas

Pulse te permite crear tarjetas personalizadas para mostrar datos relevantes a las necesidades específicas de tu aplicación. Pulse utiliza Livewire, así que es posible que desees revisar su documentación antes de construir tu primera tarjeta personalizada.

Componentes de Tarjetas

Crear una tarjeta personalizada en Laravel Pulse comienza con extender el componente Livewire Card base y definiendo una vista correspondiente:

namespace App\Livewire\Pulse;

use Laravel\Pulse\Livewire\Card;
use Livewire\Attributes\Lazy;

#[Lazy]
class TopSellers extends Card
{
    public function render()
    {
        return view('livewire.pulse.top-sellers');
    }
}

Al utilizar la función de carga perezosa de Livewire, el componente Card proporcionará automáticamente un marcador de posición que respeta los atributos cols y rows pasados a tu componente. Al escribir la vista correspondiente de tu tarjeta Pulse, puedes aprovechar los componentes Blade de Pulse para un aspecto y una sensación consistentes:

<x-pulse::card :cols="$cols" :rows="$rows" :class="$class" wire:poll.5s="">
    <x-pulse::card-header name="Top Sellers">
        <x-slot:icon>
            ...
        </x-slot:icon>
    </x-pulse::card-header>

    <x-pulse::scroll :expand="$expand">
        ...
    </x-pulse::scroll>
</x-pulse::card>

Las variables $cols, $rows, $class y $expand deben pasarse a sus respectivos componentes Blade para que el diseño de la tarjeta pueda personalizarse desde la vista del panel de control. También es posible que desees incluir el atributo wire:poll.5s="" en tu vista para que la tarjeta se actualice automáticamente. Una vez que hayas definido tu componente Livewire y plantilla, la tarjeta puede incluirse en tu vista de dashboard:

<x-pulse>
    ...

    <livewire:pulse.top-sellers cols="4" />
</x-pulse>
lightbulb

Si tu tarjeta está incluida en un paquete, necesitarás registrar el componente con Livewire utilizando el método Livewire::component.

Estilización

Si tu tarjeta requiere un estilo adicional más allá de las clases y componentes incluidos con Pulse, hay algunas opciones para incluir CSS personalizado para tus tarjetas.

Integración de Laravel Vite

Si tu tarjeta personalizada vive dentro de la base de código de tu aplicación y estás utilizando la integración de Vite de Laravel, puedes actualizar tu archivo vite.config.js para incluir un punto de entrada CSS dedicado para tu tarjeta:

laravel({
    input: [
        'resources/css/pulse/top-sellers.css',
        // ...
    ],
}),

Ahora puedes usar la directiva Blade @vite en tu vista del panel, especificando el punto de entrada CSS para tu tarjeta:

<x-pulse>
    @vite('resources/css/pulse/top-sellers.css')

    ...
</x-pulse>

Archivos CSS

Para otros casos de uso, incluidos los cards de Pulse contenidos dentro de un paquete, puedes instruir a Pulse para que cargue hojas de estilo adicionales definiendo un método css en tu componente de Livewire que devuelva la ruta del archivo a tu archivo CSS:

class TopSellers extends Card
{
    // ...

    protected function css()
    {
        return __DIR__.'/../../dist/top-sellers.css';
    }
}

Cuando esta tarjeta se incluye en el panel, Pulse incluirá automáticamente el contenido de este archivo dentro de una etiqueta <style>, por lo que no es necesario publicarlo en el directorio public.

Tailwind CSS

Al usar Tailwind CSS, debes crear un archivo de configuración de Tailwind dedicado para evitar cargar CSS innecesario o entrar en conflicto con las clases de Tailwind de Pulse:

export default {
    darkMode: 'class',
    important: '#top-sellers',
    content: [
        './resources/views/livewire/pulse/top-sellers.blade.php',
    ],
    corePlugins: {
        preflight: false,
    },
};

Entonces, puedes especificar el archivo de configuración en tu punto de entrada CSS:

@config "../../tailwind.top-sellers.config.js";
@tailwind base;
@tailwind components;
@tailwind utilities;

También necesitarás incluir un atributo id o class en la vista de tu tarjeta que coincida con el selector pasado a la estrategia de selección important de Tailwind:

<x-pulse::card id="top-sellers" :cols="$cols" :rows="$rows" class="$class">
    ...
</x-pulse::card>

Captura y Agregación de Datos

Las tarjetas personalizadas pueden obtener y mostrar datos desde cualquier lugar; sin embargo, es posible que desees aprovechar el poderoso y eficiente sistema de grabación y agregación de datos de Pulse.

Capturando Entradas

Pulse te permite registrar "entradas" utilizando el método Pulse::record:

use Laravel\Pulse\Facades\Pulse;

Pulse::record('user_sale', $user->id, $sale->amount)
    ->sum()
    ->count();

El primer argumento proporcionado al método record es el type para la entrada que estás registrando, mientras que el segundo argumento es la key que determina cómo se deben agrupar los datos agregados. Para la mayoría de los métodos de agregación, también necesitarás especificar un value que se agregará. En el ejemplo anterior, el valor que se está agregando es $sale->amount. Luego puedes invocar uno o más métodos de agregación (como sum) para que Pulse pueda capturar los valores pre-agregados en "cubos" para una recuperación eficiente más adelante. Los métodos de agregación disponibles son:

  • avg
  • count
  • max
  • min
  • sum
lightbulb

Al construir un paquete de tarjeta que captura la ID del usuario autenticado actualmente, debes usar el método Pulse::resolveAuthenticatedUserId(), que respeta cualquier personalización del resolutor de usuarios realizada en la aplicación.

Recuperando Datos Agregados

Al extender el componente Card de Livewire de Pulse, puedes usar el método aggregate para recuperar datos agregados para el periodo que se está viendo en el panel:

class TopSellers extends Card
{
    public function render()
    {
        return view('livewire.pulse.top-sellers', [
            'topSellers' => $this->aggregate('user_sale', ['sum', 'count'])
        ]);
    }
}

El método aggregate devuelve una colección de objetos stdClass de PHP. Cada objeto contendrá la propiedad key capturada anteriormente, junto con claves para cada uno de los agregados solicitados:

@foreach ($topSellers as $seller)
    {{ $seller->key }}
    {{ $seller->sum }}
    {{ $seller->count }}
@endforeach

Pulse recuperará principalmente datos de los cubos pre-agregados; por lo tanto, los agregados especificados deben haber sido capturados desde el inicio utilizando el método Pulse::record. El cubo más antiguo típicamente caerá parcialmente fuera del período, por lo que Pulse agregará las entradas más antiguas para llenar el vacío y dar un valor preciso para todo el período, sin necesidad de agregar todo el período en cada solicitud de sondeo. También puedes recuperar un valor total para un tipo dado utilizando el método aggregateTotal. Por ejemplo, el siguiente método obtendría el total de todas las ventas de usuarios en lugar de agruparlas por usuario.

$total = $this->aggregateTotal('user_sale', 'sum');

Mostrando Usuarios

Al trabajar con agregados que registran un ID de usuario como la clave, puedes resolver las claves a registros de usuario utilizando el método Pulse::resolveUsers:

$aggregates = $this->aggregate('user_sale', ['sum', 'count']);

$users = Pulse::resolveUsers($aggregates->pluck('key'));

return view('livewire.pulse.top-sellers', [
    'sellers' => $aggregates->map(fn ($aggregate) => (object) [
        'user' => $users->find($aggregate->key),
        'sum' => $aggregate->sum,
        'count' => $aggregate->count,
    ])
]);

El método find devuelve un objeto que contiene las claves name, extra y avatar, que puedes pasar opcionalmente directamente al componente Blade <x-pulse::user-card>:

<x-pulse::user-card :user="{{ $seller->user }}" :stats="{{ $seller->sum }}" />

Grabadores Personalizados

Los autores del paquete pueden desear proporcionar clases de grabador para permitir a los usuarios configurar la captura de datos. Los grabadores se registran en la sección recorders del archivo de configuración config/pulse.php de la aplicación:

[
    // ...
    'recorders' => [
        Acme\Recorders\Deployments::class => [
            // ...
        ],

        // ...
    ],
]

Los grabadores pueden escuchar eventos especificando una propiedad $listen. Pulse registrará automáticamente los oyentes y llamará al método record de los grabadores:

<?php

namespace Acme\Recorders;

use Acme\Events\Deployment;
use Illuminate\Support\Facades\Config;
use Laravel\Pulse\Facades\Pulse;

class Deployments
{
    /**
     * The events to listen for.
     *
     * @var array<int, class-string>
     */
    public array $listen = [
        Deployment::class,
    ];

    /**
     * Record the deployment.
     */
    public function record(Deployment $event): void
    {
        $config = Config::get('pulse.recorders.'.static::class);

        Pulse::record(
            // ...
        );
    }
}