PHP code example of dynamic / silverstripe-foxy-discounts
1. Go to this page and download the library: Download dynamic/silverstripe-foxy-discounts library. Choose the download type require.
2. Extract the ZIP file and open the index.php.
3. Add this code to the index.php.
<?php
require_once('vendor/autoload.php');
/* Start to develop here. Best regards https://php-download.com/ */
dynamic / silverstripe-foxy-discounts example snippets
<?
namespace {
use SilverStripe\ORM\DataExtension;
use Dynamic\Products\Page\Product;
class DiscountDataExtension extends DataExtension
{
/**
* @var array
*/
private static $many_many = [
'Products' => Product::class,
'ExcludeProducts' => Product::class,
];
/**
* @param FieldList $fields
*/
public function updateCMSFields(FieldList $fields)
{
if ($this->owner->ID) {
// Products
$field = $fields->dataFieldByName('Products');
$fields->removeByName('Products');
$fields->addFieldToTab('Root.Included', $field);
$field->setDescription('Limit the discount to these products. If no products specified, all products will receive the discount');
$config = $field->getConfig();
$config
->removeComponentsByType([
GridFieldAddExistingAutocompleter::class,
GridFieldAddNewButton::class,
GridFieldArchiveAction::class,
])
->addComponents([
new GridFieldAddExistingSearchButton(),
]);
$exclusions = $fields->dataFieldByName('ExcludeProducts');
$fields->removeByName('ExcludeProducts');
$fields->addFieldToTab('Root.Excluded', $exclusions);
$exclusions->setDescription('Products in this list will ALWAYS be excluded from the discount, even if added to the "Included" tab.');
$excludeConfig = $exclusions->getConfig();
$excludeConfig
->removeComponentsByType([
GridFieldAddExistingAutocompleter::class,
GridFieldAddNewButton::class,
GridFieldArchiveAction::class,
])
->addComponents([
new GridFieldAddExistingSearchButton(),
]);
}
}
/**
* @return array
*/
public function getRestrictions()
{
if ($this->owner->Products()->count() == 0) {
$products = Product::get()->column();
} else {
$products = $this->owner->Products()->column();
}
foreach ($this->owner->ExcludeProducts()->column() as $id) {
if (in_array($id, $products)) {
$key = array_search($id, $products);
unset($products[$key]);
}
}
return $products;
}
}
}
Loading please wait ...
Before you can download the PHP files, the dependencies should be resolved. This can take some minutes. Please be patient.