drarok/kotal

There is no license information available for the latest version (dev-develop) of this package.

PHPTAL Templates for Kohana

Maintainers

Details

github.com/Drarok/KOtal

Source

Installs: 20

Dependents: 1

Suggesters: 0

Security: 0

Stars: 1

Watchers: 2

Forks: 2

Type:kohana-module

dev-develop 2013-11-08 00:40 UTC

This package is auto-updated.

Last update: 2024-12-29 04:53:22 UTC


README

KOtal is a module for Kohana 3.3 that implements PHPTAL as a view processor.

PHPTAL is a PHP implementation of Zope Page Templates (ZPT). To be short, PHPTAL is a XML/XHTML template library for PHP.

Originally created by Hanson Wong, this fork adds:

  • Support for Kohana 3.3.
  • Support for installation via Composer.
  • Default to xhtml file extension.

Installation via Composer

composer.json:

	{
	    "require": {
	        "drarok/kotal": "dev-develop"
	    }
	}

bootstrap.php:

	Kohana::modules(array(
		'kotal' => MODPATH . 'kotal',
	));

Usage

Create views in the normal application/views directory, but with an xhtml extension, and adhere to TAL syntax and rules.

KOtal also routes i18n requests into native Kohana methods.

There are a few 'advanced' options, and they are shown in the examples below.

Example

Firstly, create a new view file called taltest.xhtml and place it under views/.

<?xml version="1.0"?>
<tal:block
	xmlns="http://www.w3.org/1999/xhtml"
	xmlns:tal="http://xml.zope.org/namespaces/tal"
	xmlns:metal="http://xml.zope.org/namespaces/metal"
	xmlns:i18n="http://xml.zope.org/namespaces/i18n"
	xmlns:phptal="http://phptal.org/ns/phptal"
>
	<h1 tal:content="title">Sample Title - Not Output</h1>
	<p tal:repeat="person people" tal:content="person">Example Name - Not Output</p>
</tal:block>

Then in your controller, add the following code to generate and display your view.

$view = View::factory('taltest');
$people = array(
	'Alan',
	'Bob',
	'Jane',
	'Maria'
);
$view->title = 'People';
$view->people = $people;

$this->response->body($view);

Accessing this action, you should see:

People

Alan
Bob
Jane
Maria

Now say we didn't want to store TAL views with an 'xhtml' extension. We would like to use 'html' instead. Simply change the extension on your views and change the option in config/kotal.php.

'ext' => 'html',

This is a global setting and will affect all views that are generated through KOtal.

Next, we would like to change how KOtal outputs out documents. Easy. There are two relevant methods.

$view->set_output_mode(PHPTAL::XHTML)
     ->set_encoding('utf-8');

These are the default settings, see the PHPTAL documentation for available options.

Say if you were in the middle of changing to TAL, and some views had yet been converted. No worries, we can just disable TAL processing on a per-view basis.

$view->use_tal(FALSE);

Lastly, other features that appear in Kohana's default handler should work in KOtal, such as method chaining and setting the view file path just before rendering. Thus, our final example code could be:

$view = View::factory()
	->set_output_mode(PHPTAL::XHTML)
	->set_encoding('utf-8')
	->set(array(
		'people' => array(
			'Alan',
			'Bob',
			'Jane',
			'Maria'
		),
		'title' => 'People'
	))
	->set_filename('taltest');
$this->response->body($view);

Caveats

As KOtal overrides the default Kohana view handler, modules that use "normal" views will fail initially. You can fix this by using the controller exclude list inside config/kotal.php. Simply drop in the controller's name (as defined inside routes).

'exclude' => array(
	'codebench',
	'unittest',
	'userguide',
),

Alternatively, you can globally disable KOtal in config/kotal.php.

'enabled' => FALSE,

Then, as you convert each view, you can switch KOtal on for that one view.

$view->use_tal(TRUE);

Once all of your views have been upgraded to use PHPTAL, you can switch KOtal on globally and remove all the use_tal(TRUE) calls.

Modules that ship with Kohana 3.3 by default will already be covered in the default KOtal configuration.

Other

KOtal is licensed under the New BSD License. Credits to zombor's KOstache for the initial inspiration and naming idea.

PHPTAL is licensed under the terms of the GNU Lesser General Public License.

For more specific documentation on creating TAL views, see the PHPTAL Website.