From 62e4742a5a183e9bef2c8a8a88a23d5354d02902 Mon Sep 17 00:00:00 2001 From: Andy Weichler <53085804+aweichler@users.noreply.github.com> Date: Fri, 19 Apr 2024 09:56:55 +0200 Subject: [PATCH] fix output channels to work properly with classification stores (#115) --- doc/classificationstore.md | 7 +++-- src/ConfigElement/AbstractConfigElement.php | 26 +++++++++++++++++++ src/ConfigElement/Operator/Concatenator.php | 7 +++++ src/ConfigElement/Operator/Group.php | 6 +++++ src/ConfigElement/Operator/Table.php | 6 +++++ src/ConfigElement/Operator/TableCol.php | 9 ++++++- src/ConfigElement/Operator/TableRow.php | 6 +++++ src/ConfigElement/Operator/TextAddon.php | 9 ++++++- src/ConfigElement/Operator/TranslateValue.php | 10 +++++-- src/ConfigElement/Value/DefaultValue.php | 14 +++------- 10 files changed, 84 insertions(+), 16 deletions(-) diff --git a/doc/classificationstore.md b/doc/classificationstore.md index dbb6d43..4e507b8 100644 --- a/doc/classificationstore.md +++ b/doc/classificationstore.md @@ -16,7 +16,10 @@ different display modes for classification store keys in the output definition c for eq. ```php $outputDataConfig = OutputDataConfigToolkitBundle\Service::getOutputDataConfig($object, 'Output config channel'); - $outputDataConfig[0]->classificationstore = 'Attributes'; ### classificationstore field name in object - $outputDataConfig[0]->classificationstore_group = 'Product'; ### Classificationstore group name + $outputDataConfig[0]->setClassificationstore('Attributes'); ### classificationstore field name in object + $outputDataConfig[0]->setClassificationstoreGroup('Product'); ### Classificationstore group name + # the old way was access the values directly + // $outputDataConfig[0]->classificationstore = 'Attributes'; ### classificationstore field name in object + // $outputDataConfig[0]->classificationstore_group = 'Product'; ### Classificationstore group name $outputDataConfig[0]->getLabeledValue($object); ``` \ No newline at end of file diff --git a/src/ConfigElement/AbstractConfigElement.php b/src/ConfigElement/AbstractConfigElement.php index 6e53a35..d0e94c8 100644 --- a/src/ConfigElement/AbstractConfigElement.php +++ b/src/ConfigElement/AbstractConfigElement.php @@ -22,6 +22,12 @@ abstract class AbstractConfigElement implements IConfigElement protected $context; + /** @var string|null */ + public ?string $classificationstore = null; + + /** @var string|null */ + public ?string $classificationstore_group = null; + public function __construct($config, $context = null) { $this->attribute = $config->attribute ?? null; @@ -35,6 +41,26 @@ public function getLabel() return $this->label; } + public function getClassificationstore(): ?string + { + return $this->classificationstore; + } + + public function getClassificationstoreGroup(): ?string + { + return $this->classificationstore_group; + } + + public function setClassificationstore(?string $classificationstore): void + { + $this->classificationstore = $classificationstore; + } + + public function setClassificationstoreGroup(?string $classificationstore_group): void + { + $this->classificationstore_group = $classificationstore_group; + } + public function getAttribute() { return $this->attribute; diff --git a/src/ConfigElement/Operator/Concatenator.php b/src/ConfigElement/Operator/Concatenator.php index 20eb81e..ced3af1 100644 --- a/src/ConfigElement/Operator/Concatenator.php +++ b/src/ConfigElement/Operator/Concatenator.php @@ -15,6 +15,8 @@ namespace OutputDataConfigToolkitBundle\ConfigElement\Operator; +use OutputDataConfigToolkitBundle\ConfigElement\AbstractConfigElement; + class Concatenator extends AbstractOperator { protected $glue; @@ -44,6 +46,11 @@ public function getLabeledValue($object) $valueArray = []; foreach ($childs as $c) { + if ($c instanceof AbstractConfigElement) { + $c->setClassificationstore($this->getClassificationstore()); + $c->setClassificationstoreGroup($this->getClassificationstoreGroup()); + } + $value = $c->getLabeledValue($object) ? $c->getLabeledValue($object)->value : null; if (!$hasValue) { diff --git a/src/ConfigElement/Operator/Group.php b/src/ConfigElement/Operator/Group.php index 6df1180..6ef1ce5 100644 --- a/src/ConfigElement/Operator/Group.php +++ b/src/ConfigElement/Operator/Group.php @@ -15,6 +15,8 @@ namespace OutputDataConfigToolkitBundle\ConfigElement\Operator; +use OutputDataConfigToolkitBundle\ConfigElement\AbstractConfigElement; + class Group extends AbstractOperator { public function getLabeledValue($object) @@ -23,6 +25,10 @@ public function getLabeledValue($object) $childs = $this->getChilds(); foreach ($childs as $c) { + if ($c instanceof AbstractConfigElement) { + $c->setClassificationstore($this->getClassificationstore()); + $c->setClassificationstoreGroup($this->getClassificationstoreGroup()); + } $value = $c->getLabeledValue($object); if (!empty($value) && !$value->empty && (!method_exists($value, 'isEmpty') || !$value->isEmpty())) { $valueArray[] = $value; diff --git a/src/ConfigElement/Operator/Table.php b/src/ConfigElement/Operator/Table.php index 94b42b5..6ade8ff 100644 --- a/src/ConfigElement/Operator/Table.php +++ b/src/ConfigElement/Operator/Table.php @@ -15,6 +15,8 @@ namespace OutputDataConfigToolkitBundle\ConfigElement\Operator; +use OutputDataConfigToolkitBundle\ConfigElement\AbstractConfigElement; + class Table extends AbstractOperator { protected $tooltip; @@ -37,6 +39,10 @@ public function getLabeledValue($object) $isEmpty = false; $valueArray = []; foreach ($childs as $c) { + if ($c instanceof AbstractConfigElement) { + $c->setClassificationstore($this->getClassificationstore()); + $c->setClassificationstoreGroup($this->getClassificationstoreGroup()); + } $row = $c->getLabeledValue($object); $valueArray[] = $row; $isEmpty = $row->empty; diff --git a/src/ConfigElement/Operator/TableCol.php b/src/ConfigElement/Operator/TableCol.php index b374552..42fc357 100644 --- a/src/ConfigElement/Operator/TableCol.php +++ b/src/ConfigElement/Operator/TableCol.php @@ -15,6 +15,8 @@ namespace OutputDataConfigToolkitBundle\ConfigElement\Operator; +use OutputDataConfigToolkitBundle\ConfigElement\AbstractConfigElement; + class TableCol extends AbstractOperator { protected $colspan; @@ -34,7 +36,12 @@ public function getLabeledValue($object) $childs = $this->getChilds(); if ($childs) { - $value = $childs[0]->getLabeledValue($object); + $c = $childs[0]; + if ($c instanceof AbstractConfigElement) { + $c->setClassificationstore($this->getClassificationstore()); + $c->setClassificationstoreGroup($this->getClassificationstoreGroup()); + } + $value = $c->getLabeledValue($object); $value->colSpan = $this->colspan; $value->headline = $this->headline; diff --git a/src/ConfigElement/Operator/TableRow.php b/src/ConfigElement/Operator/TableRow.php index f85399c..6e41ec9 100644 --- a/src/ConfigElement/Operator/TableRow.php +++ b/src/ConfigElement/Operator/TableRow.php @@ -15,6 +15,8 @@ namespace OutputDataConfigToolkitBundle\ConfigElement\Operator; +use OutputDataConfigToolkitBundle\ConfigElement\AbstractConfigElement; + class TableRow extends AbstractOperator { protected $headline; @@ -35,6 +37,10 @@ public function getLabeledValue($object) $valueArray = []; foreach ($childs as $c) { + if ($c instanceof AbstractConfigElement) { + $c->setClassificationstore($this->getClassificationstore()); + $c->setClassificationstoreGroup($this->getClassificationstoreGroup()); + } $col = $c->getLabeledValue($object); if (!empty($col) && (!$col->empty && !($c instanceof \OutputDataConfigToolkitBundle\ConfigElement\Operator\Text))) { $isEmpty = false; diff --git a/src/ConfigElement/Operator/TextAddon.php b/src/ConfigElement/Operator/TextAddon.php index 6668ce7..b5338d6 100644 --- a/src/ConfigElement/Operator/TextAddon.php +++ b/src/ConfigElement/Operator/TextAddon.php @@ -15,6 +15,8 @@ namespace OutputDataConfigToolkitBundle\ConfigElement\Operator; +use OutputDataConfigToolkitBundle\ConfigElement\AbstractConfigElement; + class TextAddon extends AbstractOperator { private $addon; @@ -30,7 +32,12 @@ public function getLabeledValue($object) { $childs = $this->getChilds(); if (!empty($childs)) { - $value = $childs[0]->getLabeledValue($object); + $c = $childs[0]; + if ($c instanceof AbstractConfigElement) { + $c->setClassificationstore($this->getClassificationstore()); + $c->setClassificationstoreGroup($this->getClassificationstoreGroup()); + } + $value = $c->getLabeledValue($object); if (!is_null($value->value)) { $value->value = $value->value.$this->getAddon(); diff --git a/src/ConfigElement/Operator/TranslateValue.php b/src/ConfigElement/Operator/TranslateValue.php index d1e4cd0..9965de4 100644 --- a/src/ConfigElement/Operator/TranslateValue.php +++ b/src/ConfigElement/Operator/TranslateValue.php @@ -15,6 +15,8 @@ namespace OutputDataConfigToolkitBundle\ConfigElement\Operator; +use OutputDataConfigToolkitBundle\ConfigElement\AbstractConfigElement; + class TranslateValue extends AbstractOperator { private $prefix; @@ -31,8 +33,12 @@ public function getLabeledValue($object) $childs = $this->getChilds(); if ($childs) { $translator = \Pimcore::getContainer()->get('translator'); - - $value = $childs[0]->getLabeledValue($object); + $c = $childs[0]; + if ($c instanceof AbstractConfigElement) { + $c->setClassificationstore($this->getClassificationstore()); + $c->setClassificationstoreGroup($this->getClassificationstoreGroup()); + } + $value = $c->getLabeledValue($object); if ($value->value) { $value->value = $translator->trans($this->prefix . $value->value); } diff --git a/src/ConfigElement/Value/DefaultValue.php b/src/ConfigElement/Value/DefaultValue.php index d7d5eae..f54aee6 100644 --- a/src/ConfigElement/Value/DefaultValue.php +++ b/src/ConfigElement/Value/DefaultValue.php @@ -29,12 +29,6 @@ class DefaultValue extends AbstractConfigElement /** @var string|null */ protected $icon; - /** @var string|null */ - public $classificationstore; - - /** @var string|null */ - public $classificationstore_group; - public function __construct($config, $context = null) { parent::__construct($config, $context); @@ -157,15 +151,15 @@ public function getLabeledValue($object) protected function getLabeledValueForClassificationStore($object): ?object { // checking classification store fieldname - if (!$this->classificationstore) { + if (!$this->getClassificationstore()) { return null; } - $getter = 'get' . ucfirst($this->classificationstore); + $getter = 'get' . ucfirst($this->getClassificationstore()); // checking classification sote group - if (!$this->classificationstore_group) { + if (!$this->getClassificationstoreGroup()) { return null; } - $groupDef = Classificationstore\GroupConfig::getByName($this->classificationstore_group); + $groupDef = Classificationstore\GroupConfig::getByName($this->getClassificationstoreGroup()); // classification store $attribute = str_replace('#cs#', '', $this->attribute);