Install the Category Image feature
Edit on GitHubThis document describes how to install the Category Image feature.
Install feature core
Follow the steps below to install the Category Image feature core.
Prerequisites
Install the required features:
NAME | VERSION | INSTALLATION GUIDE |
---|---|---|
Spryker Core | 202404.0 | Install the Spryker Core feature |
Category | 202404.0 |
1) Install the required modules
composer require spryker-feature/category-image:"202404.0" --update-with-dependencies
Make sure the following modules have been installed:
MODULE | EXPECTED DIRECTORY |
---|---|
CategoryImage | vendor/spryker/category-image |
CategoryImageGui | vendor/spryker/category-image-gui |
CategoryImageStorage | vendor/spryker/category-image-storage |
CategoryExtension | vendor/spryker/category-extension |
2) Set up database schema and transfer objects
- Adjust the schema definition so entity changes can trigger events.
AFFECTED ENTITY | TRIGGERED EVENTS |
---|---|
spy_category_image_set | Entity.spy_category_image_set.create Entity.spy_category_image_set.update Entity.spy_category_image_set.delete |
spy_category_image | Entity.spy_category_image_set.create Entity.spy_category_image_set.update Entity.spy_category_image_set.delete |
spy_category_image_set_to_category_image | Entity.spy_category_image_set_to_category_image.create Entity.spy_category_image_set_to_category_image.update Entity.spy_category_image_set_to_category_image.delete |
src/Pyz/Zed/CategoryImage/Persistence/Propel/Schema/spy_category_image.schema.xml
<?xml version="1.0"?>
<database xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" name="zed" xsi:noNamespaceSchemaLocation="http://static.spryker.com/schema-01.xsd" namespace="Orm\Zed\CategoryImage\Persistence" package="src.Orm.Zed.CategoryImage.Persistence">
<table name="spy_category_image_set">
<behavior name="event">
<parameter name="spy_category_image_set_all" column="*"/>
</behavior>
</table>
<table name="spy_category_image">
<behavior name="event">
<parameter name="spy_category_image_all" column="*"/>
</behavior>
</table>
<table name="spy_category_image_set_to_category_image">
<behavior name="event">
<parameter name="spy_category_image_set_to_category_image_all" column="*"/>
</behavior>
</table>
</database>
- Set up synchronization queue pools so that non-multi-store entities (not store-specific entities) are synchronized among stores:
src/Pyz/Zed/CategoryImageStorage/Persistence/Propel/Schema/spy_category_image_storage.schema.xml
<?xml version="1.0"?>
<database xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
name="zed"
xsi:noNamespaceSchemaLocation="http://static.spryker.com/schema-01.xsd"
namespace="Orm\Zed\CategoryImageStorage\Persistence"
package="src.Orm.Zed.CategoryImageStorage.Persistence">
<table name="spy_category_image_storage">
<behavior name="synchronization">
<parameter name="queue_pool" value="synchronizationPool" />
</behavior>
</table>
</database>
- Apply database changes and generate entity and transfer changes:
console propel:install
console transfer:generate
Make sure that the following changes have been applied by checking your database.
DATABASE ENTITY | TYPE | EVENT |
---|---|---|
spy_category_image_set | table | created |
spy_category_image | table | created |
spy_category_image_set_to_category_image | table | created |
spy_category_image_storage | table | created |
Make sure that propel entities have been generated successfully by checking their existence. Also, change the generated entity classes to extend from Spryker core classes.
CLASS PATH | EXTENDS |
---|---|
src/Orm/Zed/CategoryImage/Persistence/Base/SpyCategoryImage.php | Spryker\Zed\CategoryImage\Persistence\Propel\AbstractSpyCategoryImage |
src/Orm/Zed/CategoryImage/Persistence/Base/SpyCategoryImageQuery.php | Spryker\Zed\CategoryImage\Persistence\Propel\AbstractSpyCategoryImageQuery |
src/Orm/Zed/CategoryImage/Persistence/Base/SpyCategoryImageSet.php | Spryker\Zed\CategoryImage\Persistence\Propel\AbstractSpyCategoryImageSet |
src/Orm/Zed/CategoryImage/Persistence/Base/SpyCategoryImageSetQuery.php | Spryker\Zed\CategoryImage\Persistence\Propel\AbstractSpyCategoryImageSetQuery |
src/Orm/Zed/CategoryImage/Persistence/Base/SpyCategoryImageSetToCategoryImage.php | Spryker\Zed\CategoryImage\Persistence\Propel\AbstractSpyCategoryImageSetToCategoryImage |
src/Orm/Zed/CategoryImage/Persistence/Base/SpyCategoryImageSetToCategoryImageQuery.php | Spryker\Zed\CategoryImage\Persistence\Propel\AbstractSpyCategoryImageSetToCategoryImageQuery |
src/Orm/Zed/CategoryImageStorage/Persistence/Base/SpyCategoryImageStorage.php | Spryker\Zed\CategoryImageStorage\Persistence\Propel\AbstractSpyCategoryImageStorage |
src/Orm/Zed/CategoryImageStorage/Persistence/Base/SpyCategoryImageStorageQuery.php | Spryker\Zed\CategoryImageStorage\Persistence\Propel\AbstractSpyCategoryImageStorageQuery |
Make sure that the following changes have been implemented in transfer objects:
TRANSFER | TYPE | EVENT | PATH |
---|---|---|---|
CategoryImageSet | class | created | src/Generated/Shared/Transfer/CategoryImageSetTransfer.php |
CategoryImage | class | created | src/Generated/Shared/Transfer/CategoryImageTransfer.php |
Category | class | created | src/Generated/Shared/Transfer/CategoryTransfer.php |
CategoryCriteria | class | created | src/Generated/Shared/Transfer/CategoryCriteriaTransfer.php |
CategoryCollection | class | created | src/Generated/Shared/Transfer/CategoryCollectionTransfer.php |
Pagination | class | created | src/Generated/Shared/Transfer/PaginationTransfer.php |
3) Configure export to Redis
To configure export to Redis, follow steps in the subsections.
Set up event listeners
In this step, you enable publishing of table changes—create, edit, delete to spy_category_image_storage
and synchronization of data to Storage.
PLUGIN | SPECIFICATION | PREREQUISITES | NAMESPACE |
---|---|---|---|
CategoryImageStorageEventSubscriber | Registers listeners that are responsible for publishing category image information to storage when a related entity changes. | None | Spryker\Zed\CategoryImageStorage\Communication\Plugin\Event\Subscriber |
src/Pyz/Zed/Event/EventDependencyProvider.php
<?php
namespace Pyz\Zed\Event;
use Spryker\Zed\CategoryImageStorage\Communication\Plugin\Event\Subscriber\CategoryImageStorageEventSubscriber;
use Spryker\Zed\Event\EventDependencyProvider as SprykerEventDependencyProvider;
class EventDependencyProvider extends SprykerEventDependencyProvider
{
public function getEventSubscriberCollection()
{
$eventSubscriberCollection = parent::getEventSubscriberCollection();
$eventSubscriberCollection->add(new CategoryImageStorageEventSubscriber());
return $eventSubscriberCollection;
}
}
src/Pyz/Zed/CategoryImageStorage/CategoryImageStorageConfig.php
<?php
namespace Pyz\Zed\CategoryImageStorage;
use Pyz\Zed\Synchronization\SynchronizationConfig;
use Spryker\Zed\CategoryImageStorage\CategoryImageStorageConfig as SprykerCategoryImageSTorageConfig;
class CategoryImageStorageConfig extends SprykerCategoryImageSTorageConfig
{
/**
* @return string|null
*/
public function getCategoryImageSynchronizationPoolName(): ?string
{
return SynchronizationConfig::DEFAULT_SYNCHRONIZATION_POOL_NAME;
}
}
Set up publisher trigger plugins
Add the following plugins to your project:
PLUGIN | SPECIFICATION | PREREQUISITES | NAMESPACE |
---|---|---|---|
CategoryImagePublisherTriggerPlugin | Allows publishing or republishing category images data manually. | None | Spryker\Zed\CategoryImageStorage\Communication\Plugin\Publisher |
src/Pyz/Zed/Publisher/PublisherDependencyProvider.php
<?php
namespace Pyz\Zed\Publisher;
use Spryker\Zed\CategoryImageStorage\Communication\Plugin\Publisher\CategoryImagePublisherTriggerPlugin;
use Spryker\Zed\Publisher\PublisherDependencyProvider as SprykerPublisherDependencyProvider;
class PublisherDependencyProvider extends SprykerPublisherDependencyProvider
{
/**
* @return array<\Spryker\Zed\PublisherExtension\Dependency\Plugin\PublisherTriggerPluginInterface>
*/
protected function getPublisherTriggerPlugins(): array
{
return [
new CategoryImagePublisherTriggerPlugin(),
];
}
}
Set up data synchronization
Add the following plugins to your project:
PLUGIN | SPECIFICATION | PREREQUISITES | NAMESPACE |
---|---|---|---|
CategoryImageSynchronizationDataPlugin | Synchronizes all category image entries from the database to Redis. | None | Spryker\Zed\CategoryImageStorage\Communication\Plugin\Synchronization |
src/Pyz/Zed/Synchronization/SynchronizationDependencyProvider.php
<?php
namespace Pyz\Zed\Synchronization;
use Spryker\Zed\CategoryImageStorage\Communication\Plugin\Synchronization\CategoryImageSynchronizationDataPlugin;
use Spryker\Zed\Synchronization\SynchronizationDependencyProvider as SprykerSynchronizationDependencyProvider;
class SynchronizationDependencyProvider extends SprykerSynchronizationDependencyProvider
{
/**
* @return \Spryker\Zed\SynchronizationExtension\Dependency\Plugin\SynchronizationDataPluginInterface[]
*/
protected function getSynchronizationDataPlugins(): array
{
return [
new CategoryImageSynchronizationDataPlugin(),
];
}
}
Make sure that when a category image is created, updated, or deleted, it is exported or removed from Redis accordingly.
STORAGE TYPE | TARGET ENTITY | EXAMPLE EXPECTED DATA IDENTIFIER |
---|---|---|
Redis | Category Image | kv:category_image:en_us:1 |
An example of expected data fragment
{
"id_category":1,
"image_sets": [
{
"name":"default",
"images": [
{
"id_category_image":1,
"external_url_large":"http://mysprykershop.com/image/url.jpg",
"external_url_small":"http://mysprykershop.com/image/url.jpg"
}
]
}
]
}
4) Import data
In this step, the category template is configured to display category images.
- Prepare your data according to your requirements using our demo data:
data/import/category_template.csv
template_name,template_path
"Sub Categories grid","@CatalogPage/views/sub-categories-grid/sub-categories-grid.twig"
COLUMN | IS REQUIRED | DATA TYPE | DATA EXAMPLE | DATA EXPLANATION |
---|---|---|---|---|
template_name | ✓ | string | My category template | A human readable name of the category template. |
template_path | ✓ | string | @ModuleName/path/to/category/template.twig | Category template path that is used to display a category page. |
- Import data:
console data:import:category-template
Make sure that, in the database, the configured data has been added to the spy_category_template
table.
5) Set up behavior
Add the following plugins to your project:
PLUGIN | SPECIFICATION | PREREQUISITES | NAMESPACE |
---|---|---|---|
CategoryImageSetCreatorPlugin | Persists new category image sets into the database after the category creation. | None | \Spryker\Zed\CategoryImage\Communication\Plugin |
CategoryImageSetExpanderPlugin | Hydrates category with image data after reading them from the database. | None | \Spryker\Zed\CategoryImage\Communication\Plugin |
CategoryImageSetUpdaterPlugin | Persists category image set changes into the database after the category update. | None | \Spryker\Zed\CategoryImage\Communication\Plugin |
RemoveCategoryImageSetRelationPlugin | Deletes category image sets when a category is deleted. | None | \Spryker\Zed\CategoryImage\Communication\Plugin |
CategoryImageFormPlugin | Extends create/edit category forms with category image set related fields. | None | \Spryker\Zed\CategoryImageGui\Communication\Plugin |
CategoryImageFormTabExpanderPlugin | Extends the create and edit category tabs with the category image set related item. | None | \Spryker\Zed\CategoryImageGui\Communication\Plugin |
src/Pyz/Zed/Category/CategoryDependencyProvider.php
<?php
namespace Pyz\Zed\Category;
use Spryker\Zed\Category\CategoryDependencyProvider as SprykerDependencyProvider;
use Spryker\Zed\CategoryImage\Communication\Plugin\CategoryImageSetCreatorPlugin;
use Spryker\Zed\CategoryImage\Communication\Plugin\CategoryImageSetExpanderPlugin;
use Spryker\Zed\CategoryImage\Communication\Plugin\CategoryImageSetUpdaterPlugin;
use Spryker\Zed\CategoryImage\Communication\Plugin\RemoveCategoryImageSetRelationPlugin;
use Spryker\Zed\CategoryImageGui\Communication\Plugin\CategoryImageFormPlugin;
use Spryker\Zed\CategoryImageGui\Communication\Plugin\CategoryImageFormTabExpanderPlugin;
class CategoryDependencyProvider extends SprykerDependencyProvider
{
/**
* @return \Spryker\Zed\Category\Dependency\Plugin\CategoryRelationDeletePluginInterface[]
*/
protected function getRelationDeletePluginStack()
{
$deletePlugins = array_merge(
[
new RemoveCategoryImageSetRelationPlugin(),
],
parent::getRelationDeletePluginStack()
);
return $deletePlugins;
}
/**
* @return \Spryker\Zed\CategoryExtension\Dependency\Plugin\CategoryTransferExpanderPluginInterface[]
*/
protected function getCategoryPostReadPlugins(): array
{
return [
new CategoryImageSetExpanderPlugin(),
];
}
/**
* @return array
*/
protected function getCategoryFormPlugins()
{
return array_merge(parent::getCategoryFormPlugins(), [
new CategoryImageFormPlugin(),
]);
}
/**
* @return \Spryker\Zed\CategoryExtension\Dependency\Plugin\CategoryUpdateAfterPluginInterface[]
*/
protected function getCategoryPostUpdatePlugins(): array
{
return [
new CategoryImageSetUpdaterPlugin(),
];
}
/**
* @return \Spryker\Zed\CategoryExtension\Dependency\Plugin\CategoryCreateAfterPluginInterface[]
*/
protected function getCategoryPostCreatePlugins(): array
{
return [
new CategoryImageSetCreatorPlugin(),
];
}
/**
* @return \Spryker\Zed\CategoryExtension\Dependency\Plugin\CategoryFormTabExpanderPluginInterface[]
*/
protected function getCategoryFormTabExpanderPlugins(): array
{
return [
new CategoryImageFormTabExpanderPlugin(),
];
}
}
Make sure that category image handling is integrated successfully by going to Zed and creating, editing, and deleting categories with images.
Install feature frontend
Follow the steps below to install the Alternative Products feature frontend.
Prerequisites
Install the required features:
NAME | VERSION | INSTALLATION GUIDE |
---|---|---|
Spryker Core | 202404.0 | Install the Spryker Core feature |
Category | 202404.0 |
1) Install the required modules
composer require spryker-feature/category-image:"202404.0" --update-with-dependencies
Make sure that the following modules have been installed:
MODULE | EXPECTED DIRECTORY |
---|---|
CategoryImageStorageWidget | vendor/spryker-shop/category-image-storage-widget |
2) Set up widgets
Register the following global widgets:
WIDGET | DESCRIPTION | NAMESPACE |
---|---|---|
CategoryImageStorageWidget | Finds the given category image set in Storage and displays its first image in a given size format. | SprykerShop\Yves\CategoryImageStorageWidget\Widget |
src/Pyz/Yves/ShopApplication/ShopApplicationDependencyProvider.php
<?php
namespace Pyz\Yves\ShopApplication;
use SprykerShop\Yves\ShopApplication\ShopApplicationDependencyProvider as SprykerShopApplicationDependencyProvider;
use SprykerShop\Yves\CategoryImageStorageWidget\Widget\CategoryImageStorageWidget;
class ShopApplicationDependencyProvider extends SprykerShopApplicationDependencyProvider
{
/**
* @return string[]
*/
protected function getGlobalWidgets(): array
{
return [
CategoryImageStorageWidget::class,
];
}
}
Make sure the following widgets have been registered:
MODULE | TEST |
---|---|
CategoryImageStorageWidget | Make sure you have category image data in your storage. Then, render the widget for all the categories that have images assigned. |
Thank you!
For submitting the form