| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859 |
- <?php
- namespace MailPoet\Newsletter\Options;
- if (!defined('ABSPATH')) exit;
- use MailPoet\Doctrine\Repository;
- use MailPoet\Entities\NewsletterEntity;
- use MailPoet\Entities\NewsletterOptionEntity;
- use MailPoet\Entities\NewsletterOptionFieldEntity;
- /**
- * @extends Repository<NewsletterOptionEntity>
- */
- class NewsletterOptionsRepository extends Repository {
- protected function getEntityClassName() {
- return NewsletterOptionEntity::class;
- }
- /**
- * @return NewsletterOptionEntity[]
- */
- public function findWelcomeNotificationsForSegments(array $segmentIds): array {
- return $this->entityManager->createQueryBuilder()
- ->select('no')
- ->from(NewsletterOptionEntity::class, 'no')
- ->join('no.newsletter', 'n')
- ->join('no.optionField', 'nof')
- ->where('n.deletedAt IS NULL')
- ->andWhere('n.type = :typeWelcome')
- ->andWhere('nof.name = :nameSegment')
- ->andWhere('no.value IN (:segmentIds)')
- ->setParameter('typeWelcome', NewsletterEntity::TYPE_WELCOME)
- ->setParameter('nameSegment', NewsletterOptionFieldEntity::NAME_SEGMENT)
- ->setParameter('segmentIds', $segmentIds)
- ->getQuery()->getResult();
- }
- /**
- * @return NewsletterOptionEntity[]
- */
- public function findAutomaticEmailsForSegments(array $segmentIds): array {
- return $this->entityManager->createQueryBuilder()
- ->select('no')
- ->from(NewsletterOptionEntity::class, 'no')
- ->join('no.newsletter', 'n')
- ->join('no.optionField', 'nof')
- ->where('n.deletedAt IS NULL')
- ->andWhere('n.type = :typeAutomatic')
- ->andWhere('nof.name = :nameSegment')
- ->andWhere('no.value IN (:segmentIds)')
- ->setParameter('typeAutomatic', NewsletterEntity::TYPE_AUTOMATIC)
- ->setParameter('nameSegment', NewsletterOptionFieldEntity::NAME_SEGMENT)
- ->setParameter('segmentIds', $segmentIds)
- ->getQuery()->getResult();
- }
- }
|