2014-07-28 19:00:50 +02:00
|
|
|
<?php
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
// {{{ICINGA_LICENSE_HEADER}}}
|
|
|
|
|
|
|
|
namespace Icinga\Module\Doc;
|
|
|
|
|
|
|
|
use Icinga\Data\Identifiable;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* A section of a documentation
|
|
|
|
*/
|
|
|
|
class Section implements Identifiable
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* The ID of the section
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $id;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The title of the section
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
|
|
|
protected $title;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* The header level
|
|
|
|
*
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
protected $level;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether to instruct search engines to not index the link to the section
|
|
|
|
*
|
|
|
|
* @var bool
|
|
|
|
*/
|
|
|
|
protected $nofollow;
|
|
|
|
|
|
|
|
/**
|
2014-08-19 09:45:53 +02:00
|
|
|
* The ID of the chapter the section is part of
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2014-08-19 09:45:53 +02:00
|
|
|
protected $chapterId;
|
2014-07-28 19:00:50 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* The content of the section
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $content = array();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create a new section
|
|
|
|
*
|
|
|
|
* @param string $id The ID of the section
|
|
|
|
* @param string $title The title of the section
|
|
|
|
* @param int $level The header level
|
|
|
|
* @param bool $nofollow Whether to instruct search engines to not index the link to the section
|
2014-08-19 09:45:53 +02:00
|
|
|
* @param string $chapterId The ID of the chapter the section is part of
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
2014-08-19 09:45:53 +02:00
|
|
|
public function __construct($id, $title, $level, $nofollow, $chapterId)
|
2014-07-28 19:00:50 +02:00
|
|
|
{
|
|
|
|
$this->id = $id;
|
|
|
|
$this->title = $title;
|
|
|
|
$this->level = $level;
|
|
|
|
$this->nofollow = $nofollow;
|
2014-08-19 09:45:53 +02:00
|
|
|
$this->chapterId= $chapterId;
|
2014-07-28 19:00:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the ID of the section
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getId()
|
|
|
|
{
|
|
|
|
return $this->id;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the title of the section
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getTitle()
|
|
|
|
{
|
|
|
|
return $this->title;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the header level
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getLevel()
|
|
|
|
{
|
|
|
|
return $this->level;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether to instruct search engines to not index the link to the section
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function isNofollow()
|
|
|
|
{
|
|
|
|
return $this->nofollow;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2014-08-19 09:45:53 +02:00
|
|
|
* The ID of the chapter the section is part of
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2014-08-19 09:45:53 +02:00
|
|
|
public function getChapterId()
|
2014-07-28 19:00:50 +02:00
|
|
|
{
|
2014-08-19 09:45:53 +02:00
|
|
|
return $this->chapterId;
|
2014-07-28 19:00:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Append content
|
|
|
|
*
|
|
|
|
* @param string $content
|
|
|
|
*/
|
|
|
|
public function appendContent($content)
|
|
|
|
{
|
|
|
|
$this->content[] = $content;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the content of the section
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getContent()
|
|
|
|
{
|
|
|
|
return $this->content;
|
|
|
|
}
|
|
|
|
}
|