TYPO3 API  SVNRelease
PaginateViewHelper.php
Go to the documentation of this file.
00001 <?php
00002 
00003 /*                                                                        *
00004  * This script belongs to the FLOW3 package "Fluid".                      *
00005  *                                                                        *
00006  * It is free software; you can redistribute it and/or modify it under    *
00007  * the terms of the GNU Lesser General Public License as published by the *
00008  * Free Software Foundation, either version 3 of the License, or (at your *
00009  * option) any later version.                                             *
00010  *                                                                        *
00011  * This script is distributed in the hope that it will be useful, but     *
00012  * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHAN-    *
00013  * TABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser       *
00014  * General Public License for more details.                               *
00015  *                                                                        *
00016  * You should have received a copy of the GNU Lesser General Public       *
00017  * License along with the script.                                         *
00018  * If not, see http://www.gnu.org/licenses/lgpl.html                      *
00019  *                                                                        *
00020  * The TYPO3 project - inspiring people to share!                         *
00021  *                                                                        */
00022 
00023 /**
00024  * This ViewHelper renders a Pagination of objects.
00025  *
00026  * = Examples =
00027  *
00028  * <code title="required arguments">
00029  * <f:widget.paginate objects="{blogs}" as="paginatedBlogs">
00030  *   // use {paginatedBlogs} as you used {blogs} before, most certainly inside
00031  *   // a <f:for> loop.
00032  * </f:widget.paginate>
00033  * </code>
00034  *
00035  * <code title="full configuration">
00036  * <f:widget.paginate objects="{blogs}" as="paginatedBlogs" configuration="{itemsPerPage: 5, insertAbove: 1, insertBelow: 0}">
00037  *   // use {paginatedBlogs} as you used {blogs} before, most certainly inside
00038  *   // a <f:for> loop.
00039  * </f:widget.paginate>
00040  * </code>
00041  *
00042  * = Performance characteristics =
00043  *
00044  * In the above examples, it looks like {blogs} contains all Blog objects, thus
00045  * you might wonder if all objects were fetched from the database.
00046  * However, the blogs are NOT fetched from the database until you actually use them,
00047  * so the paginate ViewHelper will adjust the query sent to the database and receive
00048  * only the small subset of objects.
00049  * So, there is no negative performance overhead in using the Paginate Widget.
00050  *
00051  * @license http://www.gnu.org/licenses/lgpl.html GNU Lesser General Public License, version 3 or later
00052  * @api
00053  */
00054 class Tx_Fluid_ViewHelpers_Widget_PaginateViewHelper extends Tx_Fluid_Core_Widget_AbstractWidgetViewHelper {
00055 
00056     /**
00057      * @var Tx_Fluid_ViewHelpers_Widget_Controller_PaginateController
00058      */
00059     protected $controller;
00060 
00061     /**
00062      * @param Tx_Fluid_ViewHelpers_Widget_Controller_PaginateController $controller
00063      * @return void
00064      */
00065     public function injectController(Tx_Fluid_ViewHelpers_Widget_Controller_PaginateController $controller) {
00066         $this->controller = $controller;
00067     }
00068 
00069     /**
00070      *
00071      * @param Tx_Extbase_Persistence_QueryResultInterface $objects
00072      * @param string $as
00073      * @param array $configuration
00074      * @return string
00075      */
00076     public function render(Tx_Extbase_Persistence_QueryResultInterface $objects, $as, array $configuration = array('itemsPerPage' => 10, 'insertAbove' => FALSE, 'insertBelow' => TRUE)) {
00077         return $this->initiateSubRequest();
00078     }
00079 }
00080 
00081 ?>