67 lines
1.4 KiB
PHP
67 lines
1.4 KiB
PHP
<?php
|
|
|
|
namespace Engelsystem;
|
|
|
|
class UserHintsRenderer
|
|
{
|
|
/** @var string[] */
|
|
private $hints = [];
|
|
|
|
private $important = false;
|
|
|
|
/**
|
|
* Render the added hints to a popover for the toolbar.
|
|
*
|
|
* @return string
|
|
*/
|
|
public function render()
|
|
{
|
|
if (count($this->hints) > 0) {
|
|
$hint_class = $this->important ? 'danger' : 'info';
|
|
$glyphicon = $this->important ? 'warning-sign' : 'info-sign';
|
|
|
|
return toolbar_popover($glyphicon . ' text-' . $hint_class, '', $this->hints, 'bg-' . $hint_class);
|
|
}
|
|
|
|
return '';
|
|
}
|
|
|
|
/**
|
|
* Add a hint to the list, if its not null and a not empty string.
|
|
*
|
|
* @param string $hint The hint
|
|
* @param boolean $important Is the hint important?
|
|
*/
|
|
public function addHint($hint, $important = false)
|
|
{
|
|
if ($hint != null && $hint != '') {
|
|
if ($important) {
|
|
$this->important = true;
|
|
$this->hints[] = error($hint, true);
|
|
} else {
|
|
$this->hints[] = info($hint, true);
|
|
}
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Get all hints.
|
|
*
|
|
* @return string[]
|
|
*/
|
|
public function getHints()
|
|
{
|
|
return $this->hints;
|
|
}
|
|
|
|
/**
|
|
* Are there important hints? This leads to a more intensive icon.
|
|
*
|
|
* @return bool
|
|
*/
|
|
public function isImportant()
|
|
{
|
|
return $this->important;
|
|
}
|
|
}
|