 
        At the frontend, the AJAX-ZOOM module for Shopware 5 is based on responsive mouseover zoom + optional 360°. However, starting from the plugin's version 1.2.4, there is an exclusive option for Shopware 5 customers to inject only the AJAX-ZOOM 360-degree player directly into the default product image slider.
At the backend, administrators can upload several 360s or import them from ZIP files and folders, which were previously uploaded, e.g., via FTP.
Each 360° view can be configured with separate AJAX-ZOOM settings and attached to a properties combination. For standard images, there are no changes required.
There are several options in the plugin configuration area for adjusting and fine-tuning the plugin's appearance. One of those options is especially interesting because it allows you to test the plugin without affecting the entire website. With the "displayOnlyForThisProductID", you can specify to show AJAX-ZOOM only for a few products and perform the tests you need.
Under the menu Items -> AJAX-ZOOM, there is a dedicated list with all main articles where you overview the amount of 360-degree views and videos. Using the search field, you can quickly find the article you are looking for. Clicking on an article name takes you to the area where you can upload 360-views and videos.
Creating a new 360/3D degree product view is very easy. While creating a new entry, you can immediately select a ZIP file that has been previously uploaded to a specific "ZIP" directory, e.g., via FTP. During the creation of the entry, the plugin unpacks the image files from the selected ZIP archive and places them within the plugin structure.
Alternatively, you can upload the images directly via the backend interface. The upload interface appears immediately after a new entry for the 360-item is created.
After creating a 360 and uploading the images, you can change or define several settings. For a product with variations, you have the option to assign a 360 only to specific variations. It is also possible to set nearly all settings of the AJAX-ZOOM player for each 360-degree object individually, create hotspots and product tours (see below).
If from internal or external production of the 360-views, you have many 360 items available at once, you can use the 360-batch-import function of the plugin. Switch to Administration -> Batch Import 360. There, you find the convention of how the ZIP files with 360 images must be named to be automatically imported and assigned to the associated product numbers or IDs. This automation saves you enormous amounts of time and thus costs.
The 360 "Product Tour" Editor is straightforward to use. Select areas of interest in a 360/3D view and press the crop button. The editor automatically creates thumbnails of those areas and places them in the separate gallery slider. When the user clicks on a thumbnail, the player rotates and zooms that 360-view to the selected region. You can choose from several predefined animation options. At the front end, the thumbnail gallery looks a bit different than in the editor.
Furthermore, administrators have an option to provide multilingual titles and descriptions for the selected areas. The title automatically appears as an expandable button after the rotation and zooming animation ends. If a title is defined, the user can click on the button to expand it and see the full description. The description data may include HTML and, therefore, any content, including, e.g., YouTube videos, whereby the editor provides a shortcode for YouTube videos and iframes, so you don't need to write HTML for those.
So if you quickly want to highlight anything on a 360-view, you can do it fast with the help of the "Product Tour" Editor. After a bit of practicing, it is a matter of seconds to create such professional presentations.
Compared to the "Product Tour", the operation of the hotspot editor is more complicated. That is because there are far more possibilities to design the hotspots. Anyway, it takes a lot of training to work with the editor without stress.
The hotspots are generally about defining the position of these markers in the image and providing them with interaction. For a 360-degree view, you first have to place a hotspot on individual frames of a 360 view. You can do this roughly by dragging and dropping via thumbnails overview, later positioning them in the AJAX-ZOOM Player, also using Drag & Drop. Then choose the look. Predefined are several PNG icons or CSS classes.
When the positioning is done, you can create a label and, if necessary, a connecting line between the hotspot and the label. There are many (many) predefined design options.
Finally, if you want something to happen when you click on a hotspot, you can set an interaction. There are predefined interactions like a link or, similar to the product tour, a layered window with multilingual definable content, YouTube videos, etc. You can also define your JavaScript function and let everything happen on click.
There are many other exciting features, such as displaying certain hotspots (groups) only at a specific zoom level - engaging in the context of the product tour, both working together very well.
If you are not under time pressure, you should look into the Hotspot Editor, and you will discover a variety of possibilities, which are limited only by your imagination. There is nothing comparable on the market.
The AJAX-ZOOM plugin for Shopware has sophisticated management of videos. You can add videos in addition to or instead of 360-degree views. You can define videos from Youtube, Vimeo, Dailymotion, or link directly toMP4 files. As a cloud for MP4 sources, you can use, e.g., Vimeo. They offer it as a paid service.
The plugin gives an overview of all the videos and products to which these videos are linked. For each language, you can optionally define a different video source.
You can maintain the video data by adding and deleting them manually via the backend. Alternatively, you can create an Excel file with all the necessary data and synchronize it with the database. The corresponding functionality is built-in into the backend management too.
For each video, you can upload a preview image or interactively extract a frame from MP4 videos that you want to have as a preview image for the video.
Lastly, it is possible to create an XML file from present data and submit it to Google manually or via a cronjob if video SEO matters.
You do not necessarily have to use the batch tool because if image tiles and other AJAX-ZOOM caches are not present, AJAX-ZOOM generates them on the fly. That can happen when images are loaded into the player as "preview" at the backend or appear on the product detail page.
However, if you have thousands of images, it is a good idea to batch process all existing images, which you plan to show in the AJAX-ZOOM viewer, before launching a new website or before enabling AJAX-ZOOM at the frontend. With the latest batch file, it is possible to cover up to 100% of all caches, which AJAX-ZOOM would otherwise generate on the fly if not present.
Periodically, when you add 360 / 3D images to your already existing or new products, you can keep the 360 / 3D sets disabled and let the batch tool process any amount of 360 sets at the end of the day. The batch tool can automatically activate a 360 / 3D set after it finishes processing.
Please click the buttons at the top of this page to see the live links to the screenshots below! The screenshots below show Shopware's product detail page when AJAX-ZOOM is fully enabled via a plugin option.
These are views when the Shopware default slider is activated per option. You can let AJAX-ZOOM inject the 360-views and videos into the default Shopware product view slider. All unique possibilities like product tours or hotspots are preserved.
AJAX-ZOOM product tours can be used with both the AJAX-ZOOM mouseover player and the default Shopware product view slider.
You can display AJAX-ZOOM 360-degree / 3D views, as well as videos optionally in tabs. The new tab is automatically created whenever a 360-degree view or a video is present for a product.
For the regular images, there is no need to change anything. When product images are displayed with the AJAX-ZOOM mouseover/slider, you can optionally place hotspots (clickable markers in the image) on regular images. This is done with the same editor, which is also used for 360-degree animations:
To add 360° images, switch to the 'Items' -> 'AJAX-ZOOM' panel and select a product.
	Alternatively, log in as an administrator in the browser and in new tab
	call www.your-domain.com/backend/AjaxZoom.
	There you will be able to:
