function domain_views_views_data in Domain Access 6.2
Implement hook_views_data().
File
- domain_views/
domain_views.views.inc, line 15 - Provides the views data and handlers for domain.module.
Code
function domain_views_views_data() {
$data = array();
// Define the {domain} table.
$data['domain']['table']['group'] = t('Domains');
// We can use this as a base table for Views.
$data['domain']['table']['base'] = array(
'field' => 'domain_id',
'title' => t('Domains'),
'help' => t('Domain Access uses domains to divide and display content on a group of related sites.'),
);
//Define the joins.
$data['domain']['table']['join']['node'] = array(
'left_table' => 'domain_access',
'left_field' => 'gid',
'field' => 'domain_id',
);
//Define the joins between {node_revision} and {domain}.
$data['domain']['table']['join']['node_revisions'] = array(
'left_table' => 'domain_access',
'left_field' => 'gid',
'field' => 'domain_id',
);
// Define the fields.
$data['domain']['domain_id'] = array(
'title' => t('Domain ID'),
'help' => t('The unique id key for the active domain.'),
'field' => array(
'click sortable' => TRUE,
'handler' => 'domain_views_handler_field_domain_id',
),
// Information for accepting a domain_id as a filter
'filter' => array(
'handler' => 'domain_views_handler_filter_domain_domain_id',
),
// Information for sorting on a domain_id.
'sort' => array(
'handler' => 'views_handler_sort',
),
);
$data['domain']['subdomain'] = array(
'title' => t('Subdomain'),
'help' => t('The URL string that identifies a domain.'),
'field' => array(
'click sortable' => TRUE,
),
// Information for accepting a domain_id as a filter
'filter' => array(
'handler' => 'views_handler_filter_string',
),
// Information for sorting on a domain_id.
'sort' => array(
'handler' => 'views_handler_sort',
),
);
$data['domain']['sitename'] = array(
'title' => t('Site name'),
'help' => t('The display string that identifies a domain.'),
'field' => array(
'handler' => 'domain_views_handler_field_domain_sitename',
'click sortable' => TRUE,
),
// Information for accepting a domain_id as a filter
'filter' => array(
'handler' => 'views_handler_filter_string',
),
// Information for sorting on a domain_id.
'sort' => array(
'handler' => 'views_handler_sort',
),
);
$data['domain']['scheme'] = array(
'title' => t('Scheme'),
'help' => t('The http protocol used by the domain.'),
'field' => array(
'click sortable' => TRUE,
),
// Information for accepting a domain_id as a filter
'filter' => array(
'handler' => 'views_handler_filter_string',
),
// Information for sorting on a domain_id.
'sort' => array(
'handler' => 'views_handler_sort',
),
);
$data['domain']['valid'] = array(
'title' => t('Valid'),
'help' => t('A boolean flag indicating the domain can be seen by site visitors.'),
'field' => array(
'handler' => 'views_handler_field_boolean',
'click sortable' => TRUE,
),
// Information for accepting a domain_id as a filter
'filter' => array(
'handler' => 'views_handler_filter_boolean_operator',
'label' => t('Valid'),
),
// Information for sorting on a domain_id.
'sort' => array(
'handler' => 'views_handler_sort',
),
);
// Define the {domain_access} table.
$data['domain_access']['table']['group'] = t('Domain Access');
// Define the joins.
$data['domain_access']['table']['join']['node'] = array(
'left_field' => 'nid',
'field' => 'nid',
);
// Define the join between {node_revisions} and {domain_access} table
$data['domain_access']['table']['join']['node_revisions'] = array(
'left_field' => 'nid',
'field' => 'nid',
);
$data['domain_access']['table']['join']['domain'] = array(
'left_field' => 'domain_id',
'field' => 'gid',
'extra' => array(
array(
'field' => 'realm',
'value' => 'domain_id',
'numeric' => FALSE,
),
),
);
// Define the fields.
$data['domain_access']['nid'] = array(
'title' => t('Node ID'),
'help' => t('The node id.'),
'field' => array(
'click sortable' => TRUE,
),
// Information for accepting a domain_id as a filter
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
// Information for sorting on a domain_id.
'sort' => array(
'handler' => 'views_handler_sort',
),
'relationship' => array(
'title' => t('Domain node'),
'help' => t("Bring in information about the domain this node is assigned to."),
'base' => 'node',
'field' => 'nid',
'handler' => 'views_handler_relationship',
'label' => t('Domain node'),
),
);
// Define the fields.
$data['domain_access']['gid'] = array(
'title' => t('Domain ID'),
'help' => t('The domain id of the record.'),
'field' => array(
'click sortable' => TRUE,
'handler' => 'domain_views_handler_field_domain_id',
),
// Information for accepting a domain_id as a filter
'filter' => array(
'handler' => 'domain_views_handler_filter_domain_access_gid',
),
// Information for sorting on a domain_id.
'sort' => array(
'handler' => 'views_handler_sort',
),
// Information accepting domain_id as an argument
'argument' => array(
'handler' => 'domain_views_handler_argument_domain_access_gid',
),
);
// Define the fields.
$data['domain_access']['realm'] = array(
'title' => t('Access Type'),
'help' => t('The domain realm.'),
'field' => array(
'click sortable' => TRUE,
),
// Information for accepting a domain_id as a filter
'filter' => array(
'handler' => 'views_handler_filter_string',
),
// Information for sorting on a domain_id.
'sort' => array(
'handler' => 'views_handler_sort',
),
);
// Define available on current domain field
$data['domain_access']['current_all'] = array(
'title' => t('Available on current domain'),
'help' => t('Filters out nodes not available on current domain (published to current domain or all affiliates)'),
'field' => array(
'handler' => 'views_handler_field_boolean',
'click sortable' => TRUE,
),
'filter' => array(
'field' => 'gid',
'handler' => 'domain_views_handler_filter_domain_access_current_all',
'label' => t('Available on current domain'),
),
);
// Define the {domain_editor} table.
$data['domain_editor']['table']['group'] = t('Domain Editor');
// Define the joins.
$data['domain_editor']['table']['join']['domain'] = array(
'left_field' => 'domain_id',
'field' => 'domain_id',
);
$data['domain_editor']['table']['join']['users'] = array(
'left_field' => 'uid',
'field' => 'uid',
);
$data['domain_editor']['table']['join']['node'] = array(
'left_field' => 'uid',
'field' => 'uid',
);
// Define the join between {node_revisions} and {domain_editor} table
$data['domain_editor']['table']['join']['node_revisions'] = array(
'left_field' => 'uid',
'field' => 'uid',
);
// Define the fields.
$data['domain_editor']['uid'] = array(
'title' => t('User ID'),
'help' => t('The user\'s id.'),
'field' => array(
'click sortable' => TRUE,
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
),
'sort' => array(
'handler' => 'views_handler_sort',
),
);
// Define the fields.
$data['domain_editor']['domain_id'] = array(
'title' => t('Domain ID'),
'help' => t('The domain(s) an editor is assigned to.'),
'field' => array(
'click sortable' => TRUE,
'handler' => 'domain_views_handler_field_domain_id',
),
// Information for accepting a domain_id as a filter
'filter' => array(
'handler' => 'domain_views_handler_filter_domain_domain_id',
),
// Information for accepting a domain_id as a filter
'argument' => array(
'handler' => 'domain_views_handler_argument_domain_access_gid',
),
// Information for sorting on a domain_id.
'sort' => array(
'handler' => 'views_handler_sort',
),
'relationship' => array(
'title' => t('Domain editors'),
'help' => t("Bring in information about the domain this user is assigned to."),
'base' => 'domain',
'field' => 'domain_id',
'handler' => 'views_handler_relationship',
'label' => t('Domain editors'),
),
);
return $data;
}