bee_hotel-1.x-dev/modules/beehotel_pricealterators/src/Plugin/PriceAlterator/GlobalSlider.php
modules/beehotel_pricealterators/src/Plugin/PriceAlterator/GlobalSlider.php
<?php
namespace Drupal\beehotel_pricealterators\Plugin\PriceAlterator;
use Drupal\beehotel_utils\BeeHotelCommerce;
use Drupal\beehotel_pricealterator\PriceAlteratorBase;
use Symfony\Component\DependencyInjection\ContainerInterface;
/**
* Provides a "Global Slider" Price Alterator for BeeHotel.
*
* Because the plugin manager class for our plugins uses annotated class
* discovery, Price Alterators only needs to exist within the
* Plugin\PriceAlterator namespace, and provide a PriceAlterator
* annotation to be declared as a plugin. This is defined in
* \Drupal\beehotel_pricealterator\PriceAlteratorPluginManager::__construct().
*
* The following is the plugin annotation. This is parsed by Doctrine to make
* the plugin definition. Any values defined here will be available in the
* plugin definition.
*
* This should be used for metadata that is specifically required to instantiate
* the plugin, or for example data that might be needed to display a list of all
* available plugins where the user selects one. This means many plugin
* annotations can be reduced to a plugin ID, a label and perhaps a description.
*
*
* The weight Key is the weight for this alterator.
* Legenda for the 'weight' key:
* -9999 : heaviest, to be used as very first (reserved)
* -9xxx : heavy, to be used as first (reserved)
* 0 : no need to be weighted
* 1xxx : allowed in custom modules (@TODO)
* xxxx : everything else
* 9xxx : light, to be used as last (reserved)
* 9999 : lightest, to be used as very last (reserved)
*
* @PriceAlterator(
* description = @Translation("Slide globally price up and down"),
* id = "GlobalSlider",
* provider = "beehotel_pricealterator",
* status = 1,
* type = "optional",
* weight = 9999,
* )
*/
class GlobalSlider extends PriceAlteratorBase {
/**
* The BeeHotel commerce Util.
*
* @var \Drupal\beehotel_utils\BeeHotelCommerce
*/
protected $beehotelCommerce;
/**
* Price alterator Status.
*
* @var bool
*/
private $status;
/**
* Price alterator Increase.
*
* @var float
*/
private $increase;
/**
* Price alterator Enabled.
*
* @var bool
*/
private $enabled;
/**
* Price alterator global slider.
*
* @var float
*/
private $globalslider;
/**
* Constructs a new alterator object.
*
* @param array $configuration
* A configuration array containing information about the plugin instance.
* @param string $plugin_id
* The plugin_id for the plugin instance.
* @param mixed $plugin_definition
* The plugin implementation definition.
* @param \Drupal\beehotel_utils\BeeHotelCommerce $beehotel_commerce
* BeeHotel Commerce Utils.
*/
public function __construct(array $configuration, $plugin_id, $plugin_definition, BeeHotelCommerce $beehotel_commerce) {
$config = \Drupal::config($this->configName());
$this->status = $config->get('status');
$this->globalslider = [$config->get('globalslider')];
$this->beehotelCommerce = $beehotel_commerce;
$this->enabled = $config->get('enabled');
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static(
$configuration,
$plugin_id,
$plugin_definition,
$container->get('beehotel_utils.beehotelcommerce'),
);
}
/**
* Reference to the Alterator (as plugin).
*
* This value matches the ID in the @PriceAlterator annotation.
*/
public function pluginId() {
$tmp = explode("\\", __CLASS__);
return end($tmp);
}
/**
* Alter a price.
*
* Every Alterator needs to have an alter method.
*
* @param array $data
* Array of data related to this price.
* @param array $pricetable
* Array of prices by week day.
*
* @return array
* An updated $data array.
*/
public function alter(array $data, array $pricetable) {
$data['tmp']['price'] += $data['tmp']['price'] / 100 * reset($this->globalslider);
$data['alterator'][] = __CLASS__;
return $data;
}
/**
* Current value.
*
* Get current value for this alterator. We can use this
* method to get info and settings for the alterator.
*
* @param array $data
* Array of data related to this price.
* @param array $pricetable
* Array of prices by week day.
*
* @return array
* A render array as expected by the renderer
*/
public function currentValue(array $data, array $pricetable) {
$data = [];
$data['value'] = "";
$data['currency'] = $this->beehotelCommerce->currentStoreCurrency()->get('symbol');
$data['percentage'] = "%";
$data['type'] = "";
$data['class'] = "";
$slider = reset($this->globalslider);
if (isset($slider)) {
$data['value'] = $slider ?: '';
$data['class'] = $this->polarity($slider) ?: '';
$data['type'] = $data['percentage'] ?: '';
}
$tmp = $this->t("Price will be altered as per percentage value");
$tmp .= "<br/>" . $this->t("price + (price / 100 * global slice) = Altered price");
$tmp .= "<br/>" . $this->t("IE: 200 + (200 / 100 * 20) = 240");
$current_value = [
'#default_value' => $data['value'],
'#type' => 'range_slider',
'#title' => $this->t('Current value:') . " " . $data['value'],
'#min' => -100,
'#max' => 100,
'#step' => 1,
'#description' => $tmp,
'#description_display' => 'after',
'#data-orientation' => 'horizontal',
'#output' => 'below',
'#output__field_prefix' => '',
'#output__field_suffix' => '%',
'#disabled' => TRUE,
];
return \Drupal::service('renderer')->renderPlain($current_value);
}
}
