3 namespace Drupal\bootstrap\Plugin\Setting\JavaScript\Tooltips;
5 use Drupal\bootstrap\Plugin\Setting\SettingBase;
6 use Drupal\bootstrap\Utility\Element;
7 use Drupal\Core\Form\FormStateInterface;
10 * The "tooltip_enabled" theme setting.
12 * @ingroup plugins_setting
15 * id = "tooltip_enabled",
17 * title = @Translation("Enable Bootstrap Tooltips"),
18 * description = @Translation("Elements that have the <code>data-toggle="e;tooltip"e;</code> attribute set will automatically initialize the tooltip upon page load. <strong class='error text-error'>WARNING: This feature can sometimes impact performance. Disable if pages appear to "e;hang"e; after initial load.</strong>"),
22 * "javascript" = @Translation("JavaScript"),
23 * "tooltips" = @Translation("Tooltips"),
27 class TooltipEnabled extends SettingBase {
32 public function alterFormElement(Element $form, FormStateInterface $form_state, $form_id = NULL) {
33 parent::alterFormElement($form, $form_state, $form_id);
35 $group = $this->getGroupElement($form, $form_state);
36 $group->setProperty('description', t('Inspired by the excellent jQuery.tipsy plugin written by Jason Frame; Tooltips are an updated version, which don\'t rely on images, use CSS3 for animations, and data-attributes for local title storage. See <a href=":url" target="_blank">Bootstrap tooltips</a> for more documentation.', [
37 ':url' => 'https://getbootstrap.com/docs/3.3/javascript/#tooltips',
44 public function drupalSettings() {
45 return !!$this->theme->getSetting('tooltip_enabled');