fignon / fignon-smarty-engine
The Fignon smarty Engine is a simple class which serve as bridge between the smarty template engine and Fignon Framework
Installs: 3
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/fignon/fignon-smarty-engine
Requires
- php: >=8.0.0
- fignon/fignon-view-engine: ^0.0.1
- smarty/smarty: ^3.0
README
This is a simple class to encapsulate the Smarty template engine and use it easily in the Fignon Framework.
In your Fignon project, run:
composer require fignon/fignon-smarty-engine
Then, use it like this:
//app.php (or index.php) depending of how you call you entry point declare(strict_types=1); include_once __DIR__ . "/../vendor/autoload.php"; use Fignon\Tunnel; use App\Features\Features; use Fignon\Extra\SmartyEngine; $app = new Tunnel(); $app->set('env', 'development'); // ... other middlewares // View engine initialization $app->set('views', dirname(__DIR__) . '/templates'); $app->set('views cache', dirname(__DIR__) . '/var/cache'); $app->set('view engine options', [ // Smarty require these additional option to work 'compileDir' => 'path/to/compile/dir', 'configDir' => 'path/to/config/dir' ]); // Add options to the view engine $app->engine('smarty', new SmartyEngine()); $app->set('case sensitive routing', true); // ... other middlewares // You can then use it to render (new Features($app))->bootstrap(); $app->listen();
Other view engine integration to Fignon are:
Sample Smarty Config files:
#path/to/config/dir/smarty_config.conf # global variables pageTitle = "Main Menu" bodyBgColor = #000000 tableBgColor = #000000 rowBgColor = #00ff00 [Customer] pageTitle = "Customer Info" [Login] pageTitle = "Login" focus = "username" Intro = """This is a value that spans more than one line. you must enclose it in triple quotes.""" # hidden section [.Database] host=my.example.com db=ADDRESSBOOK user=php-user pass=foobar
To learn more about smarty, please refer to the documentation of Smarty.