/engine/Shopware/Plugins/Community/Frontend/AjaxZoom/zip directory and can be removed later.
	/engine/Shopware/Plugins/Community/Frontend/AjaxZoom/axZm" directory.
		If allow_url_fopen is disabled, you will have to do it manually; see "Troubleshooting" section on this page.
	/engine/Shopware/Plugins/Community/Frontend/AjaxZoom/axZm.
	/engine/Shopware/Plugins/Community/Frontend/AjaxZoom//engine/Shopware/Plugins/Community/Frontend/AjaxZoom/axZm/engine/Shopware/Plugins/Community/Frontend/AjaxZoom/pic is writable by PHP (e.g. chmod 0775)Please see installation steps above. Proceed with manual installation.
$_SERVER['PHP_AUTH_PW'] / $_SERVER['PHP_AUTH_USER']
	are not set.
	This is because integrating the editors in the backend required to use "cUrl" internally, meaning that the server accesses itself via http(s).
	To allow it to do so, its server IP, that is, where Shopware is running, must be excluded from password entry.
	Under Apache, you can rule out the own server IP like this
AuthType Basic
Require valid-user
AuthName "Please enter password"
AuthUserFile /www/passwords/.passwd
Allow from xxx.xxx.xxx.xxx
Satisfy Any
If Shopware is managed over external tools (not via Backend) and item images are replaced keeping the same file name, then AJAX-ZOOM does not get notified of that action, and AJAX-ZOOM cache is not cleared for this image. With the Ver. 1.2.3+, we have implemented several CLI commands to clear AJAX-ZOOM cache for all images of an item or specific (named) image files. Please configure your external tools accordingly (call CLI command over API) when an image file is replaced or an item is deleted. For more information in CLI, please see https://en.community.shopware.com/_detail_1653.html
As a temporal solution, you could add the following config parameters to/engine/Shopware/Plugins/Community/Frontend/AjaxZoom/zoomConfigCustomAZ.inc.php
$zoom['config']['cTimeCompare'] = 'filectime';
$zoom['config']['dynamicThumbsCtime'] = 'filectime';
	/engine/Shopware/Plugins/Community/Frontend/AjaxZoom
		with the last AJAX-ZOOM Plugin for Shopware version.
	/engine/Shopware/Plugins/Community/Frontend/AjaxZoom/axZm
		with the latest AJAX-ZOOM version.
	ionCube loader is a widely used PHP extension, and it is required to operate AJAX-ZOOM on your server.
	Before installing the loader, please check if it is not already installed on your server.
	To check this, you can look into the output of phpinfo();.
	You can also use get_loaded_extensions PHP function - print_r( get_loaded_extensions() );
	to see if ionCube is installed.
