From 6f88d3fc9be68de05e90b43a4f89077af65e79f4 Mon Sep 17 00:00:00 2001 From: Marcin Szterling Date: Thu, 18 Jan 2018 12:16:12 +0000 Subject: [PATCH] GETWO-1556] Export: Unable to Filter Data by Attribute With Input Type Multiple Select - reduced complexity of getAttributeFilterType method --- .../Magento/ImportExport/Model/Export.php | 38 ++++++++++++------- 1 file changed, 25 insertions(+), 13 deletions(-) diff --git a/app/code/Magento/ImportExport/Model/Export.php b/app/code/Magento/ImportExport/Model/Export.php index 4719f05dd8b64..11acd68cb1e01 100644 --- a/app/code/Magento/ImportExport/Model/Export.php +++ b/app/code/Magento/ImportExport/Model/Export.php @@ -30,7 +30,7 @@ class Export extends \Magento\ImportExport\Model\AbstractModel */ const FILTER_TYPE_SELECT = 'select'; - const FILTER_TYPE_MULTISELECT ='multiselect'; + const FILTER_TYPE_MULTISELECT = 'multiselect'; const FILTER_TYPE_INPUT = 'input'; @@ -67,6 +67,17 @@ class Export extends \Magento\ImportExport\Model\AbstractModel */ protected $_exportAdapterFac; + /** + * @var array + */ + public static $backendTypeToFilterMapper = [ + 'datetime' => self::FILTER_TYPE_DATE, + 'decimal' => self::FILTER_TYPE_NUMBER, + 'int' => self::FILTER_TYPE_NUMBER, + 'varchar' => self::FILTER_TYPE_INPUT, + 'text' => self::FILTER_TYPE_INPUT + ]; + /** * @param \Psr\Log\LoggerInterface $logger * @param \Magento\Framework\Filesystem $filesystem @@ -82,7 +93,8 @@ public function __construct( \Magento\ImportExport\Model\Export\Entity\Factory $entityFactory, \Magento\ImportExport\Model\Export\Adapter\Factory $exportAdapterFac, array $data = [] - ) { + ) + { $this->_exportConfig = $exportConfig; $this->_entityFactory = $entityFactory; $this->_exportAdapterFac = $exportAdapterFac; @@ -219,19 +231,19 @@ public static function getAttributeFilterType(\Magento\Eav\Model\Entity\Attribut if ($attribute->usesSource() || $attribute->getFilterOptions()) { return 'multiselect' == $attribute->getFrontendInput() ? self::FILTER_TYPE_MULTISELECT : self::FILTER_TYPE_SELECT; - } elseif ('datetime' == $attribute->getBackendType()) { - return self::FILTER_TYPE_DATE; - } elseif ('decimal' == $attribute->getBackendType() || 'int' == $attribute->getBackendType()) { - return self::FILTER_TYPE_NUMBER; - } elseif ('varchar' == $attribute->getBackendType() || 'text' == $attribute->getBackendType()) { - return self::FILTER_TYPE_INPUT; - } elseif ($attribute->isStatic()) { + } + + if (isset(self::$backendTypeToFilterMapper[$attribute->getBackendType()])) { + return self::$backendTypeToFilterMapper[$attribute->getBackendType()]; + } + + if ($attribute->isStatic()) { return self::getStaticAttributeFilterType($attribute); - } else { - throw new \Magento\Framework\Exception\LocalizedException( - __('We can\'t determine the attribute filter type.') - ); } + + throw new \Magento\Framework\Exception\LocalizedException( + __('We can\'t determine the attribute filter type.') + ); } /**