116 lines
2.9 KiB
PHP
116 lines
2.9 KiB
PHP
|
<?php // phpcs:ignore SlevomatCodingStandard.TypeHints.DeclareStrictTypes.DeclareStrictTypesMissing
|
||
|
|
||
|
namespace MailPoet\Form;
|
||
|
|
||
|
if (!defined('ABSPATH')) exit;
|
||
|
|
||
|
|
||
|
use MailPoet\Doctrine\Repository;
|
||
|
use MailPoet\Entities\FormEntity;
|
||
|
|
||
|
/**
|
||
|
* @extends Repository<FormEntity>
|
||
|
*/
|
||
|
class FormsRepository extends Repository {
|
||
|
protected function getEntityClassName() {
|
||
|
return FormEntity::class;
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @return FormEntity[]
|
||
|
*/
|
||
|
public function findAllNotDeleted(): array {
|
||
|
return $this->entityManager
|
||
|
->createQueryBuilder()
|
||
|
->select('f')
|
||
|
->from(FormEntity::class, 'f')
|
||
|
->where('f.deletedAt IS NULL')
|
||
|
->orderBy('f.updatedAt', 'desc')
|
||
|
->getQuery()
|
||
|
->getResult();
|
||
|
}
|
||
|
|
||
|
public function getNamesOfFormsForSegments(): array {
|
||
|
$allNonDeletedForms = $this->findAllNotDeleted();
|
||
|
|
||
|
$nameMap = [];
|
||
|
foreach ($allNonDeletedForms as $form) {
|
||
|
$blockSegmentsIds = $form->getSettingsSegmentIds();
|
||
|
foreach ($blockSegmentsIds as $blockSegmentId) {
|
||
|
$nameMap[$blockSegmentId][] = $form->getName();
|
||
|
}
|
||
|
}
|
||
|
|
||
|
return $nameMap;
|
||
|
}
|
||
|
|
||
|
public function count(): int {
|
||
|
return (int)$this->doctrineRepository
|
||
|
->createQueryBuilder('f')
|
||
|
->select('count(f.id)')
|
||
|
->getQuery()
|
||
|
->getSingleScalarResult();
|
||
|
}
|
||
|
|
||
|
public function delete(FormEntity $form) {
|
||
|
$this->entityManager->remove($form);
|
||
|
$this->flush();
|
||
|
}
|
||
|
|
||
|
public function trash(FormEntity $form) {
|
||
|
$this->bulkTrash([$form->getId()]);
|
||
|
$this->entityManager->refresh($form);
|
||
|
}
|
||
|
|
||
|
public function restore(FormEntity $form) {
|
||
|
$this->bulkRestore([$form->getId()]);
|
||
|
$this->entityManager->refresh($form);
|
||
|
}
|
||
|
|
||
|
public function bulkTrash(array $ids): int {
|
||
|
if (empty($ids)) {
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
return $this->entityManager->createQueryBuilder()
|
||
|
->update(FormEntity::class, 'f')
|
||
|
->set('f.deletedAt', 'CURRENT_TIMESTAMP()')
|
||
|
->where('f.id IN (:ids)')
|
||
|
->setParameter('ids', $ids)
|
||
|
->getQuery()->execute();
|
||
|
}
|
||
|
|
||
|
public function bulkRestore(array $ids): int {
|
||
|
if (empty($ids)) {
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
return $this->entityManager->createQueryBuilder()
|
||
|
->update(FormEntity::class, 'f')
|
||
|
->set('f.deletedAt', ':deletedAt')
|
||
|
->where('f.id IN (:ids)')
|
||
|
->setParameter('deletedAt', null)
|
||
|
->setParameter('ids', $ids)
|
||
|
->getQuery()->execute();
|
||
|
}
|
||
|
|
||
|
public function bulkDelete(array $ids): int {
|
||
|
if (empty($ids)) {
|
||
|
return 0;
|
||
|
}
|
||
|
|
||
|
$result = $this->entityManager->createQueryBuilder()
|
||
|
->delete(FormEntity::class, 'f')
|
||
|
->where('f.id IN (:ids)')
|
||
|
->setParameter('ids', $ids)
|
||
|
->getQuery()->execute();
|
||
|
|
||
|
// delete was done via DQL, make sure the entities are also detached from the entity manager
|
||
|
$this->detachAll(function (FormEntity $entity) use ($ids) {
|
||
|
return in_array($entity->getId(), $ids, true);
|
||
|
});
|
||
|
|
||
|
return $result;
|
||
|
}
|
||
|
}
|