You are here

class Margin in Bootstrap Styles 1.0.x

Class Margin.

@package Drupal\bootstrap_styles\Plugin\Style

Plugin annotation


@Style(
  id = "margin",
  title = @Translation("Margin"),
  group_id = "spacing",
  weight = 2
)

Hierarchy

Expanded class hierarchy of Margin

3 string references to 'Margin'
bootstrap_styles.schema.yml in config/schema/bootstrap_styles.schema.yml
config/schema/bootstrap_styles.schema.yml
Margin::buildConfigurationForm in src/Plugin/BootstrapStyles/Style/Margin.php
Margin::buildStyleFormElements in src/Plugin/BootstrapStyles/Style/Margin.php

File

src/Plugin/BootstrapStyles/Style/Margin.php, line 20

Namespace

Drupal\bootstrap_styles\Plugin\BootstrapStyles\Style
View source
class Margin extends StylePluginBase {

  /**
   * {@inheritdoc}
   */
  public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
    $config = $this
      ->config();
    $directions = [
      'left',
      'top',
      'right',
      'bottom',
    ];
    $form['spacing']['margin_description'] = [
      '#type' => 'item',
      '#title' => $this
        ->t('Margin'),
      '#markup' => $this
        ->t('<p>Enter one value per line, in the format <b>key|label</b> where <em>key</em> is the CSS class name (without the .), and <em>label</em> is the human readable name of the margin. <br /> <b>Note:</b> These options will be reflected on the range slider at the Layout Builder form, so make sure to sort them from lowest to greatest.</p>'),
    ];
    $form['spacing']['margin_group'] = [
      '#type' => 'container',
      '#title' => $this
        ->t('Margin'),
      '#title_display' => 'invisible',
      '#tree' => FALSE,
      '#attributes' => [
        'class' => [
          'bs-admin-d-lg-flex',
          'bs-admin-group-form-item-lg-ml',
        ],
      ],
    ];
    $form['spacing']['margin_group']['margin'] = [
      '#type' => 'textarea',
      '#default_value' => $config
        ->get('margin'),
      '#title' => $this
        ->t('Margin (classes)'),
      '#cols' => 60,
      '#rows' => 5,
    ];
    for ($i = 0; $i < 4; $i++) {
      $form['spacing']['margin_group']['margin_' . $directions[$i]] = [
        '#type' => 'textarea',
        '#default_value' => $config
          ->get('margin_' . $directions[$i]),
        '#title' => $this
          ->t('Margin @direction (classes)', [
          '@direction' => $directions[$i],
        ]),
        '#cols' => 60,
        '#rows' => 5,
      ];
    }
    return $form;
  }

  /**
   * {@inheritdoc}
   */
  public function submitConfigurationForm(array &$form, FormStateInterface $form_state) {
    $this
      ->config()
      ->set('margin', $form_state
      ->getValue('margin'))
      ->set('margin_left', $form_state
      ->getValue('margin_left'))
      ->set('margin_top', $form_state
      ->getValue('margin_top'))
      ->set('margin_right', $form_state
      ->getValue('margin_right'))
      ->set('margin_bottom', $form_state
      ->getValue('margin_bottom'))
      ->save();
  }

  /**
   * {@inheritdoc}
   */
  public function buildStyleFormElements(array &$form, FormStateInterface $form_state, $storage) {
    $directions = [
      'left',
      'top',
      'right',
      'bottom',
    ];

    // This only for frontend no storage needed for this field.
    $form['margin_type'] = [
      '#type' => 'radios',
      '#options' => [
        'margin' => $this
          ->t('Margin') . '<div class="bs_tooltip" data-placement="top" role="tooltip">' . $this
          ->t('All') . '</div>',
        'margin_left' => $this
          ->t('Left') . '<div class="bs_tooltip" data-placement="top" role="tooltip">' . $this
          ->t('Left') . '</div>',
        'margin_top' => $this
          ->t('Top') . '<div class="bs_tooltip" data-placement="top" role="tooltip">' . $this
          ->t('Top') . '</div>',
        'margin_right' => $this
          ->t('Right') . '<div class="bs_tooltip" data-placement="top" role="tooltip">' . $this
          ->t('Right') . '</div>',
        'margin_bottom' => $this
          ->t('Bottom') . '<div class="bs_tooltip" data-placement="top" role="tooltip">' . $this
          ->t('Bottom') . '</div>',
      ],
      '#title' => $this
        ->t('margin type'),
      '#title_display' => 'invisible',
      '#default_value' => 'margin',
      '#validated' => TRUE,
      '#attributes' => [
        'class' => [
          'bs_col--full',
          'bs_input-boxes',
          'bs_input-boxes--box-model',
          'bs_margin--type',
        ],
      ],
      '#disable_live_preview' => TRUE,
    ];
    $default_value = 0;
    if (isset($storage['margin']['class'])) {
      $default_value = $this
        ->getStyleOptionIndexByClass('margin', $storage['margin']['class']);
    }
    $form['margin'] = [
      '#type' => 'range',
      '#title' => $this
        ->t('Margin'),
      '#min' => 0,
      '#max' => $this
        ->getStyleOptionsCount('margin'),
      '#step' => 1,
      '#default_value' => $default_value,
      '#attributes' => [
        'class' => [
          'bs-field-margin',
        ],
      ],
      '#states' => [
        'visible' => [
          ':input.bs_margin--type' => [
            'value' => 'margin',
          ],
        ],
      ],
    ];

    // Loop through the directions.
    for ($i = 0; $i < 4; $i++) {
      $default_value = 0;
      if (isset($storage['margin_' . $directions[$i]]['class'])) {
        $default_value = $this
          ->getStyleOptionIndexByClass('margin_' . $directions[$i], $storage['margin_' . $directions[$i]]['class']);
      }
      $form['margin_' . $directions[$i]] = [
        '#type' => 'range',
        '#title' => $this
          ->t('Margin @direction', [
          '@direction' => $directions[$i],
        ]),
        '#min' => 0,
        '#max' => $this
          ->getStyleOptionsCount('margin_' . $directions[$i]),
        '#step' => 1,
        '#default_value' => $default_value,
        '#attributes' => [
          'class' => [
            'bs-field-margin-' . $directions[$i],
          ],
        ],
        '#states' => [
          'visible' => [
            ':input.bs_margin--type' => [
              'value' => 'margin_' . $directions[$i],
            ],
          ],
        ],
      ];
    }

    // Pass margin options to drupal settings.
    $margin_options = [];
    $margin_options['margin'] = array_keys($this
      ->getStyleOptions('margin'));
    for ($i = 0; $i < 4; $i++) {
      $margin_options['margin_' . $directions[$i]] = array_keys($this
        ->getStyleOptions('margin_' . $directions[$i]));
    }
    $form['#attached']['drupalSettings']['bootstrap_styles']['spacing']['margin_classes_options'] = $margin_options;

    // Attach the Layout Builder form style for this plugin.
    $form['#attached']['library'][] = 'bootstrap_styles/plugin.margin.layout_builder_form';
    return $form;
  }

  /**
   * {@inheritdoc}
   */
  public function submitStyleFormElements(array $group_elements) {
    $directions = [
      'left',
      'top',
      'right',
      'bottom',
    ];
    $schema = [
      'margin' => [
        'class' => $this
          ->getStyleOptionClassByIndex('margin', $group_elements['margin']),
      ],
    ];
    for ($i = 0; $i < 4; $i++) {
      $schema['margin_' . $directions[$i]]['class'] = $this
        ->getStyleOptionClassByIndex('margin_' . $directions[$i], $group_elements['margin_' . $directions[$i]]);
    }
    return $schema;
  }

  /**
   * {@inheritdoc}
   */
  public function build(array $build, array $storage, $theme_wrapper = NULL) {
    $classes = [];
    $directions = [
      'left',
      'top',
      'right',
      'bottom',
    ];
    if (isset($storage['margin']['class'])) {
      $classes[] = $storage['margin']['class'];
    }
    for ($i = 0; $i < 4; $i++) {
      if (isset($storage['margin_' . $directions[$i]]['class'])) {
        $classes[] = $storage['margin_' . $directions[$i]]['class'];
      }
    }

    // Add the classes to the build.
    $build = $this
      ->addClassesToBuild($build, $classes, $theme_wrapper);

    // Attach bs-classes to the build.
    $build['#attached']['library'][] = 'bootstrap_styles/plugin.margin.build';
    return $build;
  }

}