If you do not detect ionCube on your server, please visit the official ionClube loaders page. There you can find "Loader Installer" and "Loader Wizard" packages, which can guide you through the installation process matching your operating system (Windows, Linux, FreeBSD, OpenBSD, OS X, Solaris).
Many hosting companies also have a guide in their FAQ on how to do this specifically for their configurations. Lastly, a mail to your hosting provider's support surely helps. ionCube is industry standard and should be a copy & paste answer for your hosting provider. If not, you should switch your hosting provider immediately.
Please note that each PHP version requires a different loader extension. When your provider offers a possibility to switch between several PHP versions, and you have added the "ionCube" extension via a separate php.ini on your own, please think about updating this php.ini file to link to the appropriate "ionCube" extension file.
Restarting the server (e.g., Apache) might be needed for the new extension to load (changes in php.ini effectively occur).
Some shared hosting companies such as "1&1" allow the users without root access to create their custom php.ini files
	and "install" Ioncube loader this way.
	However, this custom php.ini has only an effect on the folder whereinto you place it.
	It has no impact on subfolders, as you might suspect.
	Therefore, if you are dealing with this method of installing the loader, you must copy your custom php.ini into several folders.
	If the AJAX-ZOOM module for your system installs itself into, e.g., /modules/ajaxzoom directory,
	you must place the custom php.ini into /modules/ajaxzoom/axZm/ folder and
	into, e.g., /admin12345/ folder (or wherever installing the modules takes place).
No, AJAX-ZOOM should work out of the box. For some modules/plugins, AJAX-ZOOM does not install itself if the "ionCube" extension is not present on the server (see above). Other than that, there is are limitations on the number of images and image resolution of the demo version. If you would like to test AJAX-ZOOM with higher resolution images ( > 3.2 megapixels / million pixels), please request an "Evaluation" license key for your dev domain or subdomain free of charge.
If you do not have a development server but would like to install the AJAX-ZOOM plugin on your production website, you should go to module/plugin settings and set the "displayOnlyForThisProductID" option. This option allows you to enable AJAX-ZOOM only for specified product ID, so you can test the module/plugin thoroughly without affecting the entire shop / conduct A/B tests.
The translation of the strings is done via the plugin options and within the AJAX-ZOOM's core PHP configuration file.
1. All plugin options are accessed over the backend. For example, if you want to add Russian translation to the "zoomMsg360" option, which is defined as JSON, you would need to add "key" and "value" to this JSON.
    
{
    "en": "Drag to spin 360°, scroll to zoom in and out, right-click and drag to pan",
    "de": "Ziehen um 360° zu drehen, zoomen mit dem Mausrad, rechte Maustaste ziehen verschiebt die Ansicht",
    "fr": "Faites glisser pour tourner à 360 °, faites défiler pour zoomer dans et hors, cliquer et faire glisser à droite pour vous déplacer",
    "es": "Arrastrar para girar en 360º, Rueda del ratón para utilizar el Zoom, botón derecho para mover la imagen"
}
    
So when you only need English as the default language (please keep it) and want to add a Russian translation string, you would change this option to
    
