server/lib/public/AppFramework/Http/Template/SimpleMenuAction.php
Julius Härtl 038aad73c7
Add missing phpdoc for public API
Signed-off-by: Julius Härtl <jus@bitgrid.net>
2018-02-27 12:25:53 +01:00

174 lines
No EOL
3.4 KiB
PHP

<?php
/**
* @copyright Copyright (c) 2018 Julius Härtl <jus@bitgrid.net>
*
* @author Julius Härtl <jus@bitgrid.net>
*
* @license GNU AGPL version 3 or any later version
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as
* published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*
*/
namespace OCP\AppFramework\Http\Template;
use OCP\Util;
/**
* Class SimpleMenuAction
*
* @package OCP\AppFramework\Http\Template
* @since 14.0.0
*/
class SimpleMenuAction implements IMenuAction {
/** @var string */
private $id;
/** @var string */
private $label;
/** @var string */
private $icon;
/** @var string */
private $link;
/** @var int */
private $priority;
/** @var string */
private $detail;
/**
* SimpleMenuAction constructor.
*
* @param string $id
* @param string $label
* @param string $icon
* @param string $link
* @param int $priority
* @param string $detail
* @since 14.0.0
*/
public function __construct(string $id, string $label, string $icon, string $link = '', int $priority = 100, string $detail = '') {
$this->id = $id;
$this->label = $label;
$this->icon = $icon;
$this->link = $link;
$this->priority = $priority;
$this->detail = $detail;
}
/**
* @param string $id
* @since 14.0.0
*/
public function setId(string $id) {
$this->id = $id;
}
/**
* @param string $label
* @since 14.0.0
*/
public function setLabel(string $label) {
$this->label = $label;
}
/**
* @param string $detail
* @since 14.0.0
*/
public function setDetail(string $detail) {
$this->detail = $detail;
}
/**
* @param string $icon
* @since 14.0.0
*/
public function setIcon(string $icon) {
$this->icon = $icon;
}
/**
* @param string $link
* @since 14.0.0
*/
public function setLink(string $link) {
$this->link = $link;
}
/**
* @param int $priority
* @since 14.0.0
*/
public function setPriority(int $priority) {
$this->priority = $priority;
}
/**
* @return string
* @since 14.0.0
*/
public function getId(): string {
return $this->id;
}
/**
* @return string
* @since 14.0.0
*/
public function getLabel(): string {
return $this->label;
}
/**
* @return string
* @since 14.0.0
*/
public function getIcon(): string {
return $this->icon;
}
/**
* @return string
* @since 14.0.0
*/
public function getLink(): string {
return $this->link;
}
/**
* @return int
* @since 14.0.0
*/
public function getPriority(): int {
return $this->priority;
}
/**
* @return string
* @since 14.0.0
*/
public function render(): string {
$detailContent = ($this->detail !== '') ? '&nbsp;<span class="download-size">(' . Util::sanitizeHTML($this->detail) . ')</span>' : '';
return sprintf(
'<li><a href="%s"><span class="icon %s"></span>%s %s</a></li>',
Util::sanitizeHTML($this->link), Util::sanitizeHTML($this->icon), Util::sanitizeHTML($this->label), Util::sanitizeHTML($detailContent)
);
}
}