Um ein neues Einkaufswelt-Element in Shopware 5 zu erstellen, gehen Sie wie folgt vor.
Schritt 1: Erstellen Sie ein neues Unterverzeichnis im Plugin-Verzeichnis.
Dateistruktur
custom>plugins>ShoppingWorldElement

Hinweis: – ShoppingWorldElement ist ein neues Plugin, in dem wir dieses Verzeichnis bearbeiten, um ein neues Shopping World Element zu erstellen.
Schritt 2: Erstellen Sie ShoppingWorldElement.php im Verzeichnis ShoppingWorldElement.

Schritt 3: Schreiben Sie diesen Code in die Datei ShoppingWorldElement.php.
<?php
namespace ShoppingWorldElement;
use Shopware\Components\Plugin;
class ShoppingWorldElement extends Plugin
{
public static function getSubscribedEvents()
{
}
}
Schritt 4: Gehen Sie zur Verwaltungskonsole (Backend), und Configuration>Plugin Manager. Um zu sehen, ob das ShoppingWorldElement-Plugin funktioniert oder nicht.

Schritt 5: Klicken Sie auf das Bleistiftsymbol, um das Plugin zu installieren und zu aktivieren.

Schritt 6: Nachdem Sie das Plugin aktiviert haben, gehen Sie zu der Datei ShoppingWorldElement.php und schreiben Sie diesen Code in diese Datei.
<?php
namespace ShoppingWorldElement;
use Shopware\Components\Plugin;
use Shopware\Components\Plugin\Context\ActivateContext;
use Shopware\Components\Plugin\Context\DeactivateContext;
use Shopware\Components\Plugin\Context\InstallContext;
use Shopware\Components\Plugin\Context\UninstallContext;
use ShoppingWorldElement\Bootstrap\EmotionElementInstaller;
class ShoppingWorldElement extends Plugin
{
public function install(InstallContext $installContext)
{
$emotionElementInstaller = new EmotionElementInstaller(
$this->getName(),
$this->container->get(’shopware.emotion_component_installer‘)
);
$emotionElementInstaller->install();
}
public function activate(ActivateContext $activateContext)
{
$activateContext->scheduleClearCache(ActivateContext::CACHE_LIST_ALL);
}
public function deactivate(DeactivateContext $deactivateContext)
{
$deactivateContext->scheduleClearCache(DeactivateContext::CACHE_LIST_ALL);
}
public function uninstall(UninstallContext $uninstallContext)
{
$uninstallContext->scheduleClearCache(UninstallContext::CACHE_LIST_ALL);
}
}
Schritt 7: Erstellen Sie die Datei plugin.xml im Verzeichnis ShoppingWorldElement.

Schritt 8: Gehen Sie zur Datei plugin.xml und schreiben Sie diesen Code.
<?xml version="1.0" encoding="utf-8"?>
<plugin xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="https://raw.githubusercontent.com/shopware/shopware/5.3/engine/Shopware/Components/Plugin/schema/plugin.xsd">
<label lang="en">Shopping World Element</label>
<version>1.0.0</version>
<copyright>(c) Bay 20</copyright>
<license>MIT</license>
<link>http://store.shopware.com</link>
<author>Bay 20</author>
<compatibility minVersion="5.3.0"/>
<changelog version="1.0.0">
<changes lang="en">New release</changes>
</changelog>
</plugin>
Schritt 9: Erstellen Sie den Ordner Boostrap im Verzeichnis ShoppingWorldElement.

Schritt 10: Erstellen Sie EmotionElementInstaller.php im Bootstrap-Verzeichnis.

