回答:
カスタムモジュールを作成し、交換するMODULENAME
モジュールの名前とし、field_image
自分のフィールドの名前で:
/**
* Implements hook_entity_view().
*/
function MODULENAME_entity_view($entity, $type, $view_mode, $langcode) {
if ($view_mode == 'teaser') {
$entity->content['field_image']['#items'] = array_slice($entity->content['field_image']['#items'], 0, 1);
}
}
詳細については、hook_entity_view()のドキュメントを参照してください。
if ($view_mode == 'teaser' && $entity->type == 'CONTENT_TYPE')
。
最初の画像を表示する新しいフィールドを作成するためにhook_field_extra_fields()とhook_node_view()を使用し、元の画像フィールドを改ざんしないようにしました。
hook_field_extra_fields()は、ノードタイプの管理表示タブに表示される新しいフィールドを初期化します。
function HOOK_field_extra_fields() {
$extra['node']['NODE_TYPE'] = array(
'display' => array(
'primary_image' => array(
'label' => t('Primary Image'),
'weight' => 0,
)
),
);
return $extra;
}
次に、hook_node_view()を使用して、新しいフィールドのコンテンツとなる最初の画像を追加します。
function HOOK_node_view($node, $view_mode, $langcode) {
if($node->type == 'NODE_TYPE' && $view_mode == 'teaser') {
//make sure there are images
if(!empty($node->field_images)) {
$node->content['primary_image'] = $node->content['field_images'][0];
//hide the original field with multiple images
hide($node->content['field_images']);
}
}
}
注:表示スイートを有効にしている場合は、表示管理タブでこれを行うことができます。