public function ViewEditFormController::getFormBucket

Add information about a section to a display.

1 call to ViewEditFormController::getFormBucket()
ViewEditFormController::getDisplayDetails in drupal/core/modules/views_ui/lib/Drupal/views_ui/ViewEditFormController.php
Helper function to get the display details section of the edit UI.

File

drupal/core/modules/views_ui/lib/Drupal/views_ui/ViewEditFormController.php, line 873
Contains Drupal\views_ui\ViewEditFormController.

Class

ViewEditFormController
Form controller for the Views edit form.

Namespace

Drupal\views_ui

Code

public function getFormBucket(ViewUI $view, $type, $display) {
  $executable = $view
    ->get('executable');
  $executable
    ->setDisplay($display['id']);
  $executable
    ->initStyle();
  $types = $executable
    ->viewsHandlerTypes();
  $build = array(
    '#theme_wrappers' => array(
      'views_ui_display_tab_bucket',
    ),
  );
  $build['#overridden'] = FALSE;
  $build['#defaulted'] = FALSE;
  $build['#name'] = $build['#title'] = $types[$type]['title'];
  $rearrange_url = "admin/structure/views/nojs/rearrange/{$view->id()}/{$display['id']}/{$type}";
  $rearrange_text = t('Rearrange');
  $class = 'icon compact rearrange';

  // Different types now have different rearrange forms, so we use this switch
  // to get the right one.
  switch ($type) {
    case 'filter':

      // The rearrange form for filters contains the and/or UI, so override
      // the used path.
      $rearrange_url = "admin/structure/views/nojs/rearrange-filter/{$view->id()}/{$display['id']}";
      $rearrange_text = t('And/Or, Rearrange');

      // TODO: Add another class to have another symbol for filter rearrange.
      $class = 'icon compact rearrange';
      break;
    case 'field':

      // Fetch the style plugin info so we know whether to list fields or not.
      $style_plugin = $executable->style_plugin;
      $uses_fields = $style_plugin && $style_plugin
        ->usesFields();
      if (!$uses_fields) {
        $build['fields'][] = array(
          '#markup' => t('The selected style or row format does not utilize fields.'),
          '#theme_wrappers' => array(
            'views_ui_container',
          ),
          '#attributes' => array(
            'class' => array(
              'views-display-setting',
            ),
          ),
        );
        return $build;
      }
      break;
    case 'header':
    case 'footer':
    case 'empty':
      if (!$executable->display_handler
        ->usesAreas()) {
        $build[$type][] = array(
          '#markup' => t('The selected display type does not utilize @type plugins', array(
            '@type' => $type,
          )),
          '#theme_wrappers' => array(
            'views_ui_container',
          ),
          '#attributes' => array(
            'class' => array(
              'views-display-setting',
            ),
          ),
        );
        return $build;
      }
      break;
  }

  // Create an array of actions to pass to theme_links
  $actions = array();
  $count_handlers = count($executable->display_handler
    ->getHandlers($type));

  // Create the add text variable for the add action.
  $add_text = t('Add <span class="element-invisible">@type</span>', array(
    '@type' => $types[$type]['ltitle'],
  ));
  $actions['add'] = array(
    'title' => $add_text,
    'href' => "admin/structure/views/nojs/add-item/{$view->id()}/{$display['id']}/{$type}",
    'attributes' => array(
      'class' => array(
        'icon compact add',
        'views-ajax-link',
      ),
      'id' => 'views-add-' . $type,
    ),
    'html' => TRUE,
  );
  if ($count_handlers > 0) {

    // Create the rearrange text variable for the rearrange action.
    $rearrange_text = $type == 'filter' ? t('And/Or Rearrange <span class="element-invisible">filter criteria</span>') : t('Rearrange <span class="element-invisible">@type</span>', array(
      '@type' => $types[$type]['ltitle'],
    ));
    $actions['rearrange'] = array(
      'title' => $rearrange_text,
      'href' => $rearrange_url,
      'attributes' => array(
        'class' => array(
          $class,
          'views-ajax-link',
        ),
        'id' => 'views-rearrange-' . $type,
      ),
      'html' => TRUE,
    );
  }

  // Render the array of links
  $build['#actions'] = array(
    '#type' => 'dropbutton',
    '#links' => $actions,
    '#attributes' => array(
      'class' => array(
        'views-ui-settings-bucket-operations',
      ),
    ),
  );
  if (!$executable->display_handler
    ->isDefaultDisplay()) {
    if (!$executable->display_handler
      ->isDefaulted($types[$type]['plural'])) {
      $build['#overridden'] = TRUE;
    }
    else {
      $build['#defaulted'] = TRUE;
    }
  }
  static $relationships = NULL;
  if (!isset($relationships)) {

    // Get relationship labels.
    $relationships = array();
    foreach ($executable->display_handler
      ->getHandlers('relationship') as $id => $handler) {
      $relationships[$id] = $handler
        ->adminLabel();
    }
  }

  // Filters can now be grouped so we do a little bit extra:
  $groups = array();
  $grouping = FALSE;
  if ($type == 'filter') {
    $group_info = $executable->display_handler
      ->getOption('filter_groups');

    // If there is only one group but it is using the "OR" filter, we still
    // treat it as a group for display purposes, since we want to display the
    // "OR" label next to items within the group.
    if (!empty($group_info['groups']) && (count($group_info['groups']) > 1 || current($group_info['groups']) == 'OR')) {
      $grouping = TRUE;
      $groups = array(
        0 => array(),
      );
    }
  }
  $build['fields'] = array();
  foreach ($executable->display_handler
    ->getOption($types[$type]['plural']) as $id => $field) {

    // Build the option link for this handler ("Node: ID = article").
    $build['fields'][$id] = array();
    $build['fields'][$id]['#theme'] = 'views_ui_display_tab_setting';
    $handler = $executable->display_handler
      ->getHandler($type, $id);
    if (empty($handler)) {
      $build['fields'][$id]['#class'][] = 'broken';
      $field_name = t('Broken/missing handler: @table > @field', array(
        '@table' => $field['table'],
        '@field' => $field['field'],
      ));
      $build['fields'][$id]['#link'] = l($field_name, "admin/structure/views/nojs/config-item/{$view->id()}/{$display['id']}/{$type}/{$id}", array(
        'attributes' => array(
          'class' => array(
            'views-ajax-link',
          ),
        ),
        'html' => TRUE,
      ));
      continue;
    }
    $field_name = check_plain($handler
      ->adminLabel(TRUE));
    if (!empty($field['relationship']) && !empty($relationships[$field['relationship']])) {
      $field_name = '(' . $relationships[$field['relationship']] . ') ' . $field_name;
    }
    $description = filter_xss_admin($handler
      ->adminSummary());
    $link_text = $field_name . (empty($description) ? '' : " ({$description})");
    $link_attributes = array(
      'class' => array(
        'views-ajax-link',
      ),
    );
    if (!empty($field['exclude'])) {
      $link_attributes['class'][] = 'views-field-excluded';

      // Add a [hidden] marker, if the field is excluded.
      $link_text .= ' [' . t('hidden') . ']';
    }
    $build['fields'][$id]['#link'] = l($link_text, "admin/structure/views/nojs/config-item/{$view->id()}/{$display['id']}/{$type}/{$id}", array(
      'attributes' => $link_attributes,
      'html' => TRUE,
    ));
    $build['fields'][$id]['#class'][] = drupal_clean_css_identifier($display['id'] . '-' . $type . '-' . $id);
    if ($executable->display_handler
      ->useGroupBy() && $handler
      ->usesGroupBy()) {
      $build['fields'][$id]['#settings_links'][] = l('<span class="label">' . t('Aggregation settings') . '</span>', "admin/structure/views/nojs/config-item-group/{$view->id()}/{$display['id']}/{$type}/{$id}", array(
        'attributes' => array(
          'class' => 'views-button-configure views-ajax-link',
          'title' => t('Aggregation settings'),
        ),
        'html' => TRUE,
      ));
    }
    if ($handler
      ->hasExtraOptions()) {
      $build['fields'][$id]['#settings_links'][] = l('<span class="label">' . t('Settings') . '</span>', "admin/structure/views/nojs/config-item-extra/{$view->id()}/{$display['id']}/{$type}/{$id}", array(
        'attributes' => array(
          'class' => array(
            'views-button-configure',
            'views-ajax-link',
          ),
          'title' => t('Settings'),
        ),
        'html' => TRUE,
      ));
    }
    if ($grouping) {
      $gid = $handler->options['group'];

      // Show in default group if the group does not exist.
      if (empty($group_info['groups'][$gid])) {
        $gid = 0;
      }
      $groups[$gid][] = $id;
    }
  }

  // If using grouping, re-order fields so that they show up properly in the list.
  if ($type == 'filter' && $grouping) {
    $store = $build['fields'];
    $build['fields'] = array();
    foreach ($groups as $gid => $contents) {

      // Display an operator between each group.
      if (!empty($build['fields'])) {
        $build['fields'][] = array(
          '#theme' => 'views_ui_display_tab_setting',
          '#class' => array(
            'views-group-text',
          ),
          '#link' => $group_info['operator'] == 'OR' ? t('OR') : t('AND'),
        );
      }

      // Display an operator between each pair of filters within the group.
      $keys = array_keys($contents);
      $last = end($keys);
      foreach ($contents as $key => $pid) {
        if ($key != $last) {
          $store[$pid]['#link'] .= '&nbsp;&nbsp;' . ($group_info['groups'][$gid] == 'OR' ? t('OR') : t('AND'));
        }
        $build['fields'][$pid] = $store[$pid];
      }
    }
  }
  return $build;
}