masterfermin02/simple-data-grid

This is my package simple-data-grid

v0.0.3 2024-01-06 03:44 UTC

This package is auto-updated.

Last update: 2024-10-24 16:48:22 UTC


README

Latest Version on Packagist Tests Total Downloads

Simple Data Grid is a PHP package that provides an easy way to generate HTML tables from arrays of data. It supports custom headers, rows, CSS classes, and table properties.

Installation

You can install the package via composer:

composer require masterfermin02/simple-data-grid

Usage

Here's a basic example of how to use the Simple Data Grid:

use Masterfermin02\SimpleDataGrid\SimpleGrid;

$headers = ['Name', 'Email', 'Phone'];
$rows = [
    ['John Doe', 'john@example.com', '123-456-7890'],
    ['Jane Doe', 'jane@example.com', '098-765-4321'],
];

echo SimpleGrid::fromArray($headers, $rows)->render();

This will generate an HTML table with the specified headers, rows, CSS class, and table properties.

Mysql Database Support

This example assumes that you have a MySQL database running on localhost with a database named mydatabase, a table named users, and columns id, name, and email.

<?php

require __DIR__ . '/vendor/autoload.php';

use Masterfermin02\SimpleDataGrid\SimpleGrid;
use Masterfermin02\SimpleDataGrid\Database\MysqlQuery;
use Masterfermin02\SimpleDataGrid\Enums\DbTypes;

$grid = SimpleGrid::fromDatabase(
    server: 'localhost',
    username: 'myuser',
    password: 'mypassword',
    databaseName: 'mydatabase',
    dbType: DbTypes::MYSQL,
    port: 3306,
)
    ->mysqlQuery(
        new MysqlQuery(
            table: 'users',
            columns: ['id', 'name', 'email'],
        )
    );

echo $grid->render();

Add pagination

<?php
        $grid = SimpleGrid::fromArray(
            header: ['id', 'name', 'email'],
            rows: [
                [1, 'John Doe', 'josh@estemail.com'],
                [2, 'John Doe2', 'josh2@estemail.com'],
                [3, 'John Doe3', 'josh3@estemail.com'],
                [4, 'John Doe4', 'josh4@estemail.com'],
                [1, 'John Doe', 'josh@estemail.com'],
                [2, 'John Doe2', 'josh2@estemail.com'],
                [3, 'John Doe3', 'josh3@estemail.com'],
                [4, 'John Doe4', 'josh4@estemail.com'],
            ],
        )
            ->itemPerPage(3)
            ->currentPage(
                    $_GET['page'] ?? 1
            );

    echo $grid->render();
    echo (new PaginatorNav(
        $grid
    ))->render();

In this example, SimpleGrid::fromDatabase is used to create a new SimpleGrid instance connected to a MySQL database. The mysqlQuery method is then used to execute a SELECT query on the users table, selecting the id, name, and email columns. The render method is finally called to generate the HTML for the data grid.

Screenshots

N|Solid

Using laravel model

<?php
    $grid = SimpleGrid::fromArray(
            header: ['id', 'name', 'email'],
            rows: User::select('id','name', 'email')->get(),
        )
            ->itemPerPage(3)
            ->currentPage(
                    $_GET['page'] ?? 1
            );

    echo $grid->render();
    echo (new PaginatorNav(
        $grid
    ))->render();   

Using laravel query builder

<?php
    $grid = SimpleGrid::fromArray(
            header: ['id', 'name', 'email'],
            rows: DB::table('users')->select('id','name', 'email')->get(),
        )
            ->itemPerPage(3)
            ->currentPage(
                    $_GET['page'] ?? 1
            );

    echo $grid->render();
    echo (new PaginatorNav(
        $grid
    ))->render();   

Using laravel eloquent cursor

<?php
    $grid = SimpleGrid::fromIterator(
            header: ['id', 'name', 'email'],
            rows: User::select('id','name', 'email')->cursor(),
        )
            ->itemPerPage(3)
            ->currentPage(
                    $_GET['page'] ?? 1
            );

    echo $grid->render();
    echo (new PaginatorNav(
        $grid
    ))->render();   

Testing

composer test

Changelog

Please see CHANGELOG for more information on what has changed recently.

Contributing

Please see CONTRIBUTING for details.

Security Vulnerabilities

Please review our security policy on how to report security vulnerabilities.

Credits

License

The MIT License (MIT). Please see License File for more information.


This `README.md` provides a brief description of the package, installation instructions, a usage example, and links to other important documents like the changelog, contributing guidelines, and license.