function node_gallery_views_data in Node Gallery 6.3
Same name and namespace in other branches
- 6.2 node_gallery.views.inc \node_gallery_views_data()
@file Views integration for Node Gallery
File
- views2inc/
node_gallery.views.inc, line 9 - Views integration for Node Gallery
Code
function node_gallery_views_data() {
$data['node_gallery_images']['table']['group'] = t("Node Gallery: Image");
$data['node_gallery_images']['table']['join'] = array(
'node' => array(
'left_field' => 'nid',
'field' => 'nid',
),
);
$data['node_gallery_images']['gid'] = array(
'title' => t("Parent Gallery"),
'help' => t("The Id of the image's gallery."),
'field' => array(
'handler' => 'views_handler_field_node',
'click sortable' => TRUE,
),
'relationship' => array(
'label' => t('Parent Gallery'),
'base' => 'node',
'base field' => 'nid',
),
'argument' => array(
'handler' => 'views_handler_argument_node_nid',
'name field' => 'title',
// the field to display in the summary.
'numeric' => TRUE,
'validate type' => 'nid',
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'sort' => array(
'handler' => 'views_handler_sort',
),
);
$data['node_gallery_images']['weight'] = array(
'title' => t('Image weight'),
'help' => t('The weight assigned to the image. Used for sorting within a gallery.'),
'field' => array(
'handler' => 'views_handler_field',
),
'sort' => array(
'handler' => 'views_handler_sort',
),
);
$data['node_gallery_images']['navigator'] = array(
'title' => t('Image Navigator'),
'help' => t('A themed navigator for browsing previous and next images.'),
'field' => array(
'handler' => 'node_gallery_views_handler_image_navigator',
'click sortable' => FALSE,
'notafield' => TRUE,
),
);
$data['node_gallery_galleries']['table']['group'] = t('Node Gallery: Gallery');
$data['node_gallery_galleries']['table']['join'] = array(
'node' => array(
'left_field' => 'nid',
'field' => 'gid',
),
);
$node_schema = drupal_get_schema('node');
$fields = array_keys($node_schema['fields']);
$pos = array_search('nid', $fields);
if ($pos !== FALSE) {
array_splice($fields, $pos, 1);
}
$node_fields = 'node.' . implode(', node.', $fields);
$data['node_gallery_galleries']['newest_image'] = array(
'title' => t('Gallery Newest Image'),
'help' => t('Relationship to link the newest image for the gallery.'),
'relationship' => array(
'label' => t('Gallery Newest Image'),
'base' => 'node',
'table formula' => '(SELECT gid, ' . $node_fields . ', MAX(ngi.nid) as nid FROM {node_gallery_images} ngi JOIN {node} node ON ngi.nid = node.nid GROUP BY gid)',
'base field' => 'gid',
'relationship field' => 'gid',
),
);
$data['node_gallery_galleries']['oldest_image'] = array(
'title' => t('Gallery Oldest Image'),
'help' => t('Relationship to link the oldest image for the gallery.'),
'relationship' => array(
'label' => t('Gallery Oldest Image'),
'base' => 'node',
'table formula' => '(SELECT gid, ' . $node_fields . ', MIN(ngi.nid) AS nid FROM {node_gallery_images} ngi JOIN {node} node ON ngi.nid = node.nid GROUP BY gid)',
'base field' => 'gid',
'relationship field' => 'gid',
),
);
$data['node_gallery_galleries']['cover_image'] = array(
'title' => t('Gallery Cover Image'),
'help' => t('Relationship to link the cover image for the gallery.'),
'relationship' => array(
'label' => t('Gallery Cover Image'),
'base' => 'node',
'base field' => 'nid',
),
);
// Note: "image_count" field alias is somewhat confusing, because the field
// only counts published images.
// Keep it only to not break existing views.
$data['node_gallery_galleries']['image_count'] = array(
'title' => t('Published Image Count'),
'help' => t('The number of published images in the gallery.'),
'real field' => 'pub_img_count',
'field' => array(
'handler' => 'views_handler_field_numeric',
'click sortable' => TRUE,
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
'numeric' => TRUE,
'validate type' => 'numeric',
),
);
$data['node_gallery_galleries']['img_count'] = array(
'title' => t('Image Count'),
'help' => t('The total number of published and unpublished images in the gallery.'),
'field' => array(
'handler' => 'views_handler_field_numeric',
'click sortable' => TRUE,
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
'sort' => array(
'handler' => 'views_handler_sort',
),
'argument' => array(
'handler' => 'views_handler_argument_numeric',
'numeric' => TRUE,
'validate type' => 'numeric',
),
);
$data['node_gallery_galleries']['comments_count'] = array(
'title' => t('Total comments'),
'help' => t('The total number of comments on the gallery and all its images.'),
'field' => array(
'handler' => 'node_gallery_views_handler_comments_count',
'click sortable' => TRUE,
'notafield' => TRUE,
),
);
$data['node_gallery_galleries']['image_date'] = array(
'title' => t('Image Updated Date'),
'help' => t('The last changed date of an image in the gallery.'),
'field' => array(
'handler' => 'node_gallery_views_handler_image_date',
'click sortable' => TRUE,
'notafield' => TRUE,
),
);
$data['node_gallery_galleries']['gid'] = array(
'title' => t("Gallery Id"),
'help' => t("The Id of the gallery."),
'field' => array(
'handler' => 'views_handler_field',
'click sortable' => TRUE,
),
'filter' => array(
'handler' => 'views_handler_filter_numeric',
),
);
return $data;
}