| Current Path : /var/www/html/vendor/magento/module-widget/Model/ResourceModel/Widget/Instance/ |
| Current File : /var/www/html/vendor/magento/module-widget/Model/ResourceModel/Widget/Instance/Collection.php |
<?php
/**
* Copyright © Magento, Inc. All rights reserved.
* See COPYING.txt for license details.
*/
namespace Magento\Widget\Model\ResourceModel\Widget\Instance;
/**
* Widget Instance Collection
*
* @api
* @since 100.0.2
*/
class Collection extends \Magento\Framework\Model\ResourceModel\Db\Collection\AbstractCollection
{
/**
* Fields map for correlation names & real selected fields
*
* @var array
*/
protected $_map = ['fields' => ['type' => 'instance_type']];
/**
* Constructor
*
* @return void
*/
protected function _construct()
{
parent::_construct();
$this->_init(
\Magento\Widget\Model\Widget\Instance::class,
\Magento\Widget\Model\ResourceModel\Widget\Instance::class
);
}
/**
* Filter by store ids
*
* @param array|int $storeIds
* @param bool $withDefaultStore if TRUE also filter by store id '0'
* @return $this
*/
public function addStoreFilter($storeIds = [], $withDefaultStore = true)
{
if (!is_array($storeIds)) {
$storeIds = [$storeIds];
}
if ($withDefaultStore && !in_array('0', $storeIds)) {
array_unshift($storeIds, 0);
}
$where = [];
foreach ($storeIds as $storeId) {
$where[] = $this->_getConditionSql('store_ids', ['finset' => $storeId]);
}
$this->_select->where(implode(' OR ', $where));
return $this;
}
}