1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- <?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;
- }
- }
|