PHPackages                             rep98/dt-laravel-eloquent - PHPackages - PHPackages  [Skip to content](#main-content)[PHPackages](/)[Directory](/)[Categories](/categories)[Trending](/trending)[Leaderboard](/leaderboard)[Changelog](/changelog)[Analyze](/analyze)[Collections](/collections)[Log in](/login)[Sign up](/register)

1. [Directory](/)
2. /
3. [Utility &amp; Helpers](/categories/utility)
4. /
5. rep98/dt-laravel-eloquent

ActiveLibrary[Utility &amp; Helpers](/categories/utility)

rep98/dt-laravel-eloquent
=========================

Simple DataTable para Laravel Eloquent

1.0.0(8mo ago)07MITPHPPHP ^8.2

Since Aug 31Pushed 8mo ago1 watchersCompare

[ Source](https://github.com/REP98/dt-laravel-eloquent)[ Packagist](https://packagist.org/packages/rep98/dt-laravel-eloquent)[ RSS](/packages/rep98-dt-laravel-eloquent/feed)WikiDiscussions main Synced 1mo ago

READMEChangelog (1)Dependencies (10)Versions (4)Used By (0)

DataTabla Laravel Eloquent
==========================

[](#datatabla-laravel-eloquent)

Un simple, pero potente DataTable hecho para colecciones y eloquent de Laravel, su integración y uso es muy sencillo.

[![Capture de Pantalla](prints.png)](prints.png)

Instalación
-----------

[](#instalación)

Primero integramos el componente a nuestro proyecto

```
composer require rep98/dt-laravel-eloquent
```

luego publicamos el proveedor

```
php artisan vendor:publish --provider="DTLaravelEloquent\RDataTableServiceProvider"
```

Y, por último, de forma opcional, podemos ejecutar para instalar el componente

```
php artisan RDT:install
```

Podemos pasar la bandera `--raw` si queremos modificar el js o css, \[se recomienda tener npm\]

Uso
---

[](#uso)

```
use DTLaravelEloquent\RDT;

function index() {
    $dt = RDT::make(User::all())
        ->excludeFields(["password"])
        ->render()
    return view("auth.users", compact("dt"))
}
```

en Blade

```
{{-- para el export --}}

{{-- la tabla --}}
{!! $dt !!}
```

> ¿Simple no?

Configuración
-------------

[](#configuración)

Este proyecto usa [`fiduswriter/simple-datatables`](https://fiduswriter.github.io/simple-datatables/) para el manejo efectivo de tablas, por ello sus configuraciones se ajustan a este componente

- `RDataTable` es el archivo de configuración base
- `RDTOptions` es la clase encargada de administrar las configuraciones y hacerlas compatibles como el js [`fiduswriter/simple-datatables`](https://fiduswriter.github.io/simple-datatables/)

### Opciones de configuración

[](#opciones-de-configuración)

Como he mencionado, todas las opciones de configuración son obtenidas del componente [`fiduswriter/simple-datatables`](https://fiduswriter.github.io/simple-datatables/) con algunos ajustes y excepciones.

A continuación explicaré los ajustes y excepciones si desea conocer el resto de opciones, visite [Opciones de Simple Datatables](https://fiduswriter.github.io/simple-datatables/documentation/Options)

Opcionesvalor por defectoDescripción`options``array`Opciones de configuración del componente js`export``array`Opciones de exportaciónOpciones de Exportación

- `export.name` Contiene el nombre del archivo generado cuando se usa `Excel` o `PDF`.

Opciones de Configuración del Componente JS

Opcionesvalor por defectoDescripción`options.type``html`Representa el tipo de datos en las celdas de las columnas. [Ver detalle](https://fiduswriter.github.io/simple-datatables/documentation/columns#type)`options.format``YYYY-MM-DD`Cadena que representa el formato cuando se utiliza el tipo fecha.`options.locale``en`Idioma de la tabla; por defecto, la clase `RDTOptions` intenta obtener el idioma de sus configuraciones aplicadas a `app.php` y las asigna a esta opción.`options.perPage``20`Cantidad de resultados por página`options.perPageSelect``[5, 20, 50, 100, 150]`Matriz que permite al componente generar un selector para indicar cuántos resultados ver por página`options.labels``array`Son textos que se muestran en el DataTable, por defecto, la clase `RDTOptions` intenta obtenerlos desde la carpeta lang del componente, para conocer más [aquí](https://fiduswriter.github.io/simple-datatables/documentation/labels)### Clase de configuración

[](#clase-de-configuración)

La clase `RDTOptions` se usa para establecer opciones de configuración que luego serán transformadas en un objeto JavaScript para la librería [`fiduswriter/simple-datatables`](https://fiduswriter.github.io/simple-datatables/)

Sus métodos son:

- `__construct(array $options = [])` Inicializa la clase de opciones, recibe las opciones que se usarán.
- `set(string $key, mixed $value): RDTOptions` permite establecer una nueva opción o actualizar una existente.
- `get(string $key, mixed $default = null): mixed` permite obtener el valor de una opción dada.
- `merge(array $options): RDTOptions` Permite mezclar múltiples opciones
- `toArray(): array` Exporta las opciones configuradas en un `array`.
- `toCollect(): Collection` Exporta una colección Laravel de las opciones.

Esta clase tiene métodos protegidos `protected` que permite establecer opciones por defecto y obtener el idioma o ajustes de fechas de forma automática.

La Magia
--------

[](#la-magia)

La clase `RDT`, esta es la clase principal de este componente básicamente, con ella se realiza todo lo necesario para imprimir tablas de datos hermosas.

```
return RDT::DB(MyModel::all())
    ->setOption(['sortable' => false])
    ->humanHeaders([
        "created_at"=>"Fecha de Registro"
    ])
    ->excludeFields([
        'id', 'updated_at'
    ])
    ->render();
```

### Sus Métodos

[](#sus-métodos)

Métodos Estáticos

- `RDT::collection(Collection $data): RDT` Recibe una colección Laravel e inicializa el componente.
- `RDT::DB(Collection $data): RDT` Recibe una colección Eloquent de Laravel e inicializa el componente.
- `RDT::make(Collection|EloquentCollection|array $data): RDT` Recibe una colección ó colección Eloquent de Laravel e inicializa el componente.

Métodos Públicos

- `setOption(RDTOptions $options): RDT` Permite establecer opciones de configuración a los datos actuales.
- `getOptions(): RDTOptions` Retorna las opciones establecidas.
- `mergeOptions(array|RDTOptions $options): RDT` Permite mezclar opciones nuevas con las existentes, útil cuando queremos usar condiciones o datos dinámicos.
- `humanHeaders(array $header): RDT` Permite transformar la cabecera de la tabla en algo mas legible para Humanos.
- `log(): RDT` Inicial los registros logs para esta tabla.
- `excludeFields(array $fields): RDT` Permite excluir campos de los datos pasados en el constructor.
- `getData(): array` Permite obtener los datos procesados.

- `getRawData() : array` Permite obtener los datos sin procesar.
- `set_uniqueID(?string $id=null): RDT` Permite establecer un identificador único para esta tabla; por defecto, se autógena.
- `render()` Esta quizás es la función más importante y la única obligatoria aparte del constructor, es la responsable de retornar la vista con la tabla generada.

Comando
-------

[](#comando)

**DTLaravelEloquent** integra un comando `RDT:install` cuya función es permitir usar los archivos sin compilar a fin de que pueda modificarlos a sus necesidades. Para esto debe usar la bandera `--raw`, ya que si no la usa simplemente se copiará la carpeta `dist` a su carpeta pública.

Vista
-----

[](#vista)

**DTLaravelEloquent** Ofrece un componente de vista el cual permite obtener los archivos CSS y JS desde su carpeta pública a fin de poder mostrar la tabla correctamente.

Adicional
---------

[](#adicional)

Este paquete esta desarrollado usando [fiduswriter/simple-datatables](https://fiduswriter.github.io/simple-datatables/) con [Bootstrap 5.3](https://getbootstrap.com/) y utiliza iconos SVG de [Bootstrap Icon](https://icons.getbootstrap.com/), fue provado en [Laravel Vesión 11](https://laravel.com/docs/11.x/installation) y actualizado a [Laravel Vesión 12](https://laravel.com/docs/12.x/installation).

La finalidad de este desarrollo es el poder ayudar con un DataTable Simple, Rápido y eficiente.

###  Health Score

33

—

LowBetter than 75% of packages

Maintenance58

Moderate activity, may be stable

Popularity4

Limited adoption so far

Community7

Small or concentrated contributor base

Maturity54

Maturing project, gaining track record

 Bus Factor1

Top contributor holds 100% of commits — single point of failure

How is this calculated?**Maintenance (25%)** — Last commit recency, latest release date, and issue-to-star ratio. Uses a 2-year decay window.

**Popularity (30%)** — Total and monthly downloads, GitHub stars, and forks. Logarithmic scaling prevents top-heavy scores.

**Community (15%)** — Contributors, dependents, forks, watchers, and maintainers. Measures real ecosystem engagement.

**Maturity (30%)** — Project age, version count, PHP version support, and release stability.

###  Release Activity

Cadence

Every ~180 days

Total

3

Last Release

266d ago

Major Versions

v0.5.3 → 1.0.02025-08-26

PHP version history (2 changes)v0.5.0PHP ^8.0

1.0.0PHP ^8.2

### Community

Maintainers

![](https://www.gravatar.com/avatar/787b32ab010a1f8e32875260236d74930d9a4a510aa74792e629c6ad37015c04?d=identicon)[REP98](/maintainers/REP98)

---

Top Contributors

[![REP98](https://avatars.githubusercontent.com/u/21279408?v=4)](https://github.com/REP98 "REP98 (6 commits)")

---

Tags

laraveltabledatatable

###  Code Quality

TestsPHPUnit

### Embed Badge

![Health badge](/badges/rep98-dt-laravel-eloquent/health.svg)

```
[![Health](https://phpackages.com/badges/rep98-dt-laravel-eloquent/health.svg)](https://phpackages.com/packages/rep98-dt-laravel-eloquent)
```

###  Alternatives

[barryvdh/laravel-ide-helper

Laravel IDE Helper, generates correct PHPDocs for all Facade classes, to improve auto-completion.

14.9k123.0M687](/packages/barryvdh-laravel-ide-helper)[roots/acorn

Framework for Roots WordPress projects built with Laravel components.

9682.1M97](/packages/roots-acorn)[tucker-eric/eloquentfilter

An Eloquent way to filter Eloquent Models

1.8k4.8M26](/packages/tucker-eric-eloquentfilter)[aedart/athenaeum

Athenaeum is a mono repository; a collection of various PHP packages

245.2k](/packages/aedart-athenaeum)[flarum/core

Delightfully simple forum software.

211.3M1.9k](/packages/flarum-core)[tehwave/laravel-achievements

Simple, elegant Achievements the Laravel way

7012.8k](/packages/tehwave-laravel-achievements)

PHPackages © 2026

[Directory](/)[Categories](/categories)[Trending](/trending)[Changelog](/changelog)[Analyze](/analyze)
