|
TYPO3 API
SVNRelease
|
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 ?>
1.8.0