Title: Template Map
Author: Jon Christopher
Published: <strong>18 julho, 2014</strong>
Last modified: 10 fevereiro, 2022

---

Pesquisar plugins

![](https://ps.w.org/template-map/assets/banner-772x250.jpg?rev=951721)

Este plugin **não foi testado com os 3 lançamentos principais mais recentes do WordPress**.
Ele pode não ser mais mantido ou suportado e pode ter problemas de compatibilidade
quando usado com versões mais recentes do WordPress.

![](https://s.w.org/plugins/geopattern-icon/template-map_d59f6f.svg)

# Template Map

 Por [Jon Christopher](https://profiles.wordpress.org/jchristopher/)

[Baixar](https://downloads.wordpress.org/plugin/template-map.1.0.1.zip)

 * [Detalhes](https://br.wordpress.org/plugins/template-map/#description)
 * [Avaliações](https://br.wordpress.org/plugins/template-map/#reviews)
 *  [Instalação](https://br.wordpress.org/plugins/template-map/#installation)
 * [Desenvolvimento](https://br.wordpress.org/plugins/template-map/#developers)

 [Suporte](https://wordpress.org/support/plugin/template-map/)

## Descrição

Template Map is a utility plugin designed to make the creation and management of
navigation elements in your custom theme that much easier. It abstracts the need
to hard code post IDs and the like from your global and header navigation systems(
if you choose to not use Menus) for instance.

#### For Example

Many times you may use something like the following to build your main site navigation:

    ```
    <nav>
      <ul>
        <li>
          <a href="<?php echo get_permalink( 83 ); ?>">About</a>
        </li>
      </ul>
    </nav>
    ```

That works great during initial development, and continues to hold up when you migrate
to production en masse for the first time. But what about when you’re making subsequent
updates and the post IDs in your development environment are different than those
in production? You could take the time to sync the databases each and every time,
but that’s a bit overkill. Here’s where Template Map comes in to play:

    ```
    <nav>
      <ul>
        <li>
          <?php $about_page_id = TemplateMap()->get_id_from_template( 'template-about.php' ); ?>
          <a href="<?php echo get_permalink( $about_page_id ); ?>">About</a>
        </li>
      </ul>
    </nav>
    ```

Template Map allows you to _dynamically_ retreive your desired post ID based on 
the Page Template you told it to use. Page Template filenames rarely (if ever) change,
so it’s the core concept of Template Map’s implementation. Everything works backwards
from here.

Naturally this philosophy assumes your Page Template is used only once, it’s important
to keep that in mind. Modern client sites often use unique Page Templates for the‘
parent’ pages of each site section.

#### Current Site Section

Template Map also makes it easier to determine whether the current page is within
a site ‘section’ which is defined as a top level Page with a unique Page Template
that has any number of child Pages and/or Custom Post Types within it. This is very
useful when trying to set a ‘current’ state in your navigation, for example:

    ```
    <nav>
      <ul>
        <li class="<?php if( TemplateMap()->maybe_in_section( 'template-about.php' ) ) : ?> current<?php endif; ?>">
          <?php $about_page_id = TemplateMap()->get_id_from_template( 'template-about.php' ); ?>
          <a href="<?php echo get_permalink( $about_page_id ); ?>">About</a>
        </li>
      </ul>
    </nav>
    ```

Based on the same principle you can use this utility method to properly orient yourself
when outputting conditional classes contingent on the current page being within 
a ‘secton’ on your site.

## Instalação

 1. Upload `templatemap` to the `/wp-content/plugins/` directory
 2. Ative o plugin por meio do menu “Plugins” no WordPress
 3. Replace calls to `get_permalink( 83 )` with `get_permalink( TemplateMap()->get_id_from_template('
    template-about.php' ) )` where `template-about.php` is the Page you wish to link

## Perguntas frequentes

### How do I define Custom Post Types within a section?

There’s a filter for that. `template_map_post_types` accepts two parameters, the
second of which is the Page Template filename in question. You can conditionally
return an array of CPT names that will be utilized when checking to see whether 
the current page is within the section in question.

## Avaliações

Não há avaliações para este plugin.

## Colaboradores e desenvolvedores

“Template Map” é um programa de código aberto. As seguintes pessoas contribuíram
para este plugin.

Colaboradores

 *   [ Jon Christopher ](https://profiles.wordpress.org/jchristopher/)

[Traduzir o “Template Map” para seu idioma.](https://translate.wordpress.org/projects/wp-plugins/template-map)

### Interessado no desenvolvimento?

[Navegue pelo código](https://plugins.trac.wordpress.org/browser/template-map/),
consulte o [repositório SVN](https://plugins.svn.wordpress.org/template-map/) ou
assine o [registro de desenvolvimento](https://plugins.trac.wordpress.org/log/template-map/)
por [RSS](https://plugins.trac.wordpress.org/log/template-map/?limit=100&mode=stop_on_copy&format=rss).

## Registro de alterações

#### 1.0.1

 * When using maybe_in_section you can pass a 2nd parameter to force a parent ID

#### 1.0

 * Initial release

## Meta

 *  Versão **1.0.1**
 *  Última atualização **4 anos atrás**
 *  Instalações ativas **10+**
 *  Versão do WordPress ** 3.9 ou superior **
 *  Testado até **5.9.0**
 *  Idioma
 * [English (US)](https://wordpress.org/plugins/template-map/)
 * Tags
 * [link](https://br.wordpress.org/plugins/tags/link/)[template](https://br.wordpress.org/plugins/tags/template/)
 *  [Visualização avançada](https://br.wordpress.org/plugins/template-map/advanced/)

## Classificações

Ainda não foi enviada nenhuma avaliação.

[Your review](https://wordpress.org/support/plugin/template-map/reviews/#new-post)

[Ver todas avaliações](https://wordpress.org/support/plugin/template-map/reviews/)

## Colaboradores

 *   [ Jon Christopher ](https://profiles.wordpress.org/jchristopher/)

## Suporte

Tem algo a dizer? Precisa de ajuda?

 [Ver fórum de suporte](https://wordpress.org/support/plugin/template-map/)

## Doar

Gostaria de contribuir para o desenvolvimento deste plugin?

 [ Doe para este plugin ](http://mondaybynoon.com/donate/)