--- title: Page Bundles linkTitle: Page Bundles description: Content organization using Page Bundles linkTitle: Page Bundles keywords: [page, bundle, leaf, branch] categories: [content management] menu : docs: identifier: "page-bundles" parent: "content-management" weight: 30 toc: true weight: 30 --- Page Bundles are a way to group [Page Resources](/content-management/page-resources/). A Page Bundle can be one of: - Leaf Bundle (leaf means it has no children) - Branch Bundle (home page, section, taxonomy terms, taxonomy list) | | Leaf Bundle | Branch Bundle | |-------------------------------------|----------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | | Usage | Collection of content and attachments for single pages | Collection of attachments for section pages (home page, section, taxonomy terms, taxonomy list) | | Index filename | `index.md` [^fn:1] | `_index.md` [^fn:1] | | Allowed Resources | Page and non-page (like images, PDF, etc.) types | Only non-page (like images, PDF, etc.) types | | Where can the Resources live? | At any directory level within the leaf bundle directory. | Only in the directory level **of** the branch bundle directory i.e. the directory containing the `_index.md` ([ref](https://discourse.gohugo.io/t/question-about-content-folder-structure/11822/4?u=kaushalmodi)). | | Layout type | `single` | `list` | | Nesting | Does not allow nesting of more bundles under it | Allows nesting of leaf or branch bundles under it | | Example | `content/posts/my-post/index.md` | `content/posts/_index.md` | | Content from non-index page files... | Accessed only as page resources | Accessed only as regular pages | ## Leaf Bundles {#leaf-bundles} A _Leaf Bundle_ is a directory at any hierarchy within the `content/` directory, that contains an **`index.md`** file. ### Examples of Leaf Bundle organization {#examples-of-leaf-bundle-organization} ```text content/ ├── about │ ├── index.md ├── posts │ ├── my-post │ │ ├── content1.md │ │ ├── content2.md │ │ ├── image1.jpg │ │ ├── image2.png │ │ └── index.md │ └── my-other-post │ └── index.md │ └── another-section ├── .. └── not-a-leaf-bundle ├── .. └── another-leaf-bundle └── index.md ``` In the above example `content/` directory, there are four leaf bundles: `about` : This leaf bundle is at the root level (directly under `content` directory) and has only the `index.md`. `my-post` : This leaf bundle has the `index.md`, two other content Markdown files and two image files. - image1, image2: These images are page resources of `my-post` and only available in `my-post/index.md` resources. - content1, content2: These content files are page resources of `my-post` and only available in `my-post/index.md` resources. They will **not** be rendered as individual pages. `my-other-post` : This leaf bundle has only the `index.md`. `another-leaf-bundle` : This leaf bundle is nested under couple of directories. This bundle also has only the `index.md`. {{% note %}} The hierarchy depth at which a leaf bundle is created does not matter, as long as it is not inside another **leaf** bundle. {{% /note %}} ### Headless Bundle {#headless-bundle} A headless bundle is a bundle that is configured to not get published anywhere: - It will have no `Permalink` and no rendered HTML in `public/`. - It will not be part of `.Site.RegularPages`, etc. But you can get it by `.Site.GetPage`. Here is an example: ```go-html-template {{ $headless := .Site.GetPage "/some-headless-bundle" }} {{ $reusablePages := $headless.Resources.Match "author*" }}