danack / jig
Lightweight, fast, flexible PHP templating system that uses real dependency injection.
Requires
- nikic/php-parser: ^0.9.3
- zendframework/zend-escaper: ^2.5.0
Requires (Dev)
- mockery/mockery: 0.9.1
- nikic/fast-route: ~0.2.0
- phpunit/phpunit: 3.7.*
- rdlowrey/auryn: v1.0.0-alpha
- squizlabs/php_codesniffer: ^2.0.0
- dev-master
- 0.21.2
- 0.21.1
- 0.21.0
- 0.20.6
- 0.20.5
- 0.20.4
- 0.20.3
- 0.20.2
- 0.20.1
- 0.20.0
- 0.19.0
- 0.18.1
- 0.18.0
- 0.17.2
- 0.17.1
- 0.17.0
- 0.16.4
- 0.16.3
- 0.16.2
- 0.16.1
- 0.16.0
- 0.15.1
- 0.15.0
- 0.14.5
- 0.14.4
- 0.14.3
- 0.14.2
- 0.14.1
- 0.14.0
- 0.13.0
- 0.12.0
- 0.11.0
- 0.10.2
- 0.10.1
- 0.10.0
- 0.9.2
- 0.9.1
- 0.9.0
- 0.2.1
- 0.2.0
- 0.1.8
- 0.1.7
- 0.1.6
- 0.1.5
- 0.1.4
- 0.1.3
- 0.1.2
- 0.1.1
- 0.1.0
- dev-blockRenderExtraLine
This package is auto-updated.
Last update: 2022-09-11 23:09:23 UTC
README
Jig - "A device that holds a piece of machine work and guides the tools operating on it."
Or to put it another way, a jig allows you to work fast with sharp tools without cutting your fingers off.
Build status |
---|
What
Jig is a template renderer that promotes the view layer to be a first class citizen in your application.
By using it, all of your templates are unit-testable as it does not use the 'service locator' pattern like most other templating systems do.
-
Compiles to PHP class for super-duper performance.
-
Uses real Dependency injection in templates, to allow unit testing of views.
-
Super lightweight. Zero overhead when templates are already compiled when used with APC/OPCache
-
Simple but powerful plugin system.
Documentation
Please run this to view the documentation:
git clone https://github.com/danack/TierJigDocs
cd TierJigDocs/
composer install
mkdir -p var/cache
php -S localhost:8000 -t public
The "I know what I'm doing" just show me some code" guide to using Jig
use Auryn\Injector;
use Jig\JigConfig;
use Jig\Jig;
// Create a JigConfig object
$jigConfig = new JigConfig(
//The directory the source templates are in
__DIR__."/../templates/",
//The directory the generated PHP code will be written to.
__DIR__."/../var/generatedTemplates/",
// How to check if the templates need compiling.
Jig::COMPILE_CHECK_MTIME,
// The extension our templates will have.
"php.tpl"
);
// Create a Jig renderer with our config
$jig = new Jig($jigConfig);
// Check the template is compiled to PHP and get the classname of the
// generated PHP template.
$className = $jig->compile("gettingStarted/basic");
// Create a DIC that can create an instance of the template
$injector = new Injector();
$injector->alias('Jig\Escaper', 'Jig\Bridge\ZendEscaperBridge');
// Create an instance of the template
$templateInstance = $injector->make($className);
// Render the template and send it to the user.
$output = $templateInstance->render();
// Send the output to the user
echo $output;
// Alternatively if your DIC supports direct execution
//$output = $injector->execute([$className, 'render']);