bootstrap3-1.0.1/src/Plugin/Setting/JavaScript/Popovers/PopoverEnabled.php
src/Plugin/Setting/JavaScript/Popovers/PopoverEnabled.php
<?php
namespace Drupal\bootstrap3\Plugin\Setting\JavaScript\Popovers;
use Drupal\bootstrap3\Plugin\Setting\SettingBase;
use Drupal\bootstrap3\Utility\Element;
use Drupal\Core\Form\FormStateInterface;
/**
* The "popover_enabled" theme setting.
*
* @ingroup plugins_setting
*
* @BootstrapSetting(
* id = "popover_enabled",
* type = "checkbox",
* title = @Translation("Enable Bootstrap Popovers"),
* description = @Translation("Elements that have the <code>data-toggle="popover"</code> attribute set will automatically initialize the popover upon page load. <div class='alert alert-warning alert-sm'><strong>WARNING:</strong> This feature can sometimes impact performance. Disable if pages appear to hang after load.</div>"),
* defaultValue = 1,
* weight = -1,
* groups = {
* "javascript" = @Translation("JavaScript"),
* "popovers" = @Translation("Popovers"),
* },
* )
*/
class PopoverEnabled extends SettingBase {
/**
* {@inheritdoc}
*/
public function alterFormElement(Element $form, FormStateInterface $form_state, $form_id = NULL) {
parent::alterFormElement($form, $form_state, $form_id);
$group = $this->getGroupElement($form, $form_state);
$group->setProperty('description', $this->t('Add small overlays of content, like those on the iPad, to any element for housing secondary information.'));
}
/**
* {@inheritdoc}
*/
public function drupalSettings() {
return !!$this->theme->getSetting('popover_enabled');
}
}
