![]() Server : Apache System : Linux server2.corals.io 4.18.0-348.2.1.el8_5.x86_64 #1 SMP Mon Nov 15 09:17:08 EST 2021 x86_64 User : corals ( 1002) PHP Version : 7.4.33 Disable Function : exec,passthru,shell_exec,system Directory : /home/corals/old/vendor/magento/module-customer/Model/ResourceModel/Grid/ |
<?php /** * Copyright © Magento, Inc. All rights reserved. * See COPYING.txt for license details. */ namespace Magento\Customer\Model\ResourceModel\Grid; use Magento\Customer\Model\ResourceModel\Customer; use Magento\Customer\Ui\Component\DataProvider\Document; use Magento\Framework\App\ObjectManager; use Magento\Framework\Data\Collection\Db\FetchStrategyInterface as FetchStrategy; use Magento\Framework\Data\Collection\EntityFactoryInterface as EntityFactory; use Magento\Framework\Event\ManagerInterface as EventManager; use Magento\Framework\Locale\ResolverInterface; use Magento\Framework\Stdlib\DateTime\TimezoneInterface; use Magento\Framework\View\Element\UiComponent\DataProvider\SearchResult; use Psr\Log\LoggerInterface as Logger; /** * Collection to present grid of customers on admin area */ class Collection extends SearchResult { /** * @var ResolverInterface */ private $localeResolver; /** * @var TimezoneInterface */ private $timeZone; /** * @inheritdoc */ protected $document = Document::class; /** * @inheritdoc */ protected $_map = ['fields' => ['entity_id' => 'main_table.entity_id']]; /** * @param EntityFactory $entityFactory * @param Logger $logger * @param FetchStrategy $fetchStrategy * @param EventManager $eventManager * @param ResolverInterface $localeResolver * @param string $mainTable * @param string $resourceModel * @param TimezoneInterface|null $timeZone */ public function __construct( EntityFactory $entityFactory, Logger $logger, FetchStrategy $fetchStrategy, EventManager $eventManager, ResolverInterface $localeResolver, $mainTable = 'customer_grid_flat', $resourceModel = Customer::class, TimezoneInterface $timeZone = null ) { $this->localeResolver = $localeResolver; parent::__construct($entityFactory, $logger, $fetchStrategy, $eventManager, $mainTable, $resourceModel); $this->timeZone = $timeZone ?: ObjectManager::getInstance() ->get(TimezoneInterface::class); } /** * @inheritdoc */ protected function _initSelect() { parent::_initSelect(); $this->joinRegionNameTable(); return $this; } /** * @inheritdoc */ public function addFieldToFilter($field, $condition = null) { if ($field === 'billing_region') { $conditionSql = $this->_getConditionSql( $this->getRegionNameExpression(), $condition ); $this->getSelect()->where($conditionSql); return $this; } if ($field === 'created_at') { if (is_array($condition)) { foreach ($condition as $key => $value) { $condition[$key] = $this->timeZone->convertConfigTimeToUtc($value); } } } if (is_string($field) && count(explode('.', $field)) === 1) { $field = 'main_table.' . $field; } return parent::addFieldToFilter($field, $condition); } /** * Add fulltext filter * * @param string $value * @return $this */ public function addFullTextFilter(string $value) { $fields = $this->getFulltextIndexColumns(); $whereCondition = ''; foreach ($fields as $key => $field) { $field = $field === 'billing_region' ? $this->getRegionNameExpression() : 'main_table.' . $field; $condition = $this->_getConditionSql( $this->getConnection()->quoteIdentifier($field), ['like' => "%$value%"] ); $whereCondition .= ($key === 0 ? '' : ' OR ') . $condition; } if ($whereCondition) { $this->getSelect()->where($whereCondition); } return $this; } /** * Returns list of columns from fulltext index * * @return array */ private function getFulltextIndexColumns(): array { $indexes = $this->getConnection()->getIndexList($this->getMainTable()); foreach ($indexes as $index) { if (strtoupper($index['INDEX_TYPE']) == 'FULLTEXT') { return $index['COLUMNS_LIST']; } } return []; } /** * Join region name table by current locale * * @return $this */ private function joinRegionNameTable() { $locale = $this->localeResolver->getLocale(); $connection = $this->getConnection(); $regionIdField = $connection->quoteIdentifier('main_table.billing_region_id'); $localeCondition = $connection->quoteInto("rnt.locale=?", $locale); $this->getSelect() ->joinLeft( ['rct' => $this->getTable('directory_country_region')], "rct.region_id={$regionIdField}", [] )->joinLeft( ['rnt' => $this->getTable('directory_country_region_name')], "rnt.region_id={$regionIdField} AND {$localeCondition}", ['billing_region' => $this->getRegionNameExpression()] ); return $this; } /** * Get SQL Expression to define Region Name field by locale * * @return \Zend_Db_Expr */ private function getRegionNameExpression(): \Zend_Db_Expr { $connection = $this->getConnection(); $defaultNameExpr = $connection->getIfNullSql( $connection->quoteIdentifier('rct.default_name'), $connection->quoteIdentifier('main_table.billing_region') ); return $connection->getIfNullSql( $connection->quoteIdentifier('rnt.name'), $defaultNameExpr ); } }