123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120 |
- <?php
- /**
- * Copyright © Magento, Inc. All rights reserved.
- * See COPYING.txt for license details.
- */
- namespace Magento\Widget\Model\ResourceModel\Layout\Link;
- /**
- * Layout update collection model
- */
- class Collection extends \Magento\Framework\Model\ResourceModel\Db\Collection\AbstractCollection
- {
- /**
- * @var \Magento\Framework\Stdlib\DateTime
- */
- protected $dateTime;
- /**
- * @param \Psr\Log\LoggerInterface $logger
- * @param \Magento\Framework\Data\Collection\Db\FetchStrategyInterface $fetchStrategy
- * @param \Magento\Framework\Event\ManagerInterface $eventManager
- * @param \Magento\Framework\Stdlib\DateTime $dateTime
- * @param mixed $connection
- * @param \Magento\Framework\Model\ResourceModel\Db\AbstractDb $resource
- * @param \Magento\Framework\Data\Collection\EntityFactory $entityFactory
- */
- public function __construct(
- \Magento\Framework\Data\Collection\EntityFactory $entityFactory,
- \Psr\Log\LoggerInterface $logger,
- \Magento\Framework\Data\Collection\Db\FetchStrategyInterface $fetchStrategy,
- \Magento\Framework\Event\ManagerInterface $eventManager,
- \Magento\Framework\Stdlib\DateTime $dateTime,
- \Magento\Framework\DB\Adapter\AdapterInterface $connection = null,
- \Magento\Framework\Model\ResourceModel\Db\AbstractDb $resource = null
- ) {
- $this->dateTime = $dateTime;
- parent::__construct($entityFactory, $logger, $fetchStrategy, $eventManager, $connection, $resource);
- }
- /**
- * Define resource model
- *
- * @return void
- */
- protected function _construct()
- {
- parent::_construct();
- $this->_init(\Magento\Widget\Model\Layout\Link::class, \Magento\Widget\Model\ResourceModel\Layout\Link::class);
- }
- /**
- * Add filter by theme id
- *
- * @param int $themeId
- * @return $this
- */
- public function addThemeFilter($themeId)
- {
- $this->addFieldToFilter('theme_id', $themeId);
- return $this;
- }
- /**
- * Join with layout update table
- *
- * @param array $fields
- * @return $this
- */
- protected function _joinWithUpdate($fields = [])
- {
- $flagName = 'joined_with_update_table';
- if (!$this->getFlag($flagName)) {
- $this->getSelect()->join(
- ['update' => $this->getTable('layout_update')],
- 'update.layout_update_id = main_table.layout_update_id',
- [$fields]
- );
- $this->setFlag($flagName, true);
- }
- return $this;
- }
- /**
- * Filter by temporary flag
- *
- * @param bool $isTemporary
- * @return $this
- */
- public function addTemporaryFilter($isTemporary)
- {
- $this->addFieldToFilter('main_table.is_temporary', $isTemporary ? 1 : 0);
- return $this;
- }
- /**
- * Get links for layouts that are older than specified number of days
- *
- * @param string $days
- * @return $this
- */
- public function addUpdatedDaysBeforeFilter($days)
- {
- $datetime = new \DateTime('now', new \DateTimeZone('UTC'));
- $storeInterval = new \DateInterval('P' . $days . 'D');
- $datetime->sub($storeInterval);
- $formattedDate = $this->dateTime->formatDate($datetime->getTimestamp());
- $this->_joinWithUpdate();
- $this->addFieldToFilter(
- 'update.updated_at',
- ['notnull' => true]
- )->addFieldToFilter(
- 'update.updated_at',
- ['lt' => $formattedDate]
- );
- return $this;
- }
- }
|