Schritt 11: Schreiben Sie diesen Code in die Datei EmotionElementInstaller.php. Dies ist ein Konfigurationsfeld für das Element.
<?php
namespace ShoppingWorldElement\Bootstrap;
use Shopware\Components\Emotion\ComponentInstaller;
class EmotionElementInstaller
{
/**
* @var ComponentInstaller
*/
private $emotionComponentInstaller;
/**
* @var string
*/
private $pluginName;
/**
* @param string $pluginName
* @param ComponentInstaller $emotionComponentInstaller
*/
public function __construct($pluginName, ComponentInstaller $emotionComponentInstaller)
{
$this->emotionComponentInstaller = $emotionComponentInstaller;
$this->pluginName = $pluginName;
}
public function install()
{
$vimeoElement = $this->emotionComponentInstaller->createOrUpdate(
$this->pluginName,
'ShoppingWorldElement',
[
'name' => 'Vimeo Video',
'xtype' => 'emotion-components-vimeo',
'template' => 'emotion_vimeo',
'cls' => 'emotion-vimeo-element',
'description' => 'A simple vimeo video element for the shopping worlds.'
]
);
$vimeoElement->createTextField([
'name' => 'vimeo_video_id',
'fieldLabel' => 'Video ID',
'supportText' => 'Enter the ID of the video you want to embed.',
'allowBlank' => false
]);
$vimeoElement->createHiddenField([
'name' => 'vimeo_video_thumbnail'
]);
$vimeoElement->createTextField([
'name' => 'vimeo_interface_color',
'fieldLabel' => 'Interface Color',
'supportText' => 'Enter the #hex color code for the video player interface.',
'defaultValue' => '#0096FF'
]);
$vimeoElement->createCheckboxField([
'name' => 'vimeo_autoplay',
'fieldLabel' => 'Autoplay',
'defaultValue' => false
]);
$vimeoElement->createCheckboxField([
'name' => 'vimeo_loop',
'fieldLabel' => 'Loop',
'defaultValue' => false
]);
$vimeoElement->createCheckboxField([
'name' => 'vimeo_show_title',
'fieldLabel' => 'Show title',
'defaultValue' => false
]);
$vimeoElement->createCheckboxField([
'name' => 'vimeo_show_portrait',
'fieldLabel' => 'Show portrait',
'defaultValue' => false
]);
$vimeoElement->createCheckboxField([
'name' => 'vimeo_show_author',
'fieldLabel' => 'Show author',
'defaultValue' => false
]);
}
}
Schritt 12: Erstellen Sie den Ordner Resources im Verzeichnis ShoppingWorldElement.

Schritt 13: Im Verzeichnis Resources. Erstellen Sie 3 neue Unterordner (Snippets>Backend>Emotion) und erstellen Sie im Ordner emotion die Datei shopping_world_element.ini.
Dateistrukturen
Resources>snippets>backend>emotion>shopping_world_element.ini

Schritt 14: In die Datei shopping_world_element.ini schreiben Sie diesen Code.
[en_GB]
interfaceColorFieldLabel = "Interface Color"
interfaceColorSupportText = "Enter the #hex color code for the video player interface."
[de_DE]
interfaceColorFieldLabel = "Interface Farbe"
interfaceColorSupportText = "Gib den #hex Farbcode für das Video Player Interface ein."
Schritt 15: Erstellen Sie im Ordner Resources ein neues Unterverzeichnis mit dem Namen views.

Schritt 16: Erstellen Sie im Ordner views 6 neue Unterverzeichnisse (backend>emotion>shopping_world_element>view>detail>elements) und im Ordner elements erstellen Sie vimeo_video.js

