Title: Template Map
Author: Jon Christopher
Published: <strong>جولای 18, 2014</strong>
Last modified: فبروری 10, 2022

---

جستجوی افزونه‌ها

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

این افزونه **با آخرین 3 نسخه اصلی وردپرس تست نشده است**. ممکن است دیگر نگهداری یا
پشتیبانی نشود و ممکن است هنگام استفاده با نسخه های جدیدتر وردپرس مشکلات سازگاری 
داشته باشد.

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

# Template Map

 توسط [Jon Christopher](https://profiles.wordpress.org/jchristopher/)

[دانلود](https://downloads.wordpress.org/plugin/template-map.1.0.1.zip)

 * [جزئیات](https://fa-af.wordpress.org/plugins/template-map/#description)
 * [نقد و بررسی‌ها](https://fa-af.wordpress.org/plugins/template-map/#reviews)
 *  [نصب](https://fa-af.wordpress.org/plugins/template-map/#installation)
 * [توسعه](https://fa-af.wordpress.org/plugins/template-map/#developers)

 [پشتیبانی](https://wordpress.org/support/plugin/template-map/)

## توضیحات

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.

## نصب

 1. Upload `templatemap` to the `/wp-content/plugins/` directory
 2. Activate the plugin through the ‘Plugins’ menu in 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

## سوالات متداول

### 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.

## نقد و بررسی‌ها

نقد و بررسی‌ای برای این افزونه یافت نشد.

## توسعه دهندگان و همکاران

“Template Map” نرم افزار متن باز است. افراد زیر در این افزونه مشارکت کرده‌اند.

مشارکت کنندگان

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

[ترجمه “Template Map” به زبان شما.](https://translate.wordpress.org/projects/wp-plugins/template-map)

### علاقه‌ مند به توسعه هستید؟

[کد را مرور کنید](https://plugins.trac.wordpress.org/browser/template-map/), را 
بررسی کنید [مخزن SVN](https://plugins.svn.wordpress.org/template-map/), یا مشترک
شوید [گزارش توسعه](https://plugins.trac.wordpress.org/log/template-map/) توسط [RSS](https://plugins.trac.wordpress.org/log/template-map/?limit=100&mode=stop_on_copy&format=rss).

## گزارش تغییرات

#### 1.0.1

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

#### 1.0

 * Initial release

## اطلاعات

 *  Version **1.0.1**
 *  Last updated **4 سال پیش**
 *  Active installations **10+**
 *  WordPress version ** 3.9 یا بالاتر **
 *  Tested up to **5.9.0**
 *  Language
 * [English (US)](https://wordpress.org/plugins/template-map/)
 * Tags
 * [link](https://fa-af.wordpress.org/plugins/tags/link/)[template](https://fa-af.wordpress.org/plugins/tags/template/)
 *  [نمایش پیشرفته](https://fa-af.wordpress.org/plugins/template-map/advanced/)

## امتیازها

No reviews have been submitted yet.

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

[See all reviews](https://wordpress.org/support/plugin/template-map/reviews/)

## مشارکت کنندگان

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

## پشتیبانی

چیزی برای گفتن دارید؟ نیاز به کمک دارید؟

 [مشاهده انجمن پشتیبانی](https://wordpress.org/support/plugin/template-map/)

## کمک مالی

آیا تمایل دارید از پیشرفت این افزونه حمایت کنید؟

 [ کمک مالی به این افزونه ](http://mondaybynoon.com/donate/)