<?php declare(strict_types=1);
namespace GlobusSW6;
use Doctrine\DBAL\Connection;
use GlobusSW6\Core\Content\CheckoutSpecialCase\CheckoutSpecialCaseDefinition;
use GlobusSW6\Core\Content\ProtectedNames\ProtectedNamesDefinition;
use GlobusSW6\Service\PaymentMethods\AbholungPayment;
use GlobusSW6\Service\PaymentMethods\KauflandPayment;
use Shopware\Core\Checkout\Payment\PaymentMethodEntity;
use Shopware\Core\Content\MailTemplate\Aggregate\MailTemplateType\MailTemplateTypeEntity;
use Shopware\Core\Content\MailTemplate\MailTemplateEntity;
use Shopware\Core\Defaults;
use Shopware\Core\Framework\DataAbstractionLayer\EntityRepositoryInterface;
use Shopware\Core\Framework\DataAbstractionLayer\Search\Criteria;
use Shopware\Core\Framework\DataAbstractionLayer\Search\Filter\EqualsAnyFilter;
use Shopware\Core\Framework\DataAbstractionLayer\Search\Filter\EqualsFilter;
use Shopware\Core\Framework\Plugin;
use Shopware\Core\Framework\Plugin\Context\InstallContext;
use Shopware\Core\Framework\Plugin\Context\UninstallContext;
use Shopware\Core\Framework\Plugin\Context\UpdateContext;
use Shopware\Core\Framework\Context;
use Shopware\Core\Framework\Plugin\Util\PluginIdProvider;
use Shopware\Core\Framework\Uuid\Uuid;
use Symfony\Component\Finder\Finder;
use GlobusSW6\Core\IaneoDefaults;
class GlobusSW6 extends Plugin
{
const MAIL_TEMPLATE_PROTECTED_NAMES_NAME = 'system.protected_names';
public function install(InstallContext $installContext): void
{
$shopwareContext = $installContext->getContext();
//$this->addCustomFields($shopwareContext);
/*
$this->connection = $this->container->get('Doctrine\DBAL\Connection');
$this->snippetRepository = $this->container->get('snippet.repository');
$this->setSnippets('visibilityAusgeschaltet', 'Das Produkt ist ausgeschaltet.', 'de-DE');
$this->setSnippets('visibilityBestellwareDispomarker', 'Bei dem Produkt handelt es sich um Bestellware, welche weder den Dispo-Marker G oder K enthält', 'de-DE');
$this->setSnippets('visibilityDeactivated', 'Das Produkt ist deaktiviert.', 'de-DE');
$this->setSnippets('visibilityInactive', 'Das Produkt ist inaktiv.', 'de-DE');
$this->setSnippets('visibilityMeterware', 'Das Produkt ist Meterware mit dem Dispomarker R.', 'de-DE');
$this->setSnippets('visibilityProductExtraordinaire', 'Das Produkt befindet sich im Globus Hitseller Sales Channel und enthält keine Checkout Attributes', 'de-DE');
$this->setSnippets('visibilityProtectedNames', 'Das Produkt enthält geschützte Namen.', 'de-DE');
$this->setSnippets('visibilitySperrkennzeichen', 'Das Produkt ist mit einem Sperrkennzeichen markiert.', 'de-DE');
$this->setSnippets('visibilityStreckenartikel', 'Das Produkt ist ein Streckenartikel ohne Dispomarker G oder K.', 'de-DE');
*/
$this->installProtectedNames($installContext);
$this->installCheckoutSpecialCases();
$this->installAvailabilitySnippets();
$this->installCheckoutSnippets();
parent::install($installContext);
}
public function update(UpdateContext $updateContext): void
{
$shopwareContext = $updateContext->getContext();
//$this->addCustomFields($shopwareContext);
//$this->installPaymentMethods($updateContext);
parent::update($updateContext);
}
public function uninstall(UninstallContext $uninstallContext): void
{
$shopwareContext = $uninstallContext->getContext();
//$this->removeCustomFields($shopwareContext);
if ($uninstallContext->keepUserData()) {
return;
}
$this->uninstallProtectedNames($uninstallContext);
$this->uninstallCheckoutSpecialCases();
$this->uninstallAvailabilitySnippets();
$this->uninstallCheckoutSnippets();
parent::uninstall($uninstallContext); // TODO: Change the autogenerated stub
}
/**
* @param string $key : the translation key/technical name of the snippet
* @param string $value : the value of the snippet
* @param string $set : the iso of the snippet_set to use (e.g. de-DE or en-GB)
* @return bool
*/
private function setSnippets(string $key, string $value, string $set) : bool
{
$connection = $this->container->get('Doctrine\DBAL\Connection');
$snippetRepository = $this->container->get('snippet.repository');
$snippetSetId = $connection->fetchColumn('
SELECT id
FROM snippet_set
WHERE iso =?
', [$set]);
if (!$snippetSetId) {
throw new \InvalidArgumentException('Iso ' . $set . ' not found.');
}
// Check if id already exists
$snippetId = $connection->fetchColumn('
SELECT LOWER(HEX(id))
FROM snippet
WHERE translation_key =? AND snippet_set_id =?
', [$key, $snippetSetId]);
if ($snippetId) {
return false;
}
$snippetRepository->upsert([
[
'id' => Uuid::randomHex(),
'translationKey' => $key,
'value' => $value,
'setId' => Uuid::fromBytesToHex($snippetSetId),
'author' => 'user/admin',
'origin' => null
]
], Context::createDefaultContext() );
return true;
}
/*
* @param string $filenamedelete field
*
* @return string|null
*/
protected function getMailTemplate(string $filename): ?string
{
$finder = new Finder();
// find all files in the current directory
$finder->files()->in(__DIR__ . '/Resources/views/mail/templates');
foreach ($finder as $file) {
if ($filename === $file->getFilenameWithoutExtension()) {
return $file->getContents();
}
}
return null;
}
private function installProtectedNames(InstallContext $installContext)
{
$mailTemplateRepository = $this->container->get('mail_template.repository');
$mailTemplateTypeRepository = $this->container->get('mail_template_type.repository');
$criteria = new Criteria();
$criteria->addFilter(new EqualsFilter('technicalName', self::MAIL_TEMPLATE_PROTECTED_NAMES_NAME));
$templateType = $mailTemplateTypeRepository->search($criteria, $installContext->getContext())->first();
if ($templateType instanceof MailTemplateTypeEntity) {
return;
}
$mailTemplateRepository->create([
[
'systemDefault' => false,
'translations' => [
[
'languageId' => Defaults::LANGUAGE_SYSTEM,
'subject' => 'Geschützte Begriffe',
'description' => 'Infomail wenn geschützte Begriffe in Artikleberschreibung genutzt wurden',
'senderName' => '{{ salesChannel.name }}',
'contentPlain' => $this->getMailTemplate('protected_names_notification.txt'),
'contentHtml' => $this->getMailTemplate('protected_names_notification.html'),
],
],
'mailTemplateType' => [
'technicalName' => self::MAIL_TEMPLATE_PROTECTED_NAMES_NAME,
'availableEntities' => [
'protectedNames' => 'protected_names',
'salesChannel' => 'sales_channel',
],
'translations' => [
[
'languageId' => Defaults::LANGUAGE_SYSTEM,
'name' => 'Protected names',
],
],
],
],
], $installContext->getContext());
}
private function uninstallProtectedNames(UninstallContext $uninstallContext)
{
$connection = $this->container->get('Doctrine\DBAL\Connection');
$protectedNamesTable = ProtectedNamesDefinition::ENTITY_NAME;
$connection->exec("DROP TABLE IF EXISTS $protectedNamesTable");
$mailTemplateRepository = $this->container->get('mail_template.repository');
$mailTemplateTypeRepository = $this->container->get('mail_template_type.repository');
$criteria = new Criteria();
$criteria->addAssociation('mailTemplateType');
$criteria->addFilter(new EqualsFilter('mailTemplateType.technicalName',
self::MAIL_TEMPLATE_PROTECTED_NAMES_NAME));
$templates = $mailTemplateRepository->search($criteria, $uninstallContext->getContext());
if ($templates->count() <= 0) {
return;
}
$mailTemplateIds = [];
$mailTemplateTypeIds = [];
/** @var MailTemplateEntity $mailTemplate */
foreach ($templates->getElements() as $mailTemplate) {
$mailTemplateIds[] = ['id' => $mailTemplate->getId()];
if (!in_array($mailTemplate->getMailTemplateTypeId(), $mailTemplateTypeIds)) {
$mailTemplateTypeIds[] = ['id' => $mailTemplate->getMailTemplateTypeId()];
}
}
if (!empty($mailTemplateIds)) {
$mailTemplateRepository->delete($mailTemplateIds, $uninstallContext->getContext());
}
if (!empty($mailTemplateTypeIds)) {
$mailTemplateTypeRepository->delete($mailTemplateTypeIds, $uninstallContext->getContext());
}
// @todo: wieder entfernen?
// $connection->exec("DROP TABLE IF EXISTS ianeo_category_attributes");
// $connection->exec("DROP TABLE IF EXISTS ianeo_category_attributes_translation");
// $connection->exec("DROP TABLE IF EXISTS ianeo_product_attributes");
// $connection->exec("DROP TABLE IF EXISTS ianeo_product_attributes_translation");
//
// $connection->exec("
// ALTER TABLE `category` DROP COLUMN `ianeoAttributes`;
// ALTER TABLE `product` DROP COLUMN `ianeoAttributes`;
// ALTER TABLE `customer` DROP COLUMN `ianeoAttributes`;
// ALTER TABLE `order` DROP COLUMN `ianeoAttributes`;
// ALTER TABLE `customer_group` DROP COLUMN `ianeoAttributes`;
// ");
}
private function installCheckoutSpecialCases(){
$this->setSnippets('deliveryInformation.OnlyBuyAtPlace', 'Kann nur im Markt vor Ort erworben werden', 'de-DE');
$this->setSnippets('deliveryInformation.OnlyBuyAtPlace', 'Kann nur im Markt vor Ort erworben werden', 'en-GB');
$this->setSnippets('deliveryInformation.deliveryTime', 'ca. %min% - %max% Werktage Lieferzeit', 'de-DE');
$this->setSnippets('deliveryInformation.deliveryTime', 'ca. %min% - %max% Werktage Lieferzeit', 'en-GB');
$this->setSnippets('deliveryInformation.readyForPickup', 'In %pickuptime% Stunden abholbereit', 'de-DE');
$this->setSnippets('deliveryInformation.readyForPickup', 'In %pickuptime% Stunden abholbereit', 'en-GB');
$this->setSnippets('reserveInStore.noSelectedStore', 'IM MARKT RESERVIEREN: MARKT SUCHEN', 'de-DE');
$this->setSnippets('reserveInStore.noSelectedStore', 'IM MARKT RESERVIEREN: MARKT SUCHEN', 'en-GB');
$this->setSnippets('reserveInStore.articleNotAvailable', 'ARTIKEL IM GEWÄHLTEN MARKT NICHT LIEFERBAR! VERFÜGBARKEIT IN ANDEREM MARKT PRÜFEN', 'de-DE');
$this->setSnippets('reserveInStore.articleNotAvailable', 'ARTIKEL IM GEWÄHLTEN MARKT NICHT LIEFERBAR! VERFÜGBARKEIT IN ANDEREM MARKT PRÜFEN', 'en-GB');
$this->setSnippets('reserveInStore.articleAvailable', 'IM MARKT RESERVIEREN: ', 'de-DE');
$this->setSnippets('reserveInStore.articleAvailable', 'IM MARKT RESERVIEREN: ', 'en-GB');
$this->setSnippets('reserveInStore.reservationText.articleNotAvailable', 'nicht verfügbar', 'de-DE');
$this->setSnippets('reserveInStore.reservationText.articleNotAvailable', 'EN_ nicht verfügbar', 'en-GB');
$this->setSnippets('checkoutSpecialCase.NotAvailable.Header', 'Artikel nicht verfügbar:', 'de-DE');
$this->setSnippets('checkoutSpecialCase.NotAvailable.Header', 'Artikel nicht verfügbar:', 'en-GB');
$this->setSnippets('checkoutSpecialCase.NotAvailable.Message', 'Dieser Artikel ist aktuell nicht bestellbar, wird aber in Kürze wieder verfügbar sein.', 'de-DE');
$this->setSnippets('checkoutSpecialCase.NotAvailable.Message', 'Dieser Artikel ist aktuell nicht bestellbar, wird aber in Kürze wieder verfügbar sein.', 'en-GB');
$this->setSnippets('deliveryInformation.manufacturer.text', "Lieferung durch <a href='%link%'>Hersteller</a>", 'de-DE');
$this->setSnippets('deliveryInformation.manufacturer.text', "Delivery by <a href='%link%'>manufacturer</a>", 'en-GB');
$this->setSnippets('hvc.notice', '<b>Hinweis:</b> Die Installation nicht steckerfertiger Geräte ist vom jeweiligen Netzbetreiber oder von einem eingetragenen Fachbetrieb vorzunehmen.', 'de-DE');
$this->setSnippets('hvc.notice', '<b>Hinweis:</b> Die Installation nicht steckerfertiger Geräte ist vom jeweiligen Netzbetreiber oder von einem eingetragenen Fachbetrieb vorzunehmen.', 'en-GB');
$this->setSnippets('puFoam.notice', 'Entsorgungshinweis: Gebrauchte PU-Schaumdosen gelten als Sonderabfall und dürfen daher nicht über den Restmüll, „Gelben Sack“, Weißblechcontainer oder Baumischabfall entsorgt werden. Gebrauchte PU-Schaumdosen können innerhalb unserer Öffnungszeiten in unseren Märkten vor Ort kostenlos zurückgegeben oder mit dem im Paket beigelegten Retourenlabel zurückgesendet werden. Zudem können PU-Schaumdosen über <a href=\"https://www.pdr.de/pu-schaumdosen-recycling/plz-suche-rueckgabestellen-in-meiner-naehe-finden/\" target=\"_blank\" rel=\"nofollow\"><u>Rückgabestellen in Ihrer Nähe</u></a> kostenfrei entsorgt werden.', 'de-DE');
$this->setSnippets('puFoam.notice', 'Entsorgungshinweis: Gebrauchte PU-Schaumdosen gelten als Sonderabfall und dürfen daher nicht über den Restmüll, „Gelben Sack“, Weißblechcontainer oder Baumischabfall entsorgt werden. Gebrauchte PU-Schaumdosen können innerhalb unserer Öffnungszeiten in unseren Märkten vor Ort kostenlos zurückgegeben oder mit dem im Paket beigelegten Retourenlabel zurückgesendet werden. Zudem können PU-Schaumdosen über <a href=\"https://www.pdr.de/pu-schaumdosen-recycling/plz-suche-rueckgabestellen-in-meiner-naehe-finden/\" target=\"_blank\" rel=\"nofollow\"><u>Rückgabestellen in Ihrer Nähe</u></a> kostenfrei entsorgt werden.', 'en-GB');
$this->setSnippets('biocidal.notice', 'Hinweis: Biozidprodukte vorsichtig verwenden. Vor Gebrauch stets Etikett und Produktinformation lesen.', 'de-DE');
$this->setSnippets('biocidal.notice', 'Hinweis: Biozidprodukte vorsichtig verwenden. Vor Gebrauch stets Etikett und Produktinformation lesen.', 'en-GB');
$this->setSnippets('mixedCart.Modal.p1', 'Bitte beachten Sie, dass Sie einen Artikel zur Reservierung im Markt und zur Online-Bestellung nicht gleichzeitig in Ihren Warenkorb legen können.', 'de-DE');
$this->setSnippets('mixedCart.Modal.p1', 'Bitte beachten Sie, dass Sie einen Artikel zur Reservierung im Markt und zur Online-Bestellung nicht gleichzeitig in Ihren Warenkorb legen können.', 'en-GB');
$this->setSnippets('mixedCart.Modal.p2', 'Lösen Sie hierfür bitte eine separate Bestellung aus.', 'de-DE');
$this->setSnippets('mixedCart.Modal.p2', 'Lösen Sie hierfür bitte eine separate Bestellung aus.', 'en-GB');
$this->setSnippets('desiredAmountNotAvailable.Modal.h1', 'Leider ist die gewünschte Menge aktuell nicht verfügbar.', 'de-DE');
$this->setSnippets('desiredAmountNotAvailable.Modal.h1', 'Leider ist die gewünschte Menge aktuell nicht verfügbar.', 'en-GB');
$this->setSnippets('desiredAmountNotAvailable.Modal.p1a', 'Die verbleibende Menge von ', 'de-DE');
$this->setSnippets('desiredAmountNotAvailable.Modal.p1a', 'Die verbleibende Menge von ', 'en-GB');
$this->setSnippets('desiredAmountNotAvailable.Modal.p1b', ' Stück wurde Ihrem Warenkorb automatisch hinzugefügt. Alternativ hilft Ihnen unser Kundenservice weiter: ', 'de-DE');
$this->setSnippets('desiredAmountNotAvailable.Modal.p1b', ' Stück wurde Ihrem Warenkorb automatisch hinzugefügt. Alternativ hilft Ihnen unser Kundenservice weiter: ', 'en-GB');
$this->setSnippets('desiredAmountNotAvailable.Modal.p2', '+49 6898/ 515880 oder E-Mail an onlineshop@globus-baumarkt.de', 'de-DE');
$this->setSnippets('desiredAmountNotAvailable.Modal.p2', '+49 6898/ 515880 oder E-Mail an onlineshop@globus-baumarkt.de', 'en-GB');
$this->setSnippets('desiredAmountNotAvailable.Modal.p2.hitseller', '+49 6898/ 515800 oder E-Mail an info@hitseller.de', 'de-DE');
$this->setSnippets('desiredAmountNotAvailable.Modal.p2.hitseller', '+49 6898/ 515800 oder E-Mail an info@hitseller.de', 'en-GB');
$this->setSnippets('desiredAmountNotAvailable.OffcanvasModal.p1', 'Bitte beachten Sie, dass die maximale Bestellmenge für diesen Artikel %maxPurchase% Stück beträgt.', 'de-DE');
$this->setSnippets('desiredAmountNotAvailable.OffcanvasModal.p1', 'Bitte beachten Sie, dass die maximale Bestellmenge für diesen Artikel %maxPurchase% Stück beträgt.', 'en-GB');
$this->setSnippets('desiredAmountNotAvailable.OffcanvasModal.storePurchase.p1', 'Bitte beachten Sie, dass die maximale Bestellmenge für diesen Artikel im gewählten Store %maxPurchase% Stück beträgt.', 'de-DE');
$this->setSnippets('desiredAmountNotAvailable.OffcanvasModal.storePurchase.p1', 'Bitte beachten Sie, dass die maximale Bestellmenge für diesen Artikel im gewählten Store %maxPurchase% Stück beträgt.', 'en-GB');
$this->setSnippets('klimasplit.Modal.p1', 'Der Kunde wurde darüber informiert, dass das oben genannte Klimagerät gemäß zwingender rechtlicher Vorgaben (§ 9 Abs. 3 Chemikalien-Klimaschutzverordnung) nur von zertifizierten Fachbetrieben installiert werden darf. Der Verkauf erfolgt ausschließlich unter der Voraussetzung, dass der Kunde die Installation entsprechend beauftragt.', 'de-DE');
$this->setSnippets('klimasplit.Modal.p1', 'Der Kunde wurde darüber informiert, dass das oben genannte Klimagerät gemäß zwingender rechtlicher Vorgaben (§ 9 Abs. 3 Chemikalien-Klimaschutzverordnung) nur von zertifizierten Fachbetrieben installiert werden darf. Der Verkauf erfolgt ausschließlich unter der Voraussetzung, dass der Kunde die Installation entsprechend beauftragt.', 'en-GB');
$this->setSnippets('klimasplit.Modal.p2', 'Der Kunde sichert hiermit verbindlich zu, dies zu tun. Die Wahl des zertifizierten Unternehmens steht dem Kunden frei. Er wird darauf hingewiesen, dass folgendes Unternehmen, der Hersteller des gegenständlichen Gerätes, das erforderliche Zertifikat besitzt und einen Installationsservice anbietet:', 'de-DE');
$this->setSnippets('klimasplit.Modal.p2', 'Der Kunde sichert hiermit verbindlich zu, dies zu tun. Die Wahl des zertifizierten Unternehmens steht dem Kunden frei. Er wird darauf hingewiesen, dass folgendes Unternehmen, der Hersteller des gegenständlichen Gerätes, das erforderliche Zertifikat besitzt und einen Installationsservice anbietet:', 'en-GB');
$this->setSnippets('klimasplit.Modal.p3', 'MIDEA Europe GmbH br
Ludwig-Erhard-Str. 14 br
65760 Eschborn br
Telefon: 06196 - 90 20-0 br
E-Mail: info-meg@midea.com', 'de-DE');
$this->setSnippets('klimasplit.Modal.p3', 'MIDEA Europe GmbH br
Ludwig-Erhard-Str. 14 br
65760 Eschborn br
Telefon: 06196 - 90 20-0 br
E-Mail: info-meg@midea.com', 'en-GB');
$this->setSnippets('klimasplit.Modal.p4', 'Die MIDEA Europe GmbH handelt im eigenen Namen und ist rechtlich unabhängig von der GLOBUS Fachmärkte GmbH & Co. KG. Ein Vertrag zur Installation des Gerätes kommt ggf. ausschließlich zwischen MIDEA und dem Kunden zu Stande.', 'de-DE');
$this->setSnippets('klimasplit.Modal.p4', 'Die MIDEA Europe GmbH handelt im eigenen Namen und ist rechtlich unabhängig von der GLOBUS Fachmärkte GmbH & Co. KG. Ein Vertrag zur Installation des Gerätes kommt ggf. ausschließlich zwischen MIDEA und dem Kunden zu Stande.', 'en-GB');
$this->setSnippets('klimasplit.Modal.p5', 'Gemäß der oben genannten Regelung ist die GLOBUS Fachmärkte GmbH & Co. KG im Falle einer behördlichen Überprüfung verpflichtet, schriftlich nachzuweisen, dass die oben genannten Bedingungen eingehalten wurden. Auf Grundlage des Art. 6 Abs. 1 lit. c EU-DSGVO speichert die GLOBUS Fachmärkte GmbH & Co. KG daher das vorliegende Dokument, um es ggf. der zuständigen Behörde vorlegen zu können. Weitere Hinweise zum Datenschutz entnehmen Sie bitte den ausliegenden Datenschutzhinweisen für Kunden im Markt und unter <a href="https://www.globus-baumarkt.de/datenschutz" target="_blank">https://www.globus-baumarkt.de/datenschutz</a>.', 'de-DE');
$this->setSnippets('klimasplit.Modal.p5', 'Gemäß der oben genannten Regelung ist die GLOBUS Fachmärkte GmbH & Co. KG im Falle einer behördlichen Überprüfung verpflichtet, schriftlich nachzuweisen, dass die oben genannten Bedingungen eingehalten wurden. Auf Grundlage des Art. 6 Abs. 1 lit. c EU-DSGVO speichert die GLOBUS Fachmärkte GmbH & Co. KG daher das vorliegende Dokument, um es ggf. der zuständigen Behörde vorlegen zu können. Weitere Hinweise zum Datenschutz entnehmen Sie bitte den ausliegenden Datenschutzhinweisen für Kunden im Markt und unter <a href="https://www.globus-baumarkt.de/datenschutz" target="_blank">https://www.globus-baumarkt.de/datenschutz</a>.', 'en-GB');
$this->setSnippets('general.shippingInfoFree', 'Versandkostenfrei', 'de-DE');
$this->setSnippets('general.shippingInfoFree', 'Free Shipping', 'en-GB');
$this->setSnippets('general.shippingInfoNotFree', 'zzgl. Versandkosten', 'de-DE');
$this->setSnippets('general.shippingInfoNotFree', 'plus Shipping costs', 'en-GB');
$this->setSnippets('general.shippingTextVat', 'inkl. gesetzl. MwSt.', 'de-DE');
$this->setSnippets('general.shippingTextVat', 'incl. VAT', 'en-GB');
$this->setSnippets('general.shippingTextLink', '/Online-Shop/Versand-Zahlung/', 'de-DE');
$this->setSnippets('general.shippingTextLink', '/Online-Shop/Versand-Zahlung/', 'en-GB');
$this->setSnippets('textil.animalParts','Enthält nichttextile Teile tierischen Ursprungs.','de-DE');
$this->setSnippets('textil.animalParts','Enthält nichttextile Teile tierischen Ursprungs.','en-GB');
$this->setSnippets('orderRepeat.productnotavailable', 'Dieser Artikel kann nicht mehr bestellt werden!','de-DE');
$this->setSnippets('orderRepeat.productnotavailable', 'Dieser Artikel kann nicht mehr bestellt werden!','en-GB');
// TODO-NGS could try to insert values here - or keep this logic in defaultDataservice
}
private function uninstallCheckoutSpecialCases(){
// drop both tables
$connection = $this->container->get('Doctrine\DBAL\Connection');
$coSpclCsTbl = CheckoutSpecialCaseDefinition::ENTITY_NAME;
$connection->exec("DROP TABLE IF EXISTS $coSpclCsTbl");
$connection->exec("DROP TABLE IF EXISTS ianeo_storage_indicator");
// remove snippets
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "deliveryInformation.OnlyBuyAtPlace"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "deliveryInformation.deliveryTime"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "deliveryInformation.readyForPickup"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "reserveInStore.noSelectedStore"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "reserveInStore.articleNotAvailable"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "reserveInStore.articleAvailable"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "checkoutSpecialCase.NotAvailable.Header"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "checkoutSpecialCase.NotAvailable.Message"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "deliveryInformation.manufacturer.text"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "hvc.notice"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "puFoam.notice"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "biocidal.notice"');
}
private function installAvailabilitySnippets(){
$this->setSnippets('store.product.available', 'alle Produkte verfügbar', 'de-DE');
$this->setSnippets('store.product.available', 'alle Produkte verfügbar', 'en-GB');
$this->setSnippets('store.product.partiallyAvailable', '%share% von %total% Produkten verfügbar', 'de-DE');
$this->setSnippets('store.product.partiallyAvailable', '%share% von %total% Produkten verfügbar', 'en-GB');
$this->setSnippets('store.product.unavailable', 'nicht verfügbar', 'de-DE');
$this->setSnippets('store.product.unavailable', 'nicht verfügbar', 'en-GB');
}
private function uninstallAvailabilitySnippets(){
// remove snippets
$connection = $this->container->get('Doctrine\DBAL\Connection');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "store.product.available"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "store.product.partiallyAvailable"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "store.product.unavailable"');
}
private function installCheckoutSnippets(){
$this->setSnippets('switchStore.switchedAll', 'Reservierte Produkte wurden für den ausgewählten Store in den Warenkorb gelegt.', 'de-DE');
$this->setSnippets('switchStore.switchedAll', 'EN_ Reservierte Produkte wurden für den ausgewählten Store in den Warenkorb gelegt.', 'en-GB');
$this->setSnippets('switchStore.removedAll', 'Alle reservierten Produkte wurden aus dem Warenkorb entfernt.', 'de-DE');
$this->setSnippets('switchStore.removedAll', 'EN_ Alle reservierten Produkte wurden aus dem Warenkorb entfernt.', 'en-GB');
$this->setSnippets('switchStore.switchedPartially', 'Verfügbare reservierte Produkte wurden im ausgewählten Store in den Warenkorb gelegt.', 'de-DE');
$this->setSnippets('switchStore.switchedPartially', 'EN_ Verfügbare reservierte Produkte wurden im ausgewählten Store in den Warenkorb gelegt.', 'en-GB');
}
private function uninstallCheckoutSnippets(){
$connection = $this->container->get('Doctrine\DBAL\Connection');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "switchStore.switchedAll"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "switchStore.removedAll"');
$connection->executeUpdate('DELETE FROM `snippet` WHERE translation_key= "switchStore.switchedPartially"');
}
private function installPaymentMethods(InstallContext $installContext)
{
$context = $installContext->getContext();
$paymentRepository = $this->container->get('payment_method.repository');
/** @var PluginIdProvider $pluginIdProvider */
$pluginIdProvider = $this->container->get(PluginIdProvider::class);
$pluginId = $pluginIdProvider->getPluginIdByBaseClass(get_class($this), $context);
$criteria = new Criteria();
$criteria->addFilter(new EqualsFilter('id', IaneoDefaults::PAYMENT_METHOD_ABHOLUNG_ID));
$paymentMethod = $paymentRepository->search($criteria, $context)->first();
if ( $paymentMethod instanceof PaymentMethodEntity) {
return;
}
$paymentRepository->create(
[
[
'id' => IaneoDefaults::PAYMENT_METHOD_ABHOLUNG_ID,
'handlerIdentifier' => AbholungPayment::class,
'translations' => [
'de-DE' => [
'name' => IaneoDefaults::PAYMENT_METHOD_ABHOLUNG_NAME,
'description' => '',
],
'en-GB' => [
'name' => IaneoDefaults::PAYMENT_METHOD_ABHOLUNG_NAME,
'description' => '',
],
],
'pluginId' => $pluginId,
'active' => true
],
], $context);
$criteria = new Criteria();
$criteria->addFilter(new EqualsFilter('id', IaneoDefaults::PAYMENT_METHOD_KAUFLAND_ID));
$paymentMethod = $paymentRepository->search($criteria, $context)->first();
if ( $paymentMethod instanceof PaymentMethodEntity) {
return;
}
$paymentRepository->create(
[
[
'id' => IaneoDefaults::PAYMENT_METHOD_KAUFLAND_ID,
'handlerIdentifier' => KauflandPayment::class,
'translations' => [
'de-DE' => [
'name' => IaneoDefaults::PAYMENT_METHOD_KAUFLAND_NAME,
'description' => '',
],
'en-GB' => [
'name' => IaneoDefaults::PAYMENT_METHOD_ABHOLUNG_NAME,
'description' => '',
],
],
'pluginId' => $pluginId,
'active' => true
],
], $context);
}
}