koolreport / twig
Allow KoolReport to use twig template engine to render view
Installs: 1 421
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 0
Requires
- twig/twig: ^2.0
This package is auto-updated.
Last update: 2024-12-11 00:28:24 UTC
README
Overview
Starting from version 4.0.0, KoolReport supports other template engines rather than just its own template view file. Twig
is one of the popular template engines that KoolReport supports.
Installation
By downloading .zip file
- Download
- Unzip the zip file
- Copy the folder
twig
intokoolreport
folder so that look like below
koolreport ├── core ├── twig
By composer
composer require koolreport/twig
Get started
Step 1: Add the twig service to your report
class Report extends \koolreport\KoolReport
{
use \koolreport\clients\Bootstrap;
use \koolreport\twig\Engine;
protected function twigInit()
{
$loader = new \Twig\Loader\FilesystemLoader(dirname(__FILE__).'/views');
$twig = new \Twig\Environment($loader);
return $twig;
}
...
}
Step 2: Create the view report.html
inside views
folder like below:
<html>
<head>
<title>Welcome to Twig</title>
</head>
<body>
<h1>Welcome to Twig</h1>
{{
widget('koolreport.widgets.koolphp.Table',{
dataSource:report.dataStore("data"),
})
}}
</body>
</html>
Step 3: You can run your report with following line of code
$report = new Report;
$report->run()->render("report.html");
Congrat, Now you can use Twig to design your report.
Some notes:
- In your template, you refer to report object with parameter
report
- When use function
widget()
to generate koolreport's widget, you should change the backslash\
in the class name to dot"."
, for example, you change:\koolreport\widgets\koolphp\Table
tokoolreport.widgets.koolphp.Table
- You can reference to any datastore with
report.dataStore("name_of_datastore")
Limitation
There are some limitation due to the fact that Twig
does not allow PHP to run within. This limits some of capability of KoolReport's widget such as defining anonymous function. For example, there is no way to define custom function to format value in Table widget like this.
Table::create(array(
...
"columns"=>array(
"id"=>array(
"formatValue"=>function($value)
{
return "<a href='$value'>View</a>";
}
)
)
))
Simply it is not able to transform above php code to json definition in twig.
Resources
Support
Please use our forum if you need support, by this way other people can benefit as well. If the support request need privacy, you may send email to us at support@koolreport.com.