Members

Namesort descending Modifiers Type Description Overrides
Margin::build public function Overrides StylePluginBase::build
Margin::buildConfigurationForm public function Overrides StylePluginBase::buildConfigurationForm
Margin::buildStyleFormElements public function Overrides StylePluginBase::buildStyleFormElements
Margin::submitConfigurationForm public function Overrides StylePluginBase::submitConfigurationForm
Margin::submitStyleFormElements public function Overrides StylePluginBase::submitStyleFormElements
PluginBase::$configuration protected property Configuration information passed into the plugin. 1
PluginBase::$pluginDefinition protected property The plugin implementation definition. 1
PluginBase::$pluginId protected property The plugin_id.
PluginBase::DERIVATIVE_SEPARATOR constant A string which is used to separate base plugin IDs from the derivative ID.
PluginBase::getBaseId public function Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface::getBaseId
PluginBase::getDerivativeId public function Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface::getDerivativeId
PluginBase::getPluginDefinition public function Gets the definition of the plugin implementation. Overrides PluginInspectionInterface::getPluginDefinition 2
PluginBase::getPluginId public function Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface::getPluginId
PluginBase::isConfigurable public function Determines if the plugin is configurable.
StringTranslationTrait::$stringTranslation protected property The string translation service. 4
StringTranslationTrait::formatPlural protected function Formats a string containing a count of items.
StringTranslationTrait::getNumberOfPlurals protected function Returns the number of plurals supported by a given language.
StringTranslationTrait::getStringTranslation protected function Gets the string translation service.
StringTranslationTrait::setStringTranslation public function Sets the string translation service to use. 2
StringTranslationTrait::t protected function Translates a string to the current language or to a given language.
StylePluginBase::$configFactory protected property The config factory.
StylePluginBase::addClassesToBuild public function Helper function to add the classes to the build.
StylePluginBase::config public function
StylePluginBase::CONFIG constant Config settings.
StylePluginBase::create public static function Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface::create 1
StylePluginBase::getStyleOptionClassByIndex public function Helper function to get the class from the options list.
StylePluginBase::getStyleOptionIndexByClass public function Helper function to get the index of the class at options list.
StylePluginBase::getStyleOptions public function Helper function to get the options of given style name.
StylePluginBase::getStyleOptionsCount public function Helper function to get the options of given style name.
StylePluginBase::getSvgIconMarkup public function Helper function to get SVG Markup.
StylePluginBase::getTitle public function Return the name of the Styles Group form plugin. Overrides StylePluginInterface::getTitle
StylePluginBase::validateConfigurationForm public function
StylePluginBase::__construct public function Constructs a StylePluginBase object. Overrides PluginBase::__construct 1