Schritt 17: Schreiben Sie diesen Code in viemo_video.js
//
//{block name="backend/emotion/view/detail/elements/base"}
//{$smarty.block.parent}
Ext.define('Shopware.apps.Emotion.view.detail.elements.VimeoVideo', {
/**
* Extend from the base class for the grid elements.
*/
extend: 'Shopware.apps.Emotion.view.detail.elements.Base',
/**
* Create the alias matching with the xtype you defined for your element.
* The pattern is always 'widget.detail-element-' + xtype
*/
alias: 'widget.detail-element-emotion-components-vimeo',
/**
* You can define an additional CSS class which will be used for the grid element.
*/
componentCls: 'emotion--vimeo-video',
/**
* Define the path to an image for the icon of your element.
* You could also use a base64 string.
*/
icon: '',
/**
* You can override the original `createPreview()` method
* to create a custom grid preview for your element.
*
* @returns { string }
*/
createPreview: function () {
var me = this,
preview = '',
image = me.getConfigValue('vimeo_video_thumbnail'),
style;
if (Ext.isDefined(image)) {
style = Ext.String.format('background-image: url([0]);', image);
preview = Ext.String.format('<div class="x-emotion-banner-element-preview" style="[0]"></div>', style);
}
return preview;
}
});
//{/block}
Schritt 18: Erstellen Sie den Ordner emotion_components im Verzeichnis views.

Schritt 19: Erstellen Sie im Ordner emotion_components einen neuen Unterordner mit dem Namen backend und erstellen Sie im Backend eine neue Datei viemo_video.js.

Schritt 20: Schreiben Sie diesen Code in die Datei viemo_video.js.
// {namespace name=“backend/emotion/shopping_world_element“}
//{block name=“emotion_components/backend/vimeo_video“}
Ext.define(‚Shopware.apps.Emotion.view.components.VimeoVideo‘, {
/**
* Extend from the base class for the emotion components
*/
extend: 'Shopware.apps.Emotion.view.components.Base',
/**
* Create the alias matching the xtype you defined in your `createEmotionComponent()` method.
* The pattern is always 'widget.' + xtype
*/
alias: 'widget.emotion-components-vimeo',
/**
* Contains the translations of each input field which was created with the EmotionComponentInstaller.
* Use the name of the field as identifier
*/
snippets: {
'vimeo_interface_color': {
'fieldLabel': '{s name=interfaceColorFieldLabel}{/s}',
'supportText': '{s name=interfaceColorSupportText}{/s}'
}
},
/**
* The constructor method of each component.
*/
initComponent: function () {
var me = this;
/**
* Call the original method of the base class.
*/
me.callParent(arguments);
/**
* Get single fields you've created with the helper functions in your `Bootstrap.php` file.
*/
me.videoThumbnailField = me.getForm().findField('vimeo_video_thumbnail');
me.videoIdField = me.getForm().findField('vimeo_video_id');
/**
* For example you can register additional event listeners on your fields to handle some data.
*/
me.videoIdField.on('change', Ext.bind(me.onIdChange, me));
},
/**
* Event listener for the change event of the video id field.
*
* @param field
* @param value
*/
onIdChange: function (field, value) {
var me = this;
me.setVimeoPreviewImage(value);
},
/**
* Does a request to the vimeo api to get the preview image of the video.
* We will use the hidden input field we created via the helper functions to
* store the data we receive from the api.
*
* @param vimeoId
* @returns { boolean }
*/
setVimeoPreviewImage: function (vimeoId) {
var me = this;
if (!vimeoId) {
return false;
}
/**
* Create the url to the correct api endpoint for the given video id.
*/
var url = Ext.String.format('https://vimeo.com/api/v2/video/[0].json', vimeoId),
xhr = new XMLHttpRequest(),
response;
/**
* Request additional information about the video.
*/
xhr.onreadystatechange = function () {
if (xhr.readyState === 4 && xhr.status === 200) {
response = Ext.JSON.decode(xhr.responseText);
/**
* Save the preview image in the hidden input field.
*/
if (response[0]) {
me.videoThumbnailField.setValue(response[0]['thumbnail_large']);
}
}
};
xhr.open('GET', url, true);
xhr.send();
}
});
//{/block}
Schritt 21: Erstellen Sie im Ordner emotion_components einen neuen Unterordner widgets.

Schritt 22: Erstellen Sie im Ordner widgets 2 neue Unterordner (emotion>components) und erstellen Sie im Ordner components eine Datei mit dem Namen emotion_viemo.tpl

