3brs / sylius-packeta-plugin
Packeta plugin for Sylius
Installs: 662
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 2
Open Issues: 0
Type:sylius-plugin
pkg:composer/3brs/sylius-packeta-plugin
Requires
- php: ^8.2|^8.3
- ext-json: *
- 3brs/sylius-shipment-export-plugin: 1.0
- sylius/sylius: ^2.0
Requires (Dev)
- behat/behat: ^v3.19.0
- dmore/behat-chrome-extension: ^1.4
- dmore/chrome-mink-driver: ^2.9.3
- friends-of-behat/mink: ^1.11
- friends-of-behat/mink-browserkit-driver: ^v1.6.2
- friends-of-behat/mink-debug-extension: ^v2.1.0
- friends-of-behat/mink-extension: ^v2.7.5
- friends-of-behat/page-object-extension: ^v0.3.2
- friends-of-behat/suite-settings-extension: ^v1.1.0
- friends-of-behat/symfony-extension: ^2.6.2
- friends-of-behat/variadic-extension: ^v1.6.0
- nyholm/psr7: ^1.8
- php-http/message-factory: ^1.1.0
- phpstan/phpstan: ^2.1.10
- phpstan/phpstan-doctrine: ^2.0.2
- phpstan/phpstan-strict-rules: ^2.0.4
- phpstan/phpstan-symfony: ^2.0.3
- phpstan/phpstan-webmozart-assert: ^2.0.0
- phpunit/phpunit: ^11.1 || ^12.0.10
- polishsymfonycommunity/symfony-mocker-container: ^v1.0.8
- rector/rector: ^2.0.10
- sylius-labs/coding-standard: ^v4.4.0
- symfony/browser-kit: ^v6.4|^v7.1
- symfony/debug-bundle: ^v6.4|^v7.1
- symfony/doctrine-bridge: ^v6.4|^v7.1
- symfony/dotenv: ^v6.4|^v7.1
- symfony/flex: ^v2.5.0
- symfony/framework-bundle: ^v6.4|^v7.1
- symfony/http-foundation: ^v7.2.3
- symfony/http-kernel: ^v6.4|^v7.1
- symfony/intl: ^v6.4|^v7.1
- symfony/property-info: ^v6.4|^v7.1
- symfony/web-profiler-bundle: ^v6.4|^v7.1
- symplify/easy-coding-standard: ^12.0
Conflicts
- api-platform/core: <2.7.13
- api-platform/symfony: <v4.1.0
- babdev/pagerfanta-bundle: <3.7.0
- doctrine/collections: <1.7.0
- doctrine/data-fixtures: <1.5.1
- doctrine/dbal: <2.13.3
- doctrine/doctrine-bundle: <2.13.1
- doctrine/orm: <2.19.0
- fakerphp/faker: <1.21.0
- friendsofsymfony/rest-bundle: <3.1.0
- jms/serializer-bundle: <4.2.0
- knplabs/knp-menu: <3.3.0
- lexik/jwt-authentication-bundle: <2.12
- masterminds/html5: <2.7.5
- payum/core: <1.7.3
- polishsymfonycommunity/symfony-mocker-container: <1.0.6
- sylius/grid-bundle: <1.11.0
- sylius/resource-bundle: <1.11.0
- sylius/sylius: <2.0.6
- symfony/css-selector: <4.4.24
- symfony/dom-crawler: <5.4.0
- symfony/framework-bundle: >=5.4.0 <=5.4.20|>=6.0.0 <=6.0.16|>=6.1.0 <=6.1.8|>=6.2.0 <=6.2.2|6.2.8
- symfony/mime: <5.4.0
- symfony/validator: 7.3.0
- symfony/web-link: <5.3.0
- symplify/easy-coding-standard: <10.3.0|12.5.10
- twig/twig: <2.14.7
- webmozart/assert: <1.11.0
- willdurand/negotiation: <3.0
This package is auto-updated.
Last update: 2025-10-15 08:19:01 UTC
README
    Packeta Plugin
    
    
         
    
    
         
    
    
         
    
