custom/plugins/CogiPickLists/src/CogiPickLists.php line 20

Open in your IDE?
  1. <?php declare(strict_types=1);
  2. namespace Cogi\CogiPickLists;
  3. use Doctrine\DBAL\Connection;
  4. use Shopware\Core\Checkout\Document\Aggregate\DocumentType\DocumentTypeEntity;
  5. use Shopware\Core\Framework\Context;
  6. use Shopware\Core\Framework\DataAbstractionLayer\Search\Criteria;
  7. use Shopware\Core\Framework\DataAbstractionLayer\Search\Filter\EqualsFilter;
  8. use Shopware\Core\Framework\Plugin;
  9. use Shopware\Core\Framework\Plugin\Context\InstallContext;
  10. use Shopware\Core\Framework\Plugin\Context\UninstallContext;
  11. use Shopware\Core\Framework\Uuid\Uuid;
  12. use Shopware\Core\System\NumberRange\Aggregate\NumberRangeType\NumberRangeTypeEntity;
  13. use Shopware\Core\System\NumberRange\NumberRangeEntity;
  14. use Symfony\Component\Config\FileLocator;
  15. use Symfony\Component\DependencyInjection\ContainerBuilder;
  16. use Symfony\Component\DependencyInjection\Loader\XmlFileLoader;
  17. class CogiPickLists extends Plugin
  18. {
  19.     public function install(InstallContext $context): void {
  20.         parent::install($context);
  21.     }
  22.     public function uninstall(UninstallContext $context): void {
  23.         parent::uninstall($context);
  24.         if ($context->keepUserData()) {
  25.             return;
  26.         }
  27.         $documentTypeRepository $this->container->get('document_type.repository');
  28.         $numberRangeTypeRepository $this->container->get('number_range_type.repository');
  29.         $numberRangeRepository $this->container->get('number_range.repository');
  30.         $criteria = new Criteria();
  31.         $criteria->addFilter(new EqualsFilter('technicalName''cogi_picklist'));
  32.         /** @var DocumentTypeEntity $documentType */
  33.         $documentType $documentTypeRepository->search($criteriaContext::createDefaultContext())->getEntities()->first();
  34.         $documentTypeId $documentType->getId();
  35.         $criteria->resetFilters();
  36.         $criteria->addFilter(new EqualsFilter('technicalName''document_cogi_picklist'));
  37.         /** @var NumberRangeTypeEntity $numberRangeType */
  38.         $numberRangeType $numberRangeTypeRepository->search($criteriaContext::createDefaultContext())->getEntities()->first();
  39.         $numberRangeTypeId $numberRangeType->getId();
  40.         $criteria->resetFilters();
  41.         $criteria->addFilter(new EqualsFilter('typeId'$numberRangeTypeId));
  42.         /** @var NumberRangeEntity $numberRange */
  43.         $numberRange $numberRangeRepository->search($criteriaContext::createDefaultContext())->getEntities()->first();
  44.         $numberRangeId $numberRange->getId();
  45.         $connection $this->container->get(Connection::class);
  46.         $connection->exec("DELETE FROM `number_range_state` WHERE `number_range_id` = UNHEX('" $numberRangeId "');");
  47.         $connection->exec("DELETE FROM `number_range` WHERE `type_id` = UNHEX('" $numberRangeTypeId "');");
  48.         $connection->exec("DELETE FROM `document` WHERE `document_type_id` = UNHEX('" $documentTypeId "');");
  49.         $connection->exec("DELETE FROM `number_range_type` WHERE `technical_name` LIKE '%document_cogi_picklist%';");
  50.         $connection->exec("DELETE FROM `document_type` WHERE `technical_name` LIKE '%cogi_picklist%';");
  51.     }
  52.     public function build(ContainerBuilder $containerBuilder): void
  53.     {
  54.         parent::build($containerBuilder);
  55.         $loader = new XmlFileLoader($containerBuilder, new FileLocator(__DIR__));
  56.         $loader->load('Picklist/DependencyInjection/service.xml');
  57.     }
  58. }