Schritt 23: Schreiben Sie diesen Code in die Datei emotion_viemo.tpl.
{block name="widgets_emotion_components_vimeo_element"}
{$videoURL = "https://player.vimeo.com/video/{$Data.vimeo_video_id}?color={$Data.vimeo_interface_color|substr:1}"}
{if !$Data.vimeo_show_title}
{$videoURL = "{$videoURL}&title=0"}
{/if}
{if !$Data.vimeo_show_portrait}
{$videoURL = "{$videoURL}&portrait=0"}
{/if}
{if !$Data.vimeo_show_author}
{$videoURL = "{$videoURL}&byline=0"}
{/if}
{if $Data.vimeo_loop}
{$videoURL = "{$videoURL}&loop=1"}
{/if}
{if $Data.vimeo_autoplay}
{$videoURL = "{$videoURL}&autoplay=1"}
{/if}
<iframe src="{$videoURL}"
width="100%"
height="100%"
frameborder="0"
webkitallowfullscreen
mozallowfullscreen
allowfullscreen>
</iframe>
{/block}
Schritt 24: Erstellen Sie die Datei config.xml im Ordner Resources.

Schritt 25: Schreiben Sie diesen Code in die Datei config.xml.

Schritt 26: Erstellen Sie die Datei services.xml im Ordner Resources.

Schritt 27: Schreiben Sie diesen Code in die Datei services.xml.

Schritt 28: Erstellen Sie einen neuen Unterordner Subscriber im Verzeichnis ShoppingWorldElement.

Schritt 29: Erstellen Sie im Ordner Subscriber eine neue Datei namens TemplateRegistration.php

Schritt 30: Schreiben Sie diesen Code in die Datei TemplateRegistration.php.
<?php
namespace ShoppingWorldElement\Subscriber;
use Enlight\Event\SubscriberInterface;
use Enlight_Controller_ActionEventArgs;
class TemplateRegistration implements SubscriberInterface
{
/**
* @var string
*/
private $pluginDirectory;
/**
* @param $pluginDirectory
*/
public function __construct($pluginDirectory)
{
$this->pluginDirectory = $pluginDirectory;
}
/**
* {@inheritdoc}
*/
public static function getSubscribedEvents()
{
return [
'Enlight_Controller_Action_PostDispatchSecure_Backend_Emotion' => 'onPostDispatchBackendEmotion'
];
}
/**
* @param \Enlight_Controller_ActionEventArgs $args
*/
public function onPostDispatchBackendEmotion(\Enlight_Controller_ActionEventArgs $args)
{
$view = $args->getSubject()->View();
$view->addTemplateDir($this->pluginDirectory . '/Resources/views');
$view->extendsTemplate('backend/emotion/shopping_world_element/view/detail/elements/vimeo_video.js');
}
}
Schritt 31: Gehen Sie nun in die Verwaltungskonsole und wählen Sie Marketing>Einkaufswelten.

Schritt 31: Klicken Sie auf das Bleistiftsymbol der Einkaufswelt.

Schritt 32: Klicken Sie auf die Option Elemente. Und Sie können Ihr neues benutzerdefiniertes Shopping-Element verwenden.

Schritt 33: Ziehen Sie das Element und klicken Sie auf das Stiftsymbol, um das Element zu bearbeiten.

Schritt 34: Geben Sie die Video-ID ein und wählen Sie eine Option, die Sie verwenden möchten.

Schritt 35: Nachdem Sie diesen Vorgang gespeichert haben, gehen Sie zum Front-Store und sehen Sie nach, ob das benutzerdefinierte Element funktioniert oder nicht.

Bitte kontaktieren Sie uns unter manish@bay20.com oder rufen Sie uns unter +91-8800519180 an, wenn Sie Unterstützung zu Shopware 5 und Shopware 6 benötigen. Sie können auch die Shopware-Entwicklungsseite besuchen, um die von uns angebotenen Dienstleistungen zu prüfen.






