Risposte:
Crea un modulo personalizzato, sostituiscilo MODULENAME
con il nome del modulo e field_image
con il nome del tuo campo:
/**
* 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);
}
}
Vedere la documentazione di hook_entity_view () per maggiori dettagli.
if ($view_mode == 'teaser' && $entity->type == 'CONTENT_TYPE')
.
Non è necessario scrivere codice personalizzato.
Prova a utilizzare il modulo Limite multiplo campo .
Ti consente di accedere alle impostazioni di visualizzazione per il tuo tipo di contenuto e configurare le impostazioni del teaser per visualizzare solo una determinata quantità di valori. Puoi anche fargli saltare i valori, ad esempio se vuoi che mostri i valori da 2 a 5
.
Ho usato hook_field_extra_fields () e hook_node_view () per creare un nuovo campo per visualizzare la prima immagine in modo da non alterare il campo delle immagini originali.
hook_field_extra_fields () inizializza il nuovo campo che apparirà nella scheda di gestione del tipo di nodo.
function HOOK_field_extra_fields() {
$extra['node']['NODE_TYPE'] = array(
'display' => array(
'primary_image' => array(
'label' => t('Primary Image'),
'weight' => 0,
)
),
);
return $extra;
}
Quindi hook_node_view () viene utilizzato per aggiungere la prima immagine al contenuto del nuovo campo.
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']);
}
}
}
NOTA: se la suite di display è abilitata, è possibile farlo nella scheda Gestisci display.