2014-07-28 19:00:50 +02:00
|
|
|
<?php
|
2015-02-04 10:46:36 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
2014-07-28 19:00:50 +02:00
|
|
|
|
|
|
|
namespace Icinga\Module\Doc;
|
|
|
|
|
2015-02-06 17:29:04 +01:00
|
|
|
use Icinga\Data\Tree\TreeNode;
|
2014-07-28 19:00:50 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* A section of a documentation
|
|
|
|
*/
|
2015-02-06 17:29:04 +01:00
|
|
|
class DocSection extends TreeNode
|
2014-07-28 19:00:50 +02:00
|
|
|
{
|
|
|
|
/**
|
2015-02-10 17:03:58 +01:00
|
|
|
* Chapter the section belongs to
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
2015-03-12 13:39:17 +01:00
|
|
|
* @var DocSection
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
2015-02-10 17:03:58 +01:00
|
|
|
protected $chapter;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Content of the section
|
|
|
|
*
|
2015-03-12 13:39:17 +01:00
|
|
|
* @var array
|
2015-02-10 17:03:58 +01:00
|
|
|
*/
|
|
|
|
protected $content = array();
|
2014-07-28 19:00:50 +02:00
|
|
|
|
|
|
|
/**
|
2015-02-10 17:03:58 +01:00
|
|
|
* Header level
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
2015-03-12 13:39:17 +01:00
|
|
|
* @var int
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
|
|
|
protected $level;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether to instruct search engines to not index the link to the section
|
|
|
|
*
|
2015-03-12 13:39:17 +01:00
|
|
|
* @var bool
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
2014-08-19 09:57:22 +02:00
|
|
|
protected $noFollow;
|
2014-07-28 19:00:50 +02:00
|
|
|
|
|
|
|
/**
|
2015-02-10 17:03:58 +01:00
|
|
|
* Title of the section
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
2015-03-12 13:39:17 +01:00
|
|
|
* @var string
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
2015-02-10 17:03:58 +01:00
|
|
|
protected $title;
|
2014-07-28 19:00:50 +02:00
|
|
|
|
|
|
|
/**
|
2015-02-10 17:03:58 +01:00
|
|
|
* Set the chapter the section belongs to
|
2015-02-06 17:29:04 +01:00
|
|
|
*
|
2015-02-10 17:03:58 +01:00
|
|
|
* @param DocSection $section
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
2015-02-06 17:29:04 +01:00
|
|
|
* @return $this
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
2015-02-10 17:03:58 +01:00
|
|
|
public function setChapter(DocSection $section)
|
2014-07-28 19:00:50 +02:00
|
|
|
{
|
2015-02-10 17:03:58 +01:00
|
|
|
$this->chapter = $section;
|
2015-02-06 17:29:04 +01:00
|
|
|
return $this;
|
2014-07-28 19:00:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-02-10 17:03:58 +01:00
|
|
|
* Get the chapter the section belongs to
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
2015-02-10 17:03:58 +01:00
|
|
|
* @return DocSection
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
2015-02-10 17:03:58 +01:00
|
|
|
public function getChapter()
|
2014-07-28 19:00:50 +02:00
|
|
|
{
|
2015-02-10 17:03:58 +01:00
|
|
|
return $this->chapter;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* 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;
|
2014-07-28 19:00:50 +02:00
|
|
|
}
|
|
|
|
|
2015-08-10 13:22:16 +02:00
|
|
|
/**
|
|
|
|
* {@inheritdoc}
|
|
|
|
*/
|
|
|
|
public function setId($id)
|
|
|
|
{
|
|
|
|
return parent::setId(str_replace(' ', '-', (string) $id));
|
|
|
|
}
|
|
|
|
|
2014-07-28 19:00:50 +02:00
|
|
|
/**
|
2015-02-06 17:29:04 +01:00
|
|
|
* Set the header level
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
2015-02-06 17:29:04 +01:00
|
|
|
* @param int $level Header level
|
|
|
|
*
|
|
|
|
* @return $this
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
2015-02-06 17:29:04 +01:00
|
|
|
public function setLevel($level)
|
2014-07-28 19:00:50 +02:00
|
|
|
{
|
2015-02-06 17:29:04 +01:00
|
|
|
$this->level = (int) $level;
|
|
|
|
return $this;
|
2014-07-28 19:00:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the header level
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getLevel()
|
|
|
|
{
|
|
|
|
return $this->level;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-02-06 17:29:04 +01:00
|
|
|
* Set whether to instruct search engines to not index the link to the section
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
2015-02-06 17:29:04 +01:00
|
|
|
* @param bool $noFollow Whether to instruct search engines to not index the link to the section
|
|
|
|
*
|
|
|
|
* @return $this
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
2015-02-06 17:29:04 +01:00
|
|
|
public function setNoFollow($noFollow = true)
|
2014-07-28 19:00:50 +02:00
|
|
|
{
|
2015-02-06 17:29:04 +01:00
|
|
|
$this->noFollow = (bool) $noFollow;
|
|
|
|
return $this;
|
2014-07-28 19:00:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-02-06 17:29:04 +01:00
|
|
|
* Get whether to instruct search engines to not index the link to the section
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
2015-02-06 17:29:04 +01:00
|
|
|
* @return bool
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
2015-02-06 17:29:04 +01:00
|
|
|
public function getNoFollow()
|
2014-07-28 19:00:50 +02:00
|
|
|
{
|
2015-02-06 17:29:04 +01:00
|
|
|
return $this->noFollow;
|
2014-07-28 19:00:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-02-10 17:03:58 +01:00
|
|
|
* Set the title of the section
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
2015-02-10 17:03:58 +01:00
|
|
|
* @param string $title Title of the section
|
|
|
|
*
|
|
|
|
* @return $this
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
2015-02-10 17:03:58 +01:00
|
|
|
public function setTitle($title)
|
2014-07-28 19:00:50 +02:00
|
|
|
{
|
2015-02-10 17:03:58 +01:00
|
|
|
$this->title = (string) $title;
|
|
|
|
return $this;
|
2014-07-28 19:00:50 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-02-10 17:03:58 +01:00
|
|
|
* Get the title of the section
|
2014-07-28 19:00:50 +02:00
|
|
|
*
|
2015-02-10 17:03:58 +01:00
|
|
|
* @return string
|
2014-07-28 19:00:50 +02:00
|
|
|
*/
|
2015-02-10 17:03:58 +01:00
|
|
|
public function getTitle()
|
2014-07-28 19:00:50 +02:00
|
|
|
{
|
2015-02-10 17:03:58 +01:00
|
|
|
return $this->title;
|
2014-07-28 19:00:50 +02:00
|
|
|
}
|
|
|
|
}
|