Ho creato un blocco vista, il cui nome macchina è "notizie".
Come lo visualizzo usando module_invoke()
e il nome della macchina della vista?
Ho creato un blocco vista, il cui nome macchina è "notizie".
Come lo visualizzo usando module_invoke()
e il nome della macchina della vista?
Risposte:
Utilizzare views_embed_view()
:
echo views_embed_view('view_machine_name', 'block_1');
Puoi scoprire il nome visualizzato facendo clic sulla scheda e controllarne il nome nella barra degli indirizzi del tuo browser: #views-tab-block_1
ti dà block_1
.
{{ drupal_view('view_machine_name', 'block_1') }}
Se si desidera passare un parametro alla vista utilizzare:
echo views_embed_view('view_machine_name', 'block_1', $param);
Per esempio:
echo views_embed_view('view_machine_name', 'block_1', $node->nid);
o:
echo views_embed_view('view_machine_name', 'block_1', $nid, $uid);
La risposta di tostinni è quella corretta nella maggior parte dei casi. Tuttavia, se si desidera includere il titolo Visualizza, è un po 'più brutto.
Dalla views_embed_view()
documentazione:
Si noti che questa funzione NON visualizza il titolo della vista. Se vuoi farlo, dovrai fare ciò che questa funzione fa manualmente, caricando la vista, ottenendo l'anteprima e quindi ottenendo
$view->get_title()
.
Per esempio:
$name = 'view_machine_name';
$display_id = 'block_1';
$view = views_get_view($name);
if (!$view || !$view->access($display_id)) {
return;
}
$view_content = $view->preview($display_id);
$title = $view->get_title();
Aggiornato : @rojosnow ha notato che i documenti sottolineano che è necessario ottenere l'anteprima prima di chiamare, get_title()
quindi ho capovolto quelle due righe.
Questo ha funzionato per me:
$view = views_get_view('view_machine_name');
$view->set_display('Master');
$view->get_title();
$response = $view->preview('You_Block_id');
// e lo ha chiamato in html come questo //
<div class="col-md-4 col-sm-6">
<div class="blocksOuterWrapper companyNewsWrapper">
'.$response.'
</div>
</div>
Nota, per me viene chiamato il blocco predefinito (senza nome) block
anziché block_1
:
<?php echo views_embed_view('news_archive', 'block'); ?>
Basandoci anche sulla risposta di tostinni:
Se non si desidera visualizzare alcun HTML se la vista non ha risultati. Inoltre, aggiungi un titolo, ma solo se ci sono risultati.
if (array_filter(views_get_view_result('view_machine_name', 'block_1'))) {
print '<h2 class="my-view-block-title">Special Title</h2>';
print views_embed_view('view_machine_name', 'block_1');
}
È possibile eseguire il rendering del blocco anziché renderizzare le visualizzazioni con il seguente codice.
<?php
$block = block_load($module, $delta);
$render_array = _block_get_renderable_array(_block_render_blocks(array($block)));
$output = render($render_array);
print $output;
?>
Dalla mia esperienza, puoi trasformare un percorso in un titolo o contenuto di una vista con una funzione come la seguente.
<?php
function view_path_to_title($path)
{
// only if your path is a URL alias
$sql = "SELECT src FROM {url_alias} WHERE dst = '%s'";
$src = db_result(db_query($sql, $path));
// if you do not use URL aliases, you probably use $path here instead of $src
$menu_item = menu_get_item($src);
// make sure it worked as expected
if(!empty($menu_item)
&& $menu_item["page_callback"] == "views_page"
&& count($menu_item["page_arguments"]) >= 2)
{
$args = $menu_item["page_arguments"];
$view = views_get_view($args[0]);
}
else
{
$view = null;
}
if ($view)
{
// just loading a view is not quite enough, we have to setup the
// arguments, including the display, and the "execute" the view
$view->set_display($args[1]);
array_shift($args); // view name
array_shift($args); // display name
$view->set_arguments($args);
$view->execute();
$title = $view->get_title();
if($title)
{
return $title;
}
}
// some "random" default
return $path;
}
Per eseguire il rendering della vista, utilizzare $view->render()
invece di $view->get_title()
.
Di sicuro, fino a quando non ho chiamato correttamente il $view->execute()
, niente ha funzionato bene. Vorrei ottenere stringhe vuote (forse null) come valori di ritorno.