initphp/views

InitPHP Views Engine

1.0 2023-01-14 07:07 UTC

This package is auto-updated.

Last update: 2024-11-14 11:34:09 UTC


README

Installation

composer require initphp/views

Usage

Note : Remember to choose to work with an adapter before using it.

$data = [
    'username'  => 'admin'
];

echo view('dashboard/dashboard', $data);

Give a string array to load multiple views.

$data = [
    'username'  => 'admin'
];

echo view(['header', 'content', 'footer'], $data);

$data can be an associative array or an object.

$data = new stdClass;
$data->username = 'admin';

echo view('dashboard/profile', $data);

Adapters

PurePHP Adapter

use \InitPHP\Views\Facade\View;
use \InitPHP\Views\Adapters\PurePHPAdapter;

$viewAdapter = new PurePHPAdapter(__DIR__ . '/Views/');

View::via($viewAdapter);

Note : This adapter uses .php for the extension of the view files. If the view file does not end with .php it is added automatically.

Note : This adapter includes the view files as a PHP file at runtime.

Laravel Blade (Illuminate/View) Adapter

Don't forget to install the relevant packages before you start.

composer require illuminate/view

To start using the adapter, just generate the Instance of the relevant adapter.

use \InitPHP\Views\Facade\View;
use \InitPHP\Views\Adapters\BladeAdapter;

$viewAdapter = new BladeAdapter(__DIR__ . '/Views/', __DIR__ . '/Cache/');

View::via($viewAdapter);

Note : This adapter may have some unique changes. Docs

View::directive('now', function ($format = null) {
    return '<?php echo '
            . ($format === null ? 'date("Y-m-d H:i:s")' : 'date(' . $format . ')')
            . ' ?>';
});

// @now
// @now("Y-m-d")

Symfony Twig (Twig/Twig) Adapter

Don't forget to install the relevant packages before you start.

composer require twig/twig

To start using the adapter, just generate the Instance of the relevant adapter.

use \InitPHP\Views\Facade\View;
use \InitPHP\Views\Adapters\TwigAdapter;

$viewAdapter = new TwigAdapter(__DIR__ . '/Views/', __DIR__ . '/Cache/');

View::via($viewAdapter);

Note : Note that the Twig engine accepts any file extension and you have to specify it manually. Docs

$data = [
    'username'  => 'admin'
];

echo view('dashboard/dashboard.html', $data);

Credits

License

Copyright © 2022 MIT License