Path to the directory to be used as the "cwd" for layouts
layoutdir makes maintaining
              layouts a little easier on projects that require more than one layout. The primary advantage of using the feature is that you can change or rename the directory where your layouts are stored without having to update the path to each layout
              used throughout your project. It could also reduce some clutter in the
              Gruntfile and
              YAML Front Matter.
Additionally, a layoutdir can be defined for each
              targets, allowing for even greater control over how
              layouts are used in your projects.
layoutdir
            When layoutdir  is not defined, each layout must be defined using the full path from the project root to the layout:
assemble: {
  options: {
    layout: 'src/templates/layouts/default-layout.hbs' 
  },
  docs: {
    options: {
      layout: 'src/templates/layouts/docs-layout.hbs' 
    },
    ...
  },
  blog: {
    options: {
      layout: 'src/templates/layouts/blog-layout.hbs' 
    },
    ...
  }
  // etc. 
}This also applies to YAML front matter when it is necessary to "override" layouts at the page-level:
---
title: Blog
layout: src/templates/layouts/blog-layout.hbs
---layoutdir
            When layoutdir is defined only require the name of the layout to be used (must include the file extension):
assemble: {
  options: {
    layoutdir: 'src/templates/layouts',
    layout: 'default-layout.hbs'
  },
  docs: {
    options: {
      layout: 'docs-layout.hbs'
    },
    ...
  },
  blog: {
    options: {
      layout: 'blog-layout.hbs'
    },
    ...
  }
  // etc.
}And in YAML front matter:
---
title: Blog
layout: blog-layout.hbs
---While layoutdir can make your project a little easier to manage, it is strongly recommended that you establish clear and consistent conventions for your layouts, and follow them. Otherwise, this feature might end
              up causing more problems than it solves.
Here are some recommendations.
default-layout.hbs versus simply default.hbs, andTo understand why this is important, imagine that you're project has three "sub-projects", or
              targets: components, docs and blog, and that each target has a different layout. This is a fairly basic, common scenario. But remember that each may also have its own layoutdir as well, which
              creates potential for conventions that lead to using the wrong layout accidentally, such as this:
assemble: {
  components: {
    options: {
      layoutdir: 'src/components/layouts',
      layout: 'default.hbs' 
    }
    ...
  },
  docs: {
    options: {
      layoutdir: 'src/docs/layouts',
      layout: 'default.hbs' 
    }
    ...
  },
  blog: {
    options: {
      layoutdir: 'src/blog/layouts',
      layout: 'default.hbs' 
    }
    ...
  }
  // etc. 
}Note that the layout name is the same for each target, but the layoutdir is a different directory, indicating that there are three different "default" layouts.
While it might make sense for each target to have its own layoutdir, since layouts can be overridden in the
              YAML front matter of individual pages, it is not a good idea to use the same name for multiple layouts, unless you are intentionally using this naming convention as a strategy. The reason is that it gets very difficult to track
              which page is building from which layout when working inside the pages themselves.
Without layoutdir, you have the entire path to follow, but without it you must rely on the name of the layout itself to guide you.
---
title: Any Page
layout: default.hbs
---Using a more descriptive name for the layout helps avoid confusion now:
---
title: Any Page
layout: blog-default.hbs
---Of course, these are only recommendations and you will need to find a strategy that works for you and your team.
See the template for this page →
Find an error? Let us know →