{
    "en": "Drag to spin 360°, scroll to zoom in and out, right-click and drag to pan",
    "ru": "Крутить 360° левой кнопкой мыши, колесом увеличивать, правой кнопкой смещать zoom"
}
    
2. Some other text strings are located in [ajaxzoom plugin directory] /axZm/zoomConfig.inc.php file,
	which is part of AJAX-ZOOM core. Open this file in a text editor and find a string you are looking for.
	For example, you are looking for the "Click to load" message.
	It is located under $zoom['config']['spinNoInit'] option and looks like this:
    
$zoom['config']['spinNoInit'] = array(
    'enabled' => false,
    'file' => array('en' => 'click_to_load_en.png', 'de' => ''),
    'txt' => array(
        'en' => 'Click to load
360°
 view',
        'de' => 'Klicken um die
360° Ansicht
zu laden'
    ),
    'event' => 'click'
);
    
As you can see, this is a PHP array, and there are several other suboptions located in it.
	The best way to proceed is to either copy the entire array into zoomConfigCustomAZ.inc.php
	or copy only the suboption with locales into this file.
	You can find zoomConfigCustomAZ.inc.php outside of the /axZm folder in the plugin directory.
2a. The below is what you would add to [ajaxzoom plugin directory] /zoomConfigCustomAZ.inc.php file
	when you copy the entire array and add your translation, removing languages you do not need:
    
$zoom['config']['spinNoInit'] = array(
    'enabled' => true,
    'file' => array('en' => 'click_to_load_en.png', 'de' => ''),
    'txt' => array(
        'en' => 'Click to load
360°
 view',
        'ru' => 'Нажмите мышкой, чтоб загрузить 360° вид'
    ),
    'event' => 'click'
);
    
2b. Or you could just add the suboption to [ajaxzoom plugin directory] /zoomConfigCustomAZ.inc.php file  like this:
    
$zoom['config']['spinNoInit']['txt'] = array(
    'en' => 'Click to load
360°
 view',
    'ru' => 'Нажмите мышкой, чтоб загрузить 360° вид'
);
// or
$zoom['config']['spinNoInit']['txt']['ru'] = 'Нажмите мышкой, чтоб загрузить 360° вид';
    
/zoomConfigCustomAZ.inc.php one level up,
	outside of the "ajaxzoom" plugin directory, so when you update the plugin, this file does not get overwritten.
3. There is also a third possibility of adding a translation to strings located in
	[ajaxzoom plugin directory] /axZm/zoomConfig.inc.php.
	In the backend, under plugin configuration, you can find "azOptions" and "azOptions360",
	which allow you to override configuration from [ajaxzoom plugin directory] /axZm/zoomConfig.inc.php
	related to frontend display. If we wanted to do the same as above over "azOptions360" plugin option
	(which is saved into the database), the result in your textarea would look like this:
Here, we do not need to define English, as the related JavaScript object will get extended by what you define in "azOptions360".
	The possibility number 2 above (writing into [ajaxzoom plugin directory] /zoomConfigCustomAZ.inc.php)
	is not applied then.
There is no need to order AJAX-ZOOM before you have successfully installed and tested it! You can test in the test environment as long as necessary.
Since 2017, the AJAX-ZOOM plugin for shopware is also available in Shopware Plugin Store. If you purchase the plugin there, please contact us via the contact form, so that we can issue you the license key.
AJAX-ZOOM main files are downloaded automatically when the plugin is installed. If you want to manually install the AJAX-ZOOM Plugin for Shopware, see the installation steps above.
The license price primarily depends on the number of different images, which are displayed on a domain in the AJAX-ZOOM viewer. If you have sub-shops and all sub-shops are operated on the same server, then the license of each sub-shop must be able to cover all different images or images of the 360 (depending on what you use AJAX-ZOOM for) for all subshops. However, the multistore price regulation can reduce the license costs. For the complete license agreement, please visit the download section.
Added COLLATE=utf8_unicode_ci when database tables are created.
					
To use the live support chat, MS Teams is required. If live support via MS Teams is not available immediately, please leave us a message or send an email using the contact form.
We respond to every inquiry or question related to the AJAX-ZOOM software!
 
 
                                
Also to mention: great and dedicated support. Vadim reacts extremely fast, has tips and solutions for any issue that might occur.