You are here

class RedhenEngagementViewsController in RedHen CRM 7

RedhenMembership Views Controller class.

Hierarchy

Expanded class hierarchy of RedhenEngagementViewsController

1 string reference to 'RedhenEngagementViewsController'
redhen_engagement_entity_info in modules/redhen_engagement/redhen_engagement.module
Implements hook_entity_info().

File

modules/redhen_engagement/lib/redhen_engagement.views.inc, line 6

View source
class RedhenEngagementViewsController extends EntityDefaultViewsController {

  /**
   * Add extra fields to views_data().
   */
  public function views_data() {
    $data = parent::views_data();
    $entity_info = entity_get_info();
    foreach ($entity_info as $entity_type => $info) {
      if ($entity_type == 'redhen_note') {

        // Entity to Engagement.
        $data[$info['base table']]['redhen_engagement_rel'] = array(
          'group' => t('Engagement'),
          'title' => t('@entity to Engagement', array(
            '@entity' => drupal_ucfirst($info['label']),
          )),
          'help' => t('The Note associated with the @entity entity.', array(
            '@entity' => drupal_ucfirst($info['label']),
          )),
          'relationship' => array(
            'entity' => $entity_type,
            'handler' => 'redhen_membership_handler_relationship',
            'label' => t('@entity being the Note', array(
              '@entity' => $entity_type,
            )),
            'base' => 'redhen_engagement',
            'base field' => 'entity_id',
            'relationship field' => $info['entity keys']['id'],
          ),
        );

        // Engagement to entity.
        $data['redhen_engagement']['redhen_engagement_related_' . $entity_type] = array(
          'group' => t('Engagement'),
          'title' => t('Engagement to @entity', array(
            '@entity' => drupal_ucfirst($info['label']),
          )),
          'help' => t('The @entity entity that is associated with the Engagement.', array(
            '@entity' => $info['label'],
          )),
          'relationship' => array(
            'handler' => 'views_handler_relationship',
            'label' => t('@entity from Note', array(
              '@entity' => $entity_type,
            )),
            'base' => $info['base table'],
            'base field' => $info['entity keys']['id'],
            'relationship field' => 'entity_id',
          ),
        );
      }
    }
    return $data;
  }

}

Members

Namesort descending Modifiers Type Description Overrides
EntityDefaultViewsController::$type protected property
EntityDefaultViewsController::getRelationshipHandlerClass public function Determines the handler to use for a relationship to an entity type.
EntityDefaultViewsController::map_from_schema_info protected function Comes up with views information based on the given schema and property info.
EntityDefaultViewsController::optionsListCallback public static function A callback returning property options, suitable to be used as views options callback.
EntityDefaultViewsController::schema_fields protected function Try to come up with some views fields with the help of the schema and the entity property information.
EntityDefaultViewsController::schema_revision_fields protected function Try to come up with some views fields with the help of the revision schema and the entity property information.
EntityDefaultViewsController::__construct public function
RedhenEngagementViewsController::views_data public function Add extra fields to views_data(). Overrides EntityDefaultViewsController::views_data