3brs / sylius-payment-fee-plugin
Payment extra fee plugin for Sylius
Installs: 3 627
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 2
Forks: 4
Open Issues: 6
Type:sylius-plugin
Requires
- php: ^8.0
- sylius/sylius: ^1.11|^1.12
Requires (Dev)
- behat/behat: ^3.9.0
- behat/mink-selenium2-driver: ^1.4
- dmore/behat-chrome-extension: ^1.3
- dmore/chrome-mink-driver: ^2.7
- friends-of-behat/mink: ^1.10
- friends-of-behat/mink-browserkit-driver: ^1.4
- friends-of-behat/mink-debug-extension: ^2.1
- friends-of-behat/mink-extension: ^2.4
- friends-of-behat/page-object-extension: ^0.3
- friends-of-behat/suite-settings-extension: ^1.0
- friends-of-behat/symfony-extension: ^2.1
- friends-of-behat/variadic-extension: ^1.3
- php-http/message-factory: ^1.0.0
- phpstan/phpstan: ^1.8.1
- phpstan/phpstan-doctrine: 1.3.37
- phpstan/phpstan-strict-rules: ^1.3.0
- phpstan/phpstan-symfony: ^1.3
- phpstan/phpstan-webmozart-assert: ^1.2.0
- phpunit/phpunit: ^9.5
- polishsymfonycommunity/symfony-mocker-container: ^1.0
- rector/rector: ^0.18.12
- sylius-labs/coding-standard: ^4.2
- symfony/browser-kit: ^5.4 || ^6.0
- symfony/debug-bundle: ^5.4 || ^6.0
- symfony/dotenv: ^5.4 || ^6.0
- symfony/flex: ^2.2.2
- symfony/framework-bundle: ^5.4 || ^6.0
- symfony/http-foundation: ^5.4 || ^6.0
- symfony/http-kernel: ^5.4 || ^6.0
- symfony/intl: ^5.4 || ^6.0
- symfony/web-profiler-bundle: ^5.4 || ^6.0
Conflicts
- babdev/pagerfanta-bundle: <3.6.1
- doctrine/collections: <1.7.0
- doctrine/dbal: <2.13.3
- doctrine/doctrine-bundle: <2.4.2
- 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
- polishsymfonycommunity/symfony-mocker-container: <1.0.6
- sylius/resource-bundle: <1.10.0
- symfony/css-selector: <4.4.24
- symfony/framework-bundle: >=6.1.0 <6.1.4|6.2.8
- symfony/mime: <5.4.0
- symfony/web-link: <5.3.0
- symplify/easy-coding-standard: <10.2.0
- twig/twig: <2.14.7
- webmozart/assert: <1.11.0
- willdurand/negotiation: <3.0
This package is auto-updated.
Last update: 2025-01-02 13:22:58 UTC
README
Payment Fee Plugin
Features
- Charge extra fee for a payment method
- Typical usage: Cash on Delivery
- Taxes are implemented the same way as taxes for shipping fees
Installation
-
Run
composer require 3brs/sylius-payment-fee-plugin
-
Add plugin class to your
config/bundles.php
return [ ... ThreeBRS\SyliusPaymentFeePlugin\ThreeBRSSyliusPaymentFeePlugin::class => ['all' => true], ];
-
Your Entity
PaymentMethod
has to implement\ThreeBRS\SyliusPaymentFeePlugin\Model\PaymentMethodWithFeeInterface
. You can use TraitThreeBRS\SyliusPaymentFeePlugin\Model\PaymentMethodWithFeeTrait
.- see test PaymentMethod for inspiration
For guide how to use your own entity see Sylius docs - Customizing Models
Admin
- Include
@ThreeBRSSyliusPaymentFeePlugin/Admin/_form.html.twig
into@SyliusAdmin/PaymentMethod/_form.html.twig
.
{# ... #} {% include '@ThreeBRSSyliusPaymentFeePlugin/Admin/_form.html.twig' %}
- Include
@ThreeBRSSyliusPaymentFeePlugin/Admin/_order_show.html.twig
into@AdminBundle/Order/Show/Summary/_totals.html.twig
.
{# ... #} {% include '@ThreeBRSSyliusPaymentFeePlugin/Admin/_order_show.html.twig' %}
Shop
- Include
@ThreeBRSSyliusPaymentFeePlugin/Shop/Checkout/SelectPayment/_choice.html.twig
into@ShopBundle/Checkout/SelectPayment/_choice.html.twig
.
{# ... #} {% include '@ThreeBRSSyliusPaymentFeePlugin/Shop/Checkout/SelectPayment/_choice.html.twig' %}
- Add variable fee
{% set fee = form.method.vars.payment_costs[choice_form.vars.value] %}
into@ShopBundle/Checkout/SelectPayment/_payment.html.twig
intoforeach
.
{# ... #} {% for key, choice_form in form.method %} {% set fee = form.method.vars.payment_costs[choice_form.vars.value] %} {% include '@SyliusShop/Checkout/SelectPayment/_choice.html.twig' with {'form': choice_form, 'method': form.method.vars.choices[key].data} %} {% else %} {% include '@SyliusShop/Checkout/SelectPayment/_unavailable.html.twig' %} {% endfor %}
- Include
@ThreeBRSSyliusPaymentFeePlugin/Shop/Common/Order/Table/_payment.html.twig
into@ShopBundle/Common/Order/Table/_totals.html.twig
.
{# ... #} <tr> {% include '@SyliusShop/Common/Order/Table/_shipping.html.twig' with {'order': order} %} </tr> {% include '@ThreeBRSSyliusPaymentFeePlugin/Shop/Common/Order/Table/_payment.html.twig' with {'order': order} %}
- Create and run doctrine database migrations
bin/console doctrine:migrations:diff bin/console doctrine:migrations:migrate
- how to use your own entity see Sylius docs - Customizing Models
Development
Usage
- Alter plugin in
/src
- See
bin/
dir for useful commands
Testing
After your changes you must ensure that the tests are still passing.
composer install bin/console doctrine:database:create --if-not-exists --env=test bin/console doctrine:schema:update --complete --force --env=test yarn --cwd tests/Application install yarn --cwd tests/Application build bin/behat bin/phpstan.sh bin/ecs.sh vendor/bin/phpspec run
Opening Sylius with your plugin
- Install symfony CLI command: https://symfony.com/download
- hint: for Docker (with Ubuntu) use Debian/Ubuntu — APT based
Linux installation steps as
root
user and withoutsudo
command- you may need to install
curl
firstapt-get update && apt-get install curl --yes
- you may need to install
- hint: for Docker (with Ubuntu) use Debian/Ubuntu — APT based
Linux installation steps as
- Run app
(cd tests/Application && APP_ENV=test bin/console sylius:fixtures:load) (cd tests/Application && APP_ENV=test symfony server:start --dir=public --port=8080)
- change
APP_ENV
todev
if you need it
License
This library is under the MIT license.