Plugin that add the possibility to receive an email notification when a product return in stock
- PHP
^8.0
- Sylius
^1.11.2
-
Run
composer require webgriffe/sylius-back-in-stock-notification-plugin --no-scripts
. -
Add the plugin to the
config/bundles.php
file:
Webgriffe\SyliusBackInStockNotificationPlugin\WebgriffeSyliusBackInStockNotificationPlugin::class => ['all' => true],
- Import the plugin routes by creating a file in
config/routes/webgriffe_sylius_back_in_stock_notification_plugin.yaml
with the follwing content:
webgriffe_sylius_back_in_stock_notification_plugin:
resource: "@WebgriffeSyliusBackInStockNotificationPlugin/config/routing.yaml"
- Import required packages config in your
config/packages/webgriffe_sylius_back_in_stock_notification_plugin.yaml
file:
imports:
- { resource: "@WebgriffeSyliusBackInStockNotificationPlugin/config/packages.yaml" }
- Update the database schema and install assets:
bin/console doctrine:migrations:migrate
bin/console assets:install
bin/console sylius:theme:assets:install
- Install the plugin JS assets by adding the source to your webpack configuration:
// Shop config
Encore.setOutputPath('public/build/shop/')
.setPublicPath('/build/shop')
.addEntry('shop-entry', './vendor/sylius/sylius/src/Sylius/Bundle/ShopBundle/Resources/private/entry.js')
.addEntry('webgriffe-sylius-back-in-stock-notification-entry', './vendor/webgriffe/sylius-back-in-stock-notification-plugin/public/js/back-in-stock-notification.js') // The line to add
.disableSingleRuntimeChunk()
.cleanupOutputBeforeBuild()
.enableSourceMaps(!Encore.isProduction())
.enableVersioning(Encore.isProduction())
.enablePostCssLoader()
.enableSassLoader()
- Run yarn build:
bin/console yarn:build
- Clear cache:
bin/console cache:clear
This module sends mail using a Symfony Command. Unfortunately, the command line context does not know about your VirtualHost or domain name. To fix this, the Command loads the hostname from the Subscription's channel, if nothing set it defaults to localhost
. In console commands, URLs use http by default. You can change this globally with these configuration parameters:
- Edit the
config/services.yml
file by adding the following content:
parameters:
router.request_context.scheme: https
- As said early this module provides a command that check the stock of the product. You have to set the command
bin/console webgriffe:back-in-stock-notification:alert
in the crontab, once a day is enough:
0 12 * * * <absolute-php-path> <absolute-path-to-sylius-dir>/bin/console webgriffe:back-in-stock-notification:alert
If you want to use our Behat defined steps you have to include our Behat class in your autoloader-dev. To achieve this adds the following line to your composer.json
:
"autoload-dev": {
"psr-4": {
"Tests\\Webgriffe\\SyliusBackInStockNotificationPlugin\\": "vendor/webgriffe/sylius-back-in-stock-notification-plugin/tests/"
}
},
To contribute to this plugin clone this repository, create a branch for your feature or bugfix, do your changes and then make sure al tests are passing.
composer install
(cd tests/Application && yarn install)
(cd tests/Application && yarn build)
(cd tests/Application && APP_ENV=test bin/console assets:install public)
docker-compose up -d # only if you haven't mysql and mailhog installed locally
(cd tests/Application && APP_ENV=test bin/console doctrine:database:create)
(cd tests/Application && APP_ENV=test bin/console doctrine:schema:create)
To be able to setup a plugin's database, remember to configure you database credentials in tests/Application/.env
and tests/Application/.env.test
.
vendor/bin/phpunit
vendor/bin/phpspec run
vendor/bin/behat --strict --tags="~@javascript"
-
Start Headless Chrome:
google-chrome-stable --enable-automation --disable-background-networking --no-default-browser-check --no-first-run --disable-popup-blocking --disable-default-apps --allow-insecure-localhost --disable-translate --disable-extensions --no-sandbox --enable-features=Metal --headless --remote-debugging-port=9222 --window-size=2880,1800 --proxy-server='direct://' --proxy-bypass-list='*' http://127.0.0.1
- Install SSL certificates (only once needed) and run test application's webserver on
127.0.0.1:8080
:
symfony server:ca:install
APP_ENV=test symfony server:start --port=8080 --dir=tests/Application/public --daemon
- Run Behat:
vendor/bin/behat --strict --tags="@javascript"
vendor/bin/psalm
vendor/bin/phpstan analyse -c phpstan.neon
vendor/bin/ecs check
- Using
test
environment:
(cd tests/Application && APP_ENV=test bin/console sylius:fixtures:load)
APP_ENV=test symfony server:start --port=8080 --dir=tests/Application/public --daemon
- Using
dev
environment:
(cd tests/Application && APP_ENV=dev bin/console sylius:fixtures:load)
APP_ENV=dev symfony server:start --dir=tests/Application/public --daemon
This plugin is under the MIT license. See the complete license in the LICENSE file.
Developed by Webgriffe®.