DynamicPageList3/includes/heading/TieredHeading.php
2021-02-22 16:48:01 -07:00

118 lines
2.3 KiB
PHP

<?php
/**
* DynamicPageList3
* DPL TieredHeading Class
*
* @license GPL-2.0-or-later
* @package DynamicPageList3
*
*/
namespace DPL\Heading;
use DPL\Lister\Lister;
use DPL\Parameters;
class TieredHeading extends Heading {
/**
* List(Section) Start
*
* @var string
*/
public $listStart = '<div%s>';
/**
* List(Section) End
*
* @var string
*/
public $listEnd = '</div>';
/**
* Item Start
*
* @var string
*/
public $itemStart = '<h%2$s%1$s>';
/**
* Item End
*
* @var string
*/
public $itemEnd = '</h%2$s>';
/**
* Tier Level
*
* @var string
*/
private $tierLevel = 'eader';
/**
* Main Constructor
*
* @access public
* @param object \DPL\Parameters
* @return void
*/
public function __construct( Parameters $parameters ) {
parent::__construct( $parameters );
$this->tierLevel = substr( $parameters->getParameter( 'headingmode' ), 1 );
}
/**
* Format a heading group.
*
* @access public
* @param integer Article start index for this heading.
* @param integer Article count for this heading.
* @param string Heading link/text display.
* @param array List of \DPL\Article.
* @param object List of \DPL\Lister\Lister
* @return string Heading HTML
*/
public function formatItem( $headingStart, $headingCount, $headingLink, $articles, Lister $lister ) {
$item = '';
$item .= $this->getItemStart() . $headingLink;
if ( $this->showHeadingCount ) {
$item .= $this->articleCountMessage( $headingCount );
}
$item .= $this->getItemEnd();
$item .= $lister->formatList( $articles, $headingStart, $headingCount );
return $item;
}
/**
* Return $this->listStart with attributes replaced.
*
* @access public
* @return string List Start
*/
public function getListStart() {
return sprintf( $this->listStart, $this->listAttributes );
}
/**
* Return $this->itemStart with attributes replaced.
*
* @access public
* @return string Item Start
*/
public function getItemStart() {
return sprintf( $this->itemStart, $this->itemAttributes, $this->tierLevel );
}
/**
* Return $this->itemEnd with attributes replaced.
*
* @access public
* @return string Item End
*/
public function getItemEnd() {
return sprintf( $this->itemEnd, $this->itemAttributes, $this->tierLevel );
}
}