6.x

Configurar el breadcrumb para que siga la ruta en el url

Para configurar el breadcrumb y que siga exáctamente la ruta que se encuentra en el path lo podemos hacer con el siguiente código:


<?php
/**
* url breadcrumbs
* several functions
* http://drupal.org/node/93500
*/

function url_breadcrumb($breadcrumb) {
$url = path_alias_array();

// On admin pages, use the default breadcrumb. But I prefer having the
// title of the current page display as well. So I remove the ''
// tag from the original breadcrumb with substr() and add in the title with
// drupal_get_title().

Agregar <span> a primary-links para lograr el efecto 'Sliding Door Tabs'

Para agregar el efecto se puede hacer de dos maneras.

Con jQuery
Esta es muy sencilla, solo hay que agregar un archivo llamado 'script.js' en nuestro theme y poner dentro:

// Wrap span tags around the anchor text in the primary menu.
$(document).ready(function(){
  $("#primary li a")
  .wrapInner("<span>" + "</span>");
});

Utilizando theme_links
La manera correcta de hacer esto es utilizando lo que se llama un override de una función. Para esto vamos a poner en template.php lo siguiente:


<?php
/**

¿Cómo agregar un css id o class a 'local task' o 'primary' tabs para agregar un icono?

Cuando hablamos de local task estamos hablando de los enlaces que se colocan debajo de un nodo por ejemplo y nos indican cierta acción, lo más comun es que tengamos 'View' y 'Edit' si tenemos permisos.

Si queremos agregar un 'id' para que con CSS podamos agregar algún ícono a cada uno de manera independiente lo podremos hacer de esta manera:


function phptemplate_menu_local_task($link, $active = FALSE) {
$output = '';
$getcsslink = check_plain($link);

if(strpos($getcsslink, 'View')) {
$submitcase = 'View';
}
if(strpos($getcsslink, 'Edit')) {

Ocultar tips e input format

Para ocultar los "tips" y el input format que aparece debajo de cada nodo cuando lo estamos creando o editando, lo podemos hacer de distintas maneras, una de ellas es simplemente usar css y poner "display: none;" sin embargo puede que no sea la más apropiada.

La mejor solución a este problema sin duda es la siguiente:

<?php
/*
* Override filter.module's theme_filter_tips() function to disable tips display.
*/
function phptemplate_filter_tips($tips, $long = FALSE, $extra = '') {
  return
'';
}
function
phptemplate_filter_tips_more_info () {
  return
'';
}
?>

Cambiar el texto en un botón de views cuando usamos exposed filters

Para modificar el nombre de un botoń en views cuando usamos exposed filters lo podemos hacer con preprocess para que el cambio se haga antes de que la forma se construya, este es el código:


function MYTHEME_preprocess_views_exposed_form(&$vars, $hook) {

// only alter the jobs search exposed filter form
if ($vars['form']['#id'] == 'views-exposed-form-jobs-search-page-1') {

// Change the text on the submit button
$vars['form']['submit']['#value'] = t('Search');

// Rebuild the rendered version (submit button, rest remains unchanged)

Convertir multiple select en radios o checkboxes

Este pequeño módulo lo que hace es convertir, para el puro caso de taxonomías, una lista de selección de términos múltiples en la que usamos Control para seleccionar opciones, en una lista de checkboxes o radios, lo cual es mas conveniente y más sencillo para el usuario.

El artículo original incluye la posiblidad de hacer esto para Drupal 5.x, sin embargo en este caso solo vamos a analizar el caso para Drupal 6.x. El artículo original es: http://drupal.org/node/84286

Para hacer esto tenemos que crear un módulo llamado alterform, mismo que se incluye al final como attachment.

Personalizar el breadcrumb

Para personalizar el breadcrumb y mostrar el título de la página que se está viendo, lo podemos hacer con el siguiente cógido:

<?php
function phptemplate_breadcrumb($breadcrumb) {
 
$sep = ' &gt; ';
  if (
count($breadcrumb) > 0) {
    return
implode($breadcrumb, $sep) . $sep;
  }
  else {
    return
t("Home");
  }
}
?>

En page.tpl.php tendremos que poner:

<?php print $breadcrumb . $title; ?>

De http://drupal.org/node/64067

Ocultar un Tab en una página de organic groups y reemplazarla con otro valor.

Para ocultar un Tab en particular (menu_local_task) en una página determinada lo podemos hacer de varias maneras, para Drupal 6.x lo podemos hacer con un preprocess de la siguiente manera.


<?php
function phptemplate_preprocess(&$variables, $hook) {

if (arg(0) == 'node' && is_numeric(arg(1))) {
$node = node_load(arg(1));
if ($hook == 'page') {
if ($node->type == 'community') {
theme_removetab('View', $variables);
}
if ($node->type != 'community') {
theme_removetab('Home', $variables);
}
}
}

return $variables;
}

Cómo formatear $submitted para mostrar el autor y la fecha de creación de otra manera

Para mostrar la información que se guarda en $submitted lo podemos hacer de esta manera:

<?php
   
return t('Submitted by !username on @datetime',
      array(
       
'!username' => theme('username', $node),
       
'@datetime' => format_date($node->created),
      )
    );
?>

¿Cómo separo múltiples términos en el área de terms en Drupal 6.x?

En un artículo anterior vimos como separar las categorías para Drupal 5.x, este ya no funciona para Drupal 6.x, pero hay otra manera de hacerlo, incluso más personalizable.

En este caso tenemos 4 categorías:

  • Free Tags
  • Categoria
  • Audiencia
  • Material

Y utilizamos en template.php


<?php
function phptemplate_preprocess_node(&$variables) {
$node = $variables['node'];

// Display the current node's free-tags (but not other vocabs/terms)
$freetags = array();
foreach ($node->taxonomy as $term) {

Syndicate content