Joomla: pulsante per visualizzare un componente in una finestra modal

Alcuni appunti per visualizzare in una finestra modale un view di un componente joomla.

Il codice di riferimento è il seguente:

JHTML::_('behavior.modal', 'a.modal-button');
$link = JRoute::_( 'index.php?option=com_agimm&view=foto&tmpl=component' );
echo JHTML::link( $link, 'Foto', array(
    "class" => "modal-button",
    "rel" => "{handler: 'iframe', size: {x: 640, y: 480} }"
) );

Se il link si riferisce ad un componente joomla è possibile inserire il parametro tmp con  il valore component per visualizzare solo il componente senza i menu di sistema.

Joomla: messa a punto su host Aruba

Alcune annotazioni per la messa a punto di una installazione liscia di Joomla su host Aruba, ovvero senza utilizzare l’Application Installer  di quest0ultima.

  • In Configurazione globale / Server / Configurazione ftp non abilitare il wrapper ftp altrimenti si avrà problemi durante l’installazione delle estensioni
  • Se in Configurazione globale / Sito / Configurazione SEO è stato abilitato utilizza mod_rewrite eseguire i seguenti cambiamenti al file .htaccess
    • Commentare la linea 23 in modo da renderla così:
      #Options +FollowSymLinks
    • Decommentare la linea 59 in modo da renderla così:
      RewriteBase /
  • Se si verificano problemi strani (esempio estensioni che non funzionano dopo averle installate) provare ad eseguire un reset dei permessi dei file utilizzando l’apposita funzione Riparazione Permissions del pannello di controllo di Aruba

flowplayer: risolvere problemi di black screen disabilitando la compressione gzip di apache

Recentemente ho usato flowplayer per riprodurre alcuni file flv da utilizzare come intro e presentazioni su un sito che stò sviluppando.

Flowplayer è un player flash multiformato veramente ottimo che supporta tantissime features.

Testando il sito in locale sulla mia Debian era tutto funzionante, una volta pubblicato invece mi sono inbattuo in un problema molto strano: al momento della riproduzione dei file flv questi non venivano visualizzati mostrando invece un blocco completamente nero.

Facendo alcune ricerche sul forum di supporto ho trovato la soluzione: il problema è derivato della compressione gzip che in alcune installazioni di apache viene utilizzata; essendo questa attiva causa problemi nel caricamento dei file swf di flowplayer.

La soluzione è disablitare la compressione gzip per i file swf di flowplayer creando nella directory dove questi sono riposti un file .htaccess con la seguente linea:

SetEnv no-gzip dont-vary

Apache: abilitare mod_rewrite in locale

Appunti per abilitare il mod_rewrite in locale sulla mia debian:

  • Verificare che sia in /etc/apache2/mods-enabled sia presente un link a ../mods-available/rewrite.load
  • Modificare la configurazione del virtual host present in /etc/apache2/sites-available commentando la direttiva AllowOverride None e inserendo AllowOverride all come segue:
    <Directory /var/www/>
    Options Indexes FollowSymLinks MultiViews
    #AllowOverride None
    AllowOverride all
    Order allow,deny
    allow from all
    </Directory>
  • Riavviare apache
  • Verificare che mod_rewrite tramite la pagina l’istruzione php:
    phpinfo(INFO_MODULES);
  • Verificare il funzionamento con il tutorial indicato qui

Joomla: aggiungere helpers personalizzati a JHTML

Di seguito riporto alcuni appunti che indicano come aggiungere degli helpers personalizzati alla classe JHTML che potranno essere richiamati con la classica chiamata

JHTML::_( "prefix.file.function", ........ );

Con il parametro riportato sopra “prefix.file.function” si indica l’helper da richiamare specificando il prefisso della classe (opzionale, se non riportato viene assunto il valore JHTML), il nome del file che poi deve anche essere il suffisso della classe, e il metodo della classe da richiamare.

Per esempio, generalmente si utilizza la seguente chiamata

JHTML::_( "grid.publisher", $row, $i );

per generare codice HTML con il quale eseguire il rendering del pulsante di pubblicazione/non pubblicazione.

Nel caso sopra indicato viene in pratica eseguita la chiamata a JHTMLGrid::publisher(). Per eseguire tale chiamata viene composto il nome della classe, nome delle funzione e nome del file da caricare prendendo il primo argomento fornitoro a JHTML::_():

  • classe JHTMLGrid: composta dal prefisso JHTML (preso di default perché non specificato) e dal suffisso Grid preso dalla prima parte di grid.published
  • funzione published(): presa dalla seconda parte di grid.published
  • file grid.php da cui da cui caricare la classe: preso dalla prima parte grid.published

A questo punto capito il meccanismo con cui viene richiamato l’helper possiamo crearne uno nostro. Di seguito riporto come esempio l’helper che ho creato per eseguire un  nuovo tipo di pubblicazione ovvero chiamato publishedHd, che dovrebbe servire per eseguire la pubblicazione/non pubblicazione di un elemento che qui non sto a specificare.

La chiamata viene eseguita nel seguente modo:

JHTML::_( "extendedgrid.publisherHd", $row, $i );

che in pratica richiama JHTMLExtendgrid::publishedHd( $row, $i ) contenuta nel file extendedgrid.php

Di seguito riporto il codice sorgente della classe JHTMLExtendedgrid:

class JHTMLExtendgrid extends JHTMLGrid
{
  function publishedHd( &$row, $i, $imgY = 'tick.png', $imgX = 'publish_x.png', $prefix='' )
  {
    $img    = $row->published_hd ? $imgY : $imgX;
    $task   = $row->published_hd ? 'unpublish_hd' : 'publish_hd';
    $alt    = $row->published_hd ? JText::_( 'Published' ) : JText::_( 'Unpublished' );
    $action = $row->published_hd ? JText::_( 'Unpublish Item' ) : JText::_( 'Publish item' );
 
    $href = '
    <a title="'. $action .'" onclick="return listItemTask(\'cb'. $i .'\',\''. $prefix.$task .'\')" href="javascript:void(0);">
    <img src="images/'. $img .'" border="0" alt="'. $alt .'" /></a>';
 
    return $href;
  }
}

Il precedente sorgente contenuto nel file extendgrid.php è stato salvato nella cartella helpers/html/ nella parte amministrativa del componente sviluppato. Il path di tale directory dovrà essere fornita JHTML per sapere dove andare a cercare i files contenenti gli helpers da caricare e viene fatto con la seguente chiamata che ho inserito nell’entrypoint del componente:

JHTML::addIncludePath( array( JPATH_COMPONENT_ADMINISTRATOR.DS.'helpers'.DS.'html' ) );