Fix some strange behavior

This commit is contained in:
acognet
2023-08-10 12:24:01 +02:00
parent b852e72088
commit 49cf6f5fe2
9 changed files with 45 additions and 29 deletions

View File

@@ -48,7 +48,7 @@ class DataTable extends UIContentBlock
protected $aAjaxData;
protected $aDisplayColumns;
protected $aResultColumns;
protected $sFilter;
protected $sBasketFilter;
/**
* @var string
*/
@@ -225,17 +225,17 @@ class DataTable extends UIContentBlock
/**
* @return string
*/
public function GetFilter()
public function GetBasketFilter()
{
return $this->sFilter;
return $this->sBasketFilter;
}
/**
* @param string $sFilter
*/
public function setFilter($sFilter): void
public function setBasketFilter($sFilter): void
{
$this->sFilter = $sFilter;
$this->sBasketFilter = $sFilter;
}
/**

View File

@@ -596,7 +596,7 @@ class DataTableUIBlockFactory extends AbstractUIBlockFactory
$oDataTable->SetDisplayColumns($aColumnDefinition);
$oDataTable->SetResultColumns($oCustomSettings->aColumns);
$oFilter->SetSelectedClasses([$sBasketAliasClass]);
$oDataTable->SetFilter($oFilter->ToOQL(true));
$oDataTable->SetBasketFilter($oFilter->ToOQL(true));
$oDataTable->SetInitDisplayData(AjaxRenderController::GetDataForTable($oSet, $aClassAliases, $aColumnsToLoad, $sIdName, $aExtraParams, 1, $sLinkToBasket));
// row actions

View File

@@ -50,9 +50,9 @@ class Navigation extends UIContentBlock
protected $iIdNext = 0;
protected $iIdLast = 0;
protected $aList = [];
protected $sFilter;
protected $sBasketFilter;
protected $sBackUrl;
protected $sClass;
protected $sBasketClass;
protected $sPostedFields;
/**
@@ -63,16 +63,16 @@ class Navigation extends UIContentBlock
* @param string $sColorScheme Color scheme code such as "success", "failure", "active", ... {@see css/backoffice/components/_panel.scss}
* @param string|null $sId
*/
public function __construct(string $sClass, int $iIdx, array $aList, string $sFilter, string $sBackUrl, string $sPostedFieldsForBackUrl = "", ?string $sId = null)
public function __construct(string $sBasketClass, int $iIdx, array $aList, string $sBasketFilter, string $sBackUrl, string $sPostedFieldsForBackUrl = "", ?string $sId = null)
{
parent::__construct($sId);
$this->iCount = count($aList);
if ($this->iCount == 0) {
return new UIContentBlock();
}
$this->sClass = $sClass;
$this->sBasketClass = $sBasketClass;
$this->aList = $aList;
$this->sFilter = $sFilter;
$this->sBasketFilter = $sBasketFilter;
$this->sBackUrl = $sBackUrl;
$this->iIdx = $iIdx;
if ($this->iIdx>0) {
@@ -112,7 +112,7 @@ class Navigation extends UIContentBlock
private function GetUrlFromId($iId)
{
$sUrl = iTopStandardURLMaker::MakeObjectURL($this->sClass, $iId);
$sUrl = iTopStandardURLMaker::MakeObjectURL($this->sBasketClass, $iId);
return $sUrl;
}
@@ -159,9 +159,9 @@ class Navigation extends UIContentBlock
/**
* @return string
*/
public function GetFilter(): string
public function GetBasketFilter(): string
{
return $this->sFilter;
return $this->sBasketFilter;
}
/**

View File

@@ -22,6 +22,7 @@ namespace Combodo\iTop\Application\UI\Base\Component\Navigation;
use Combodo\iTop\Application\UI\Base\AbstractUIBlockFactory;
use DBObjectSearch;
use DBObjectSet;
use utils;
/**
* Class PanelUIBlockFactory
@@ -48,19 +49,26 @@ class NavigationUIBlockFactory extends AbstractUIBlockFactory
*
* @return \Combodo\iTop\Application\UI\Base\Component\Panel\Panel
*/
public static function MakeStandard($oObject, string $sFilter, array $aList = [], string $sBackUrl = '', $sPostedFieldsForBackUrl = "")
public static function MakeStandard($oObject, string $sBasketFilter, string $sBasketClass, array $aList = [], string $sBackUrl = '', $sPostedFieldsForBackUrl = "")
{
if ($sFilter != null && count($aList) === 0) {
$oFilter = DBObjectSearch::FromOQL($sFilter);
$oSet = new DBObjectSet($oFilter);
if (utils::IsNotNullOrEmptyString($sBasketFilter) && count($aList) === 0) {
$oBasketFilter = DBObjectSearch::FromOQL($sBasketFilter);
$oSet = new DBObjectSet($oBasketFilter);
$aList = $oSet->GetColumnAsArray('id', false);
if (utils::IsNullOrEmptyString($sBasketClass)) {
$sBasketClass = $oBasketFilter->GetClass();
}
}
if (utils::IsNullOrEmptyString($sBasketClass)) {
$oBasketFilter = DBObjectSearch::FromOQL($sBasketFilter);
$sBasketClass = $oBasketFilter->GetClass();
}
if (count($aList) === 0) {
return null;
}
$iIdx = array_search($oObject->GetKey(), $aList);
$oNavigationBlock = new Navigation(get_class($oObject), $iIdx, $aList, $sFilter, $sBackUrl, $sPostedFieldsForBackUrl);
$oNavigationBlock = new Navigation($sBasketClass, $iIdx, $aList, $sBasketFilter, $sBackUrl, $sPostedFieldsForBackUrl);
return $oNavigationBlock;
}

View File

@@ -120,8 +120,6 @@ class BlockIndirectLinkSetViewTable extends AbstractBlockLinkSetViewTable
$sAttributeLinkedSetIndirectAttCode = $oAttributeLinkedSetIndirectDefinition->GetCode();
$sAttributeLinkedSetIndirectLinkedClass = $oAttributeLinkedSetIndirectDefinition->GetTargetClass();
\IssueLog::Error('AttributeLinkedSetIndirectAttCode:'.$sAttributeLinkedSetIndirectAttCode);
\IssueLog::Error('AttributeLinkedSetIndirectLinkedClass:'.$sAttributeLinkedSetIndirectLinkedClass);
$aAttCodesToDisplay = MetaModel::GetAttributeLinkedSetIndirectDatatableAttCodesToDisplay($this->sObjectClass, $this->sAttCode, $sAttributeLinkedSetIndirectLinkedClass, $sAttributeLinkedSetIndirectAttCode);
/** @noinspection PhpUnnecessaryLocalVariableInspection */