dashboard: Use the non-translated versions of pane and dashlet names for storage
This is a dirty quick fix. And calling it *quick* is already an overstatement. Of course, it's also a breaking change, as **all** non-english users need to update their dashboard.ini after this change. Oh, and don't dare to move this over to the new dashboards! refs #3542
This commit is contained in:
parent
4fdfb190ad
commit
fcde2a9eea
|
@ -5,6 +5,9 @@ namespace Icinga\Legacy;
|
||||||
|
|
||||||
use Icinga\Application\Config;
|
use Icinga\Application\Config;
|
||||||
use Icinga\User;
|
use Icinga\User;
|
||||||
|
use Icinga\Web\Navigation\DashboardPane;
|
||||||
|
use Icinga\Web\Navigation\Navigation;
|
||||||
|
use Icinga\Web\Navigation\NavigationItem;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Legacy dashboard config class for case insensitive interpretation of dashboard config files
|
* Legacy dashboard config class for case insensitive interpretation of dashboard config files
|
||||||
|
@ -76,6 +79,51 @@ class DashboardConfig extends Config
|
||||||
*/
|
*/
|
||||||
public function saveIni($filePath = null, $fileMode = 0660)
|
public function saveIni($filePath = null, $fileMode = 0660)
|
||||||
{
|
{
|
||||||
|
// Preprocessing start, ensures that the non-translated names are used to save module dashboard changes
|
||||||
|
// TODO: This MUST NOT survive the new dashboard implementation (yes, it's still a thing..)
|
||||||
|
$dashboardNavigation = new Navigation();
|
||||||
|
$dashboardNavigation->load('dashboard-pane');
|
||||||
|
$getDashboardPane = function ($label) use ($dashboardNavigation) {
|
||||||
|
foreach ($dashboardNavigation as $dashboardPane) {
|
||||||
|
/** @var DashboardPane $dashboardPane */
|
||||||
|
if ($dashboardPane->getLabel() === $label) {
|
||||||
|
return $dashboardPane;
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($dashboardPane->getChildren() as $dashlet) {
|
||||||
|
/** @var NavigationItem $dashlet */
|
||||||
|
if ($dashlet->getLabel() === $label) {
|
||||||
|
return $dashlet;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
foreach (clone $this->config as $name => $options) {
|
||||||
|
if (strpos($name, '.') !== false) {
|
||||||
|
list($dashboardLabel, $dashletLabel) = explode('.', $name, 2);
|
||||||
|
} else {
|
||||||
|
$dashboardLabel = $name;
|
||||||
|
$dashletLabel = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
$dashboardPane = $getDashboardPane($dashboardLabel);
|
||||||
|
if ($dashboardPane !== null) {
|
||||||
|
$dashboardLabel = $dashboardPane->getName();
|
||||||
|
}
|
||||||
|
|
||||||
|
if ($dashletLabel !== null) {
|
||||||
|
$dashletItem = $getDashboardPane($dashletLabel);
|
||||||
|
if ($dashletItem !== null) {
|
||||||
|
$dashletLabel = $dashletItem->getName();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
unset($this->config[$name]);
|
||||||
|
$this->config[$dashboardLabel . ($dashletLabel ? '.' . $dashletLabel : '')] = $options;
|
||||||
|
}
|
||||||
|
// Preprocessing end
|
||||||
|
|
||||||
parent::saveIni($filePath, $fileMode);
|
parent::saveIni($filePath, $fileMode);
|
||||||
if ($filePath === null) {
|
if ($filePath === null) {
|
||||||
$filePath = $this->configFile;
|
$filePath = $this->configFile;
|
||||||
|
|
|
@ -85,7 +85,7 @@ class Dashboard extends AbstractWidget
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->mergePanes($panes);
|
$this->mergePanes($panes);
|
||||||
$this->loadUserDashboards();
|
$this->loadUserDashboards($navigation);
|
||||||
return $this;
|
return $this;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -114,10 +114,10 @@ class Dashboard extends AbstractWidget
|
||||||
/**
|
/**
|
||||||
* Load user dashboards from all config files that match the username
|
* Load user dashboards from all config files that match the username
|
||||||
*/
|
*/
|
||||||
protected function loadUserDashboards()
|
protected function loadUserDashboards(Navigation $navigation)
|
||||||
{
|
{
|
||||||
foreach (DashboardConfig::listConfigFilesForUser($this->user) as $file) {
|
foreach (DashboardConfig::listConfigFilesForUser($this->user) as $file) {
|
||||||
$this->loadUserDashboardsFromFile($file);
|
$this->loadUserDashboardsFromFile($file, $navigation);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -128,7 +128,7 @@ class Dashboard extends AbstractWidget
|
||||||
*
|
*
|
||||||
* @return bool
|
* @return bool
|
||||||
*/
|
*/
|
||||||
protected function loadUserDashboardsFromFile($file)
|
protected function loadUserDashboardsFromFile($file, Navigation $dashboardNavigation)
|
||||||
{
|
{
|
||||||
try {
|
try {
|
||||||
$config = Config::fromIni($file);
|
$config = Config::fromIni($file);
|
||||||
|
@ -143,8 +143,12 @@ class Dashboard extends AbstractWidget
|
||||||
$dashlets = array();
|
$dashlets = array();
|
||||||
foreach ($config as $key => $part) {
|
foreach ($config as $key => $part) {
|
||||||
if (strpos($key, '.') === false) {
|
if (strpos($key, '.') === false) {
|
||||||
if ($this->hasPane($part->title)) {
|
$dashboardPane = $dashboardNavigation->getItem($key);
|
||||||
$panes[$key] = $this->getPane($part->title);
|
if ($dashboardPane !== null) {
|
||||||
|
$key = $dashboardPane->getLabel();
|
||||||
|
}
|
||||||
|
if ($this->hasPane($key)) {
|
||||||
|
$panes[$key] = $this->getPane($key);
|
||||||
} else {
|
} else {
|
||||||
$panes[$key] = new Pane($key);
|
$panes[$key] = new Pane($key);
|
||||||
$panes[$key]->setTitle($part->title);
|
$panes[$key]->setTitle($part->title);
|
||||||
|
@ -155,6 +159,14 @@ class Dashboard extends AbstractWidget
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
list($paneName, $dashletName) = explode('.', $key, 2);
|
list($paneName, $dashletName) = explode('.', $key, 2);
|
||||||
|
$dashboardPane = $dashboardNavigation->getItem($paneName);
|
||||||
|
if ($dashboardPane !== null) {
|
||||||
|
$paneName = $dashboardPane->getLabel();
|
||||||
|
$dashletItem = $dashboardPane->getChildren()->getItem($dashletName);
|
||||||
|
if ($dashletItem !== null) {
|
||||||
|
$dashletName = $dashletItem->getLabel();
|
||||||
|
}
|
||||||
|
}
|
||||||
$part->pane = $paneName;
|
$part->pane = $paneName;
|
||||||
$part->dashlet = $dashletName;
|
$part->dashlet = $dashletName;
|
||||||
$dashlets[] = $part;
|
$dashlets[] = $part;
|
||||||
|
|
Loading…
Reference in New Issue