2017 © Pedro Peláez
 

library laravel-smarty

Smarty template engine for Laravel and Lumen

image

ytake/laravel-smarty

Smarty template engine for Laravel and Lumen

  • Tuesday, May 15, 2018
  • by ytake
  • Repository
  • 7 Watchers
  • 52 Stars
  • 54,784 Installations
  • PHP
  • 1 Dependents
  • 0 Suggesters
  • 14 Forks
  • 2 Open issues
  • 29 Versions
  • 6 % Grown

The README.md

Laravel.Smarty

Smarty Template Engine for Laravel
(Support for Laravel5.x - Laravel8.x and Lumen), (*1)

Build Status Coverage Status Scrutinizer Code Quality, (*2)

License Latest Version Total Downloads, (*3)

Installation For Laravel

Require this package with Composer, (*4)

$ composer require ytake/laravel-smarty

or composer.json, (*5)

"require": {
  "ytake/laravel-smarty": "^6.0"
},

Supported Auto-Discovery(^Laravel5.5), (*6)

add Laravel.Smarty Service Providers, (*7)

your config/app.php, (*8)

'providers' => [
    // add smarty extension
    Ytake\LaravelSmarty\SmartyServiceProvider::class, 
    // add artisan commands  
    Ytake\LaravelSmarty\SmartyConsoleServiceProvider::class, 
]

Installation For Lumen

Require this package with Composer, (*9)

$ composer require ytake/laravel-smarty

or composer.json, (*10)

"require": {
  "ytake/laravel-smarty": "~2.0"
},

register Laravel.Smarty Service Providers, (*11)

your bootstrap/app.php, (*12)

$app->configure('ytake-laravel-smarty');
$app->register(Ytake\LaravelSmarty\SmartyServiceProvider::class);
$app->register(Ytake\LaravelSmarty\SmartyConsoleServiceProvider::class);

Configuration

publish configuration file (for Laravel5)

$ php artisan vendor:publish

publish to config directory, (*13)

Of Course, Blade Template can also be used to Render Engine., (*14)

configuration file (for Lumen)

Copy the vendor/ytake/laravel-smarty/src/config/ytake-laravel-smarty.php file to your local config directory, (*15)

config for Production

edit config/ytake-laravel-smarty.php, (*16)

    // enabled smarty template cache
    'caching' => true, // default false

    // disabled smarty template compile
    'force_compile' => false, // default true(for develop)

Or, (*17)

add .env file, (*18)

SMARTY_CACHE=true
SMARTY_COMPILE=false

edit config/ytake-laravel-smarty.php, (*19)

    'caching' => env('SMARTY_CACHING', false),

    'force_compile' => env('SMARTY_FORCE_COMPILE', true),

and more..!, (*20)

Basic

easily use all the methods of Smarty, (*21)

// laravel5 view render
view("template.name");

// Laravel blade template render(use Facades)
\View::make('template', ['hello']);
// use Smarty method

\View::assign('word', 'hello');  
\View::clearAllAssign(); // smarty method

View Composer, and View Share

$this->app['view']->composer('index', function (View $view) {
    $view->with('message', 'enable smarty');
});
$this->app['view']->share('title', 'laravel-smarty');

Hello Laravel.Smarty

{$title}

{$message}

Artisan

smarty's cache clear, remove compile class from Artisan(cli), (*22)

Template cache clear

$ php artisan ytake:smarty-clear-cache
Options description
--file (-f) specify file
--time (-t) clear all of the files that are specified duration time
--cache_id (-cache) specified cache_id groups

Remove compile file

$ php artisan ytake:smarty-clear-compiled
Options description
--file (-f) specify file
--compile_id (-compile) specified compile_id

Template Compiler

$ php artisan ytake:smarty-optimize
Options description
--extension (-e) specified smarty file extension(default: .tpl)
--force compiles template files found in views directory

Template Caching

choose file, memcached, Redis
(default file cache driver), (*23)

// smarty cache driver "file", "memcached", "redis"
'cache_driver' => 'file',

// memcached servers
'memcached' => [
    [
        'host' => '127.0.0.1',
        'port' => 11211,
        'weight' => 100
    ],
],

// redis configure
'redis' => [
    [
        'host' => '127.0.0.1',
        'port' => 6379,
        'database' => 0,
    ],
],

example

registerFilter in ServiceProvider
registerFilter in Controller
layout.sample
layout.extends.sample, (*24)

The Versions