Share » Learn » eZ Publish » An Introduction to Developing eZ...

An Introduction to Developing eZ Publish Extensions

Friday 10 December 2010 1:24:31 am

  • Currently 5 out of 5 Stars.
  • 1
  • 2
  • 3
  • 4
  • 5

View list

Module views are defined in the file module.php. A module view makes it possible to access a PHP file. In our example we define the name of the view list with $ViewList['list'] and forward to the custom PHP script list.php.

We also want to send some parameters to the view. For example, we define two parameters (ParamOne and ParamTwo) with the statement:

'params' => array('ParamOne','ParamTwo')

... in the script module.php.

<?php
 
// Introduction in the development of eZ Publish extensions
 
$Module = array( 'name' => 'Example Modul1' ); 
$ViewList = array();
 
// new View list with 2 fixed parameters and 
// 2 parameters in order 
// http://.../modul1/list/ $Params['ParamOne'] /
// $Params['ParamTwo']/ param4/$Params['4Param'] /param3/$Params['3Param'] 
 
 
$ViewList['list'] = array( 'script' => 'list.php', 
                           'functions' => array( 'read' ), 
                           'params' => array('ParamOne', 'ParamTwo'),
                           'unordered_params' => array('param3' => '3Param',
                                                       'param4' => '4Param') );
 
// The entries in the user rights 
// are used in the View definition, to assign rights to own View functions 
// in the user roles
 
$FunctionList = array(); 
$FunctionList['read'] = array(); 
 
?>

Listing 2. View configuration file: extension/jacextension/modules/modul1/module.php

The resulting URL is:

http://localhost/ez/index.php/plain_site/modul1/list/<ValueParamOne>/<ValueParamTwo>

Later we can access the variables in list.php with the following commands:

$valueParamOne = $Params['ParamOne']; 
$valueParamTwo = $Params['ParamTwo'];

This representation of parameter access is called ordered parameters.

Unordered parameters adjust to the ordered parameters and consist of name-value pairs. For example:

http://localhost/ez/index.php/plain_site/modul1/list/ValueParamOne/ValueParamTwo/(param3)/ValueParam3/(param4)/ValueParam4

The definition is similar to the ordered parameters in module.php with:

'unordered_params' => array('param3' => '3Param', 'param4' => '4Param' )

Here we specified that param4 in URL matches 4param parameter in the PHP view.

For example, if the View command has the value .../param4/141, then eZ Publish recognises that the parameter param4 has been specified and we can read value 141 from the parameter array of the module with the statement:

$Params['4Param']

Unordered parameters can change their order. If no unordered parameter is set, then eZ Publish sets the value to false. Ordered parameters must be defined; otherwise they are assigned a NULL (zero) value.

The URL http://localhost/ez/index.php/plain_site/modul1/list/table/5/(param4)/141/(param3)/131
specifies the parameter view as follows:

$Params['ParamOne'] = 'table'; 
$Params['ParamTwo'] = '5'; 
$Params['3Param'] = '131'; 
$Params['4Param'] = '141';

For more information, refer to the eZ Publish documentation at

http://doc.ez.no/eZ-Publish/Technical-manual/4.x/Concepts-and-basics/Modules-and-views.

The general convention is to create a PHP file with a file name corresponding to the view name in the URL. This allows you to recognise from the URL which PHP file is being loaded. For example:

http://localhost/ez/index.php/plain_site/content/view/full/2

...is forwarding the view.php in the kernel module "content" (<ezroot>/kernel/content/view.php).

Hint: The kernel modules of eZ Publish are a valuable source of information and examples for programmers new to eZ Publish. The structure of kernel modules is the same as for an extension, for example our modul1 example above.

To visualize the call of the view list on the screen, we add the "echo" command in list.php, which interprets the parameters on the screen. The listing below shows our code for list.php:

<?php
 
// take current object of type eZModule 
$Module = $Params['Module'];
 
// read parameter Ordered View 
// http://.../modul1/list/ $Params['ParamOne'] / $Params['ParamTwo'] 
// for example .../modul1/list/view/5
$valueParamOne = $Params['ParamOne']; 
$valueParamTwo = $Params['ParamTwo'];
 
// read parameter UnOrdered View 
// http://.../modul1/list/(param4)/$Params['4Param']/(param3)/$Params['3Param'] 
// for example.../modul1/list/.../.../(param4)/141/(param3)/131
$valueParam3 = $Params['3Param']; 
$valueParam4 = $Params['4Param'];
 
// show values of the View parameter
echo 'Example: modul1/list/'.
        $valueParamOne .'/ '.
        $valueParamTwo .'/(param4)/'.
        $valueParam4 .'/(param3)/'.
        $valueParam3;
 
?>

Listing 3. Function file of view list: extension/jacextension/modules/modul1/list.php

36 542 Users on board!

Tutorial menu

Printable

Printer Friendly version of the full article on one page with plain styles

Author(s)