Features
- Enables sending shipments via [en] [cz] [pl] [sk] [hu] [ro] to Packeta branch or to the customer's address via Packeta service.
- The user can choose the Packeta branch from the map during checkout in the Shipment step.
- See Packeta branch in final checkout step and also in the admin panel.
- Export CSV with the Packeta shipments (both to Packeta branch or customer's address) and import it easily into Packeta's system.
Installation
- 
Run composer require 3brs/sylius-packeta-plugin.
- 
Add plugin classes to your config/bundles.php:return [ ... ThreeBRS\SyliusShipmentExportPlugin\ThreeBRSSyliusShipmentExportPlugin::class => ['all' => true], ThreeBRS\SyliusPacketaPlugin\ThreeBRSSyliusPacketaPlugin::class => ['all' => true], ]; 
- 
Use plugin configuration by creating config/packages/threebrs_sylius_packeta_plugin.yamlwith contentimports: - { resource: "@ThreeBRSSyliusPacketaPlugin/Resources/config/config.{yml,yaml}" } 
- 
Add routing to config/routes.yamlthreebrs_sylius_shipment_export_plugin: resource: "@ThreeBRSSyliusShipmentExportPlugin/Resources/config/admin_routing.{yml,yaml}" prefix: '/%sylius_admin.path_name%' 
- 
Your Entity Shipmenthas to implement\ThreeBRS\SyliusPacketaPlugin\Model\PacketaShipmentInterface. You can use the trait\ThreeBRS\SyliusPacketaPlugin\Model\PacketaShipmentTrait.<?php declare(strict_types=1); namespace App\Entity\Shipping; use Doctrine\ORM\Mapping as ORM; use ThreeBRS\SyliusPacketaPlugin\Model\PacketaShipmentInterface; use ThreeBRS\SyliusPacketaPlugin\Model\PacketaShipmentTrait; use Sylius\Component\Core\Model\Shipment as BaseShipment; #[ORM\Entity] #[ORM\Table(name: 'sylius_shipment')] class Shipment extends BaseShipment implements PacketaShipmentInterface { use PacketaShipmentTrait; } 
- 
Your Entity ShippingMethodhas to implement\ThreeBRS\SyliusPacketaPlugin\Model\PacketaShipmentInterface. You can use the trait\ThreeBRS\SyliusPacketaPlugin\Model\PacketaShipmentTrait.<?php declare(strict_types=1); namespace App\Entity\Shipping; use Doctrine\ORM\Mapping as ORM; use ThreeBRS\SyliusPacketaPlugin\Model\PacketaShippingMethodInterface; use ThreeBRS\SyliusPacketaPlugin\Model\PacketaShippingMethodTrait; use Sylius\Component\Core\Model\ShippingMethod as BaseShippingMethod; #[ORM\Entity] #[ORM\Table(name: 'sylius_shipping_method')] class ShippingMethod extends BaseShippingMethod implements PacketaShippingMethodInterface { use PacketaShippingMethodTrait; } 
- 
Override the template in @ThreeBRSSyliusShipmentExportPlugin/_row.html.twig{% extends '@!ThreeBRSSyliusShipmentExportPlugin/_row.html.twig' %} {% block address %} {% if row.packeta %} {{ include('@ThreeBRSSyliusPacketaPlugin/_exporterRow.html.twig') }} {% else %} {{ parent() }} {% endif %} {% endblock %}
- 
Create and run doctrine database migrations. 
For the guide how to use your own entity see Sylius docs - Customizing Models
Usage
- For delivery to the Packeta branch, create new shipping method in the admin panel, set Packeta api keyand leaveCarrier IDempty.
- For delivery to customer's address, create new shipping method in the admin panel, set the Carrier IDand leave thePacketa API keyempty.
- If you need to filter the points in the map by country, use the
Show only pickup points from specific country in the map. If you leave this blank, all points in all supported countries will be shown.
- Packeta CSV export will be generated for shipping method which has the code 'packeta', you can change this in
parameters, it is an array (therefore can contain more codes, e.g. if you need to have different prices for different
countries, you will need more shipping methods; it is okay to use always the same API key)
parameters: shippingMethodsCodes: ['packeta'] You should add to this array both methods for shipping to Packeta branch and also to customer's address via Packeta service.
- Packeta API documentation: https://docs.packeta.com/docs/getting-started/client-section-imports#csv-import
- You can expand the list of countries by the parameter
parameters: threebrs_sylius_packeta_plugin_payment_methods: ['cz', 'pl', 'sk', 'hu', 'ro'] 
Development
Usage
- Develop your plugin in /src
- See bin/for useful commands
Testing
After your changes you must ensure that the tests are still passing.
make ci
License
This library is under the MIT license.




