About Chris Morrell

I am a Philadelphia web designer and developer who focuses on PHP development and usable design. I am also the Director of IT for the International Association of Certified Home Inspectors.

Please Note: My site fell victim to a Wordpress security flaw a few weeks ago, and I'm just getting everything back to normal. Please bear with me.

I am currently not accepting any new clients.

Other Sites/Clients

Contact Me

If you need to get in touch with me, my name is Chris and my domain name is cmorrell.com. Think about it.

Zend Framework: Using separate layouts per module

Posted by Chris Morrell on July 10th, 2009 in Zend Framework

Someone was recently asking on ZFTalk about how to use a different layout for each module in your application. Since this is a problem I’ve dealt with in the past and planned on adding to the Galahad FE, I thought I’d quickly write up a tutorial on how to do it:

First, download the Plugin

Put the following class in a library/Galahad/Controller/Plugin/Modularlayout.php file (you’ll probably have to create all those directories and the file).

<?php
/**
* This file is part of the Galahad Framework Extension.
*
* The Galahad Framework Extension is free software: you can redistribute
* it and/or modify it under the terms of the GNU General Public License
* as published by the Free Software Foundation, either version 3 of the
* License, or (at your option) any later version.
*
* The Galahad Framework Extension is distributed in the hope that it will
* be useful, but WITHOUT ANY WARRANTY; without even the implied warranty
* of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
* General Public License for more details.
*
* @category  Galahad
* @package   Galahad
* @copyright Copyright (c) 2009 Chris Morrell <http://cmorrell.com>
* @license   GPL <http://www.gnu.org/licenses/>
* @version   0.2
*/

/**
* Use separate layout per module
*
* @category   Galahad
* @package    Galahad
* @copyright  Copyright (c) 2009 Chris Morrell <http://cmorrell.com>
* @license    GPL <http://www.gnu.org/licenses/>
*/
class Galahad_Controller_Plugin_Modularlayout extends Zend_Controller_Plugin_Abstract
{
     public function routeShutdown(Zend_Controller_Request_Abstract $request)
     {
          Zend_Layout::getMvcInstance()->setLayout($request->getModuleName());
     }
}

Next, add the Galahad namespace

Update your Bootstrap.php file’s autoloader initialization method (if you don’t have one, add one):

protected function _initAutoloaders()
{
	$this->getApplication()->setAutoloaderNamespaces(array('Galahad_'));
	return $this;
}

Please note: You might need to have other namespaces in there, like My_ or App_ or Default_.

Next, add the Plugin

Update your Bootstrap.php file’s plugin initialization method (if you don’t have one, add one):

protected function _initPlugins()
{
	$this->bootstrap('autoloaders');
	$this->bootstrap('frontController');

	$plugin = new Galahad_Controller_Plugin_Modularlayout();
        $this->frontController->registerPlugin($plugin);
}

And you’re set!

Just make sure you have a layout file in your layouts directory for each module (modulename.phtml).

7 Comments »

7 Responses to “Zend Framework: Using separate layouts per module”

  1. Ryan Mauger

    You appear to be using a Front controller Plugin for an action helper!

    please don’t do that, either its one or its the other.

    Yes they are very similar, but they actually should perform two different functions, an action helper should provide something useful to you in an action, or do something such as the viewRenderer, which renders the view for you.

    you should instead simply register the plugin with the Front controller, where it will do pretty much the same thing, and yes it is all semantics, but semantics are for clarity, and your bluring that!

  2. Chris Morrell

    Shoot! Good call—fixed.

  3. newmediahub

    Chris Morrell posted: Zend Framework: Using separate layouts per module (http://bit.ly/ADJEV)

    This comment was originally posted on Twitter

  4. Axalix

    it is written
    “Put the following class in a library/Galahad/Plugin/Modularlayout.php” but definition starts with
    “class Galahad_Controller_Plugin_Modularlayout”

    I think “/Controller/” is missed in the path.

  5. Chris Morrell

    Good point! Fixed.

  6. Vlao

    There is an easier and cleaner way:

    protected function _initLayout() {
    Zend_Layout::startMvc();
    }

    The app is now looking in the view folder of the current module for layout.phtml
    If you insist on keeping your layouts in application/layouts and naming them {module}.phtml, your approach is the right one. I prefer my modules completely separate(except for models). It all depends on the application you are building.

    Don’t take this as critisism – just another perspective :)

  7. Chris Morrell

    Nice! I didn’t know Zend_Layout gave you that option (I don’t see it anywhere in the docs). Good to know.

Leave a Reply

Additional comments powered by BackType

Comments & Trackbacks

You can leave a response, or trackback from your own site. Follow any responses to this entry through the RSS 2.0 feed.

More...

@inxilpro

  • "A Cookie" : A phrase referencing 2 or more cookies. Eg. "I think I'll have a cookie now." 8 hrs ago
  • Developing PHP applications that use a payment gateway (Authorize.net/PayPal/etc)? I'd love you feedback on a project… DM for details. 1 day ago
  • Loving the camel case matching in Zend Studio's code assist. "new ZDbAA" + TAB = "new Zend_Db_Adapter_Abstract" 2 days ago
  • More updates...
Copyright © Chris Morrell, Powered by WordPress, Entry RSS Feed / Comment RSS Feed