/htdocs/wp-content/plugins/breadcrumb-navxt/breadcrumb_navxt_admin.php
PHP | 894 lines | 693 code | 1 blank | 200 comment | 69 complexity | 9915515b1944b47db3cf2c5e15d95f62 MD5 | raw file
Possible License(s): GPL-2.0
- <?php
- /*
- Plugin Name: Breadcrumb NavXT
- Plugin URI: http://mtekk.us/code/breadcrumb-navxt/
- Description: Adds a breadcrumb navigation showing the visitor's path to their current location. For details on how to use this plugin visit <a href="http://mtekk.us/code/breadcrumb-navxt/">Breadcrumb NavXT</a>.
- Version: 4.4.0
- Author: John Havlik
- Author URI: http://mtekk.us/
- License: GPL2
- TextDomain: breadcrumb-navxt
- DomainPath: /languages/
- */
- /* Copyright 2007-2013 John Havlik (email : mtekkmonkey@gmail.com)
-
- This program 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 2 of the License, or
- (at your option) any later version.
-
- This program 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.
-
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA
- */
- require_once(dirname(__FILE__) . '/includes/block_direct_access.php');
- //Do a PHP version check, require 5.2 or newer
- if(version_compare(phpversion(), '5.2.0', '<'))
- {
- //Only purpose of this function is to echo out the PHP version error
- function bcn_phpold()
- {
- printf('<div class="error"><p>' . __('Your PHP version is too old, please upgrade to a newer version. Your version is %1$s, Breadcrumb NavXT requires %2$s', 'breadcrumb-navxt') . '</p></div>', phpversion(), '5.2.0');
- }
- //If we are in the admin, let's print a warning then return
- if(is_admin())
- {
- add_action('admin_notices', 'bcn_phpold');
- }
- return;
- }
- if(!function_exists('mb_strlen'))
- {
- require_once(dirname(__FILE__) . '/includes/multibyte_supplicant.php');
- }
- //Include the breadcrumb class
- require_once(dirname(__FILE__) . '/breadcrumb_navxt_class.php');
- //Include the WP 2.8+ widget class
- require_once(dirname(__FILE__) . '/breadcrumb_navxt_widget.php');
- //Include admin base class
- if(!class_exists('mtekk_adminKit'))
- {
- require_once(dirname(__FILE__) . '/includes/mtekk_adminkit.php');
- }
- /**
- * The administrative interface class
- *
- */
- class bcn_admin extends mtekk_adminKit
- {
- protected $version = '4.4.0';
- protected $full_name = 'Breadcrumb NavXT Settings';
- protected $short_name = 'Breadcrumb NavXT';
- protected $access_level = 'manage_options';
- protected $identifier = 'breadcrumb-navxt';
- protected $unique_prefix = 'bcn';
- protected $plugin_basename = 'breadcrumb-navxt/breadcrumb_navxt_admin.php';
- protected $support_url = 'http://mtekk.us/archives/wordpress/plugins-wordpress/breadcrumb-navxt-';
- public $breadcrumb_trail;
- /**
- * Administrative interface class default constructor
- * @param bcn_breadcrumb_trail $breadcrumb_trail a breadcrumb trail object
- */
- function __construct(bcn_breadcrumb_trail $breadcrumb_trail)
- {
- $this->breadcrumb_trail = $breadcrumb_trail;
- //Grab defaults from the breadcrumb_trail object
- $this->opt = $this->breadcrumb_trail->opt;
- //We set the plugin basename here, could manually set it, but this is for demonstration purposes
- //$this->plugin_basename = plugin_basename(__FILE__);
- //Register the WordPress 2.8 Widget
- add_action('widgets_init', create_function('', 'return register_widget("'. $this->unique_prefix . '_widget");'));
- //We're going to make sure we load the parent's constructor
- parent::__construct();
- add_action('init', array($this, 'wp_init'));
- }
- /**
- * admin initialization callback function
- *
- * is bound to wpordpress action 'admin_init' on instantiation
- *
- * @since 3.2.0
- * @return void
- */
- function init()
- {
- //We're going to make sure we run the parent's version of this function as well
- parent::init();
- //We want to run late for using our breadcrumbs
- add_filter('tha_breadcrumb_navigation', array($this, 'tha_compat'), 99);
- }
- function wp_init()
- {
- add_filter('bcn_allowed_html', array($this, 'allowed_html'), 1, 1);
- }
- function allowed_html($tags)
- {
- $allowed_html = array(
- 'a' => array(
- 'href' => true,
- 'title' => true,
- 'class' => true,
- 'id' => true,
- 'media' => true,
- 'dir' => true,
- 'relList' => true,
- 'rel' => true,
- 'aria-hidden' => true,
- 'data-icon' => true,
- 'itemref' => true,
- 'itemid' => true,
- 'itemprop' => true,
- 'itemscope' => true,
- 'itemtype' => true
- ),
- 'img' => array(
- 'alt' => true,
- 'align' => true,
- 'height' => true,
- 'width' => true,
- 'src' => true,
- 'id' => true,
- 'class' => true,
- 'aria-hidden' => true,
- 'data-icon' => true,
- 'itemref' => true,
- 'itemid' => true,
- 'itemprop' => true,
- 'itemscope' => true,
- 'itemtype' => true
- ),
- 'span' => array(
- 'title' => true,
- 'class' => true,
- 'id' => true,
- 'dir' => true,
- 'align' => true,
- 'lang' => true,
- 'xml:lang' => true,
- 'aria-hidden' => true,
- 'data-icon' => true,
- 'itemref' => true,
- 'itemid' => true,
- 'itemprop' => true,
- 'itemscope' => true,
- 'itemtype' => true
- ),
- 'h1' => array(
- 'title' => true,
- 'class' => true,
- 'id' => true,
- 'dir' => true,
- 'align' => true,
- 'lang' => true,
- 'xml:lang' => true,
- 'aria-hidden' => true,
- 'data-icon' => true,
- 'itemref' => true,
- 'itemid' => true,
- 'itemprop' => true,
- 'itemscope' => true,
- 'itemtype' => true
- ),
- 'h2' => array(
- 'title' => true,
- 'class' => true,
- 'id' => true,
- 'dir' => true,
- 'align' => true,
- 'lang' => true,
- 'xml:lang' => true,
- 'aria-hidden' => true,
- 'data-icon' => true,
- 'itemref' => true,
- 'itemid' => true,
- 'itemprop' => true,
- 'itemscope' => true,
- 'itemtype' => true
- )
- );
- return $allowed_html; //$this->array_merge_recursive($tags, $allowed_html);
- }
- function wp_loaded()
- {
- //First make sure our defaults are safe
- $this->find_posttypes($this->opt);
- $this->find_taxonomies($this->opt);
- //Let others hook into our settings
- $this->opt = apply_filters($this->unique_prefix . '_settings_init', $this->opt);
- parent::wp_loaded();
- }
- /**
- * Makes sure the current user can manage options to proceed
- */
- function security()
- {
- //If the user can not manage options we will die on them
- if(!current_user_can($this->access_level))
- {
- wp_die(__('Insufficient privileges to proceed.', 'breadcrumb-navxt'));
- }
- }
- /**
- * Upgrades input options array, sets to $this->opt
- *
- * @param array $opts
- * @param string $version the version of the passed in options
- */
- function opts_upgrade($opts, $version)
- {
- global $wp_post_types;
- //If our version is not the same as in the db, time to update
- if(version_compare($version, $this->version, '<'))
- {
- //Upgrading to 3.8.1
- if(version_compare($version, '3.8.1', '<'))
- {
- $opts['post_page_root'] = get_option('page_on_front');
- $opts['post_post_root'] = get_option('page_for_posts');
- }
- //Upgrading to 4.0
- if(version_compare($version, '4.0.0', '<'))
- {
- //Only migrate if we haven't migrated yet
- if(isset($opts['current_item_linked']))
- {
- //Loop through the old options, migrate some of them
- foreach($opts as $option => $value)
- {
- //Handle all of our boolean options first, they're real easy, just add a 'b'
- if(strpos($option, 'display') > 0 || $option == 'current_item_linked')
- {
- $this->breadcrumb_trail->opt['b' . $option] = $value;
- }
- //Handle migration of anchor templates to the templates
- else if(strpos($option, 'anchor') > 0)
- {
- $parts = explode('_', $option);
- //Do excess slash removal sanitation
- $this->breadcrumb_trail->opt['H' . $parts[0] . '_template'] = $value . '%htitle%</a>';
- }
- //Handle our abs integers
- else if($option == 'max_title_length' || $option == 'post_post_root' || $option == 'post_page_root')
- {
- $this->breadcrumb_trail->opt['a' . $option] = $value;
- }
- //Now everything else, minus prefix and suffix
- else if(strpos($option, 'prefix') === false && strpos($option, 'suffix') === false)
- {
- $this->breadcrumb_trail->opt['S' . $option] = $value;
- }
- }
- }
- //Add in the new settings for CPTs introduced in 4.0
- foreach($wp_post_types as $post_type)
- {
- //We only want custom post types
- if(!$post_type->_builtin)
- {
- //Add in the archive_display option
- $this->breadcrumb_trail->opt['bpost_' . $post_type->name . '_archive_display'] = $post_type->has_archive;
- }
- }
- $opts = $this->breadcrumb_trail->opt;
- }
- if(version_compare($version, '4.0.1', '<'))
- {
- if(isset($opts['Hcurrent_item_template_no_anchor']))
- {
- unset($opts['Hcurrent_item_template_no_anchor']);
- }
- if(isset($opts['Hcurrent_item_template']))
- {
- unset($opts['Hcurrent_item_template']);
- }
- }
- //Upgrading to 4.3.0
- if(version_compare($version, '4.3.0', '<'))
- {
- //Removed home_title
- if(isset($opts['Shome_title']))
- {
- unset($opts['Shome_title']);
- }
- //Removed mainsite_title
- if(isset($opts['Smainsite_title']))
- {
- unset($opts['Smainsite_title']);
- }
- }
- //Add custom post types
- $this->find_posttypes($opts);
- //Add custom taxonomy types
- $this->find_taxonomies($opts);
- //Save the passed in opts to the object's option array
- $this->opt = $opts;
- }
- }
- /**
- * help action hook function
- *
- * @return string
- *
- */
- function help()
- {
- $screen = get_current_screen();
- //Exit early if the add_help_tab function doesn't exist
- if(!method_exists($screen, 'add_help_tab'))
- {
- return;
- }
- //Add contextual help on current screen
- if($screen->id == 'settings_page_' . $this->identifier)
- {
- $general_tab = '<p>' . __('Tips for the settings are located below select options.', 'breadcrumb-navxt') .
- '</p><h5>' . __('Resources', 'breadcrumb-navxt') . '</h5><ul><li>' .
- sprintf(__("%sTutorials and How Tos%s: There are several guides, tutorials, and how tos available on the author's website.", 'breadcrumb-navxt'),'<a title="' . __('Go to the Breadcrumb NavXT tag archive.', 'breadcrumb-navxt') . '" href="http://mtekk.us/archives/tag/breadcrumb-navxt">', '</a>') . '</li><li>' .
- sprintf(__('%sOnline Documentation%s: Check out the documentation for more indepth technical information.', 'breadcrumb-navxt'), '<a title="' . __('Go to the Breadcrumb NavXT online documentation', 'breadcrumb-navxt') . '" href="http://mtekk.us/code/breadcrumb-navxt/breadcrumb-navxt-doc/">', '</a>') . '</li><li>' .
- sprintf(__('%sReport a Bug%s: If you think you have found a bug, please include your WordPress version and details on how to reproduce the bug.', 'breadcrumb-navxt'),'<a title="' . __('Go to the Breadcrumb NavXT support post for your version.', 'breadcrumb-navxt') . '" href="http://mtekk.us/archives/wordpress/plugins-wordpress/breadcrumb-navxt-' . $this->version . '/#respond">', '</a>') . '</li></ul>' .
- '<h5>' . __('Giving Back', 'breadcrumb-navxt') . '</h5><ul><li>' .
- sprintf(__('%sDonate%s: Love Breadcrumb NavXT and want to help development? Consider buying the author a beer.', 'breadcrumb-navxt'),'<a title="' . __('Go to PayPal to give a donation to Breadcrumb NavXT.', 'breadcrumb-navxt') . '" href="https://www.paypal.com/cgi-bin/webscr?cmd=_donations&business=FD5XEU783BR8U&lc=US&item_name=Breadcrumb%20NavXT%20Donation¤cy_code=USD&bn=PP%2dDonationsBF%3abtn_donateCC_LG%2egif%3aNonHosted">', '</a>') . '</li><li>' .
- sprintf(__('%sTranslate%s: Is your language not available? Contact John Havlik to get translating.', 'breadcrumb-navxt'),'<a title="' . __('Go to the Breadcrumb NavXT translation project.', 'breadcrumb-navxt') . '" href="http://translate.mtekk.us/projects/breadcrumb-navxt">', '</a>') . '</li></ul>';
-
- $screen->add_help_tab(
- array(
- 'id' => $this->identifier . '-base',
- 'title' => __('General', 'breadcrumb-navxt'),
- 'content' => $general_tab
- ));
- $quickstart_tab = '<p>' . __('For the settings on this page to take effect, you must either use the included Breadcrumb NavXT widget, or place either of the code sections below into your theme.', 'breadcrumb-navxt') .
- '</p><h5>' . __('Breadcrumb trail with separators', 'breadcrumb-navxt') . '</h5><pre><code><div class="breadcrumbs">' . "
- <?php if(function_exists('bcn_display'))
- {
- bcn_display();
- }?>
- </div></code></pre>" .
- '<h5>' . __('Breadcrumb trail in list form', 'breadcrumb-navxt').'</h5><pre><code><ol class="breadcrumbs">'."
- <?php if(function_exists('bcn_display_list'))
- {
- bcn_display_list();
- }?>
- </ol></code></pre>";
- $screen->add_help_tab(
- array(
- 'id' => $this->identifier . '-quick-start',
- 'title' => __('Quick Start', 'breadcrumb-navxt'),
- 'content' => $quickstart_tab
- ));
- $styling_tab = '<p>' . __('Using the code from the Quick Start section above, the following CSS can be used as base for styling your breadcrumb trail.', 'breadcrumb-navxt') . '</p>' .
- '<pre><code>.breadcrumbs
- {
- font-size: 1.1em;
- color: #fff;
- margin: 30px 0 0 10px;
- position: relative;
- float: left;
- }</code></pre>';
- $screen->add_help_tab(
- array(
- 'id' => $this->identifier . '-styling',
- 'title' => __('Styling', 'breadcrumb-navxt'),
- 'content' => $styling_tab
- ));
- $screen->add_help_tab(
- array(
- 'id' => $this->identifier . '-import-export-reset',
- 'title' => __('Import/Export/Reset', 'breadcrumb-navxt'),
- 'content' => $this->import_form()
- ));
- }
- }
- /**
- * enqueue's the tab style sheet on the settings page
- */
- function admin_styles()
- {
- wp_enqueue_style('mtekk_adminkit_tabs');
- }
- /**
- * enqueue's the tab js and translation js on the settings page
- */
- function admin_scripts()
- {
- //Enqueue ui-tabs
- wp_enqueue_script('jquery-ui-tabs');
- //Enqueue the admin tabs javascript
- wp_enqueue_script('mtekk_adminkit_tabs');
- //Load the translations for the tabs
- wp_localize_script('mtekk_adminkit_tabs', 'objectL10n', array(
- 'mtad_uid' => 'bcn_admin',
- 'mtad_import' => __('Import', 'breadcrumb-navxt'),
- 'mtad_export' => __('Export', 'breadcrumb-navxt'),
- 'mtad_reset' => __('Reset', 'breadcrumb-navxt'),
- ));
- }
- /**
- * The administrative page for Breadcrumb NavXT
- */
- function admin_page()
- {
- global $wp_taxonomies, $wp_post_types;
- $this->security();
- //Let's call the parent version of the page, will handle our setting stuff
- parent::admin_page();
- ?>
- <div class="wrap"><div id="icon-options-general" class="icon32"></div><h2><?php _e('Breadcrumb NavXT Settings', 'breadcrumb-navxt'); ?></h2>
- <?php
- //We exit after the version check if there is an action the user needs to take before saving settings
- if(!$this->version_check(get_option($this->unique_prefix . '_version')))
- {
- return;
- }
- ?>
- <form action="<?php echo $this->admin_url(); ?>" method="post" id="bcn_admin-options">
- <?php settings_fields('bcn_options');?>
- <div id="hasadmintabs">
- <fieldset id="general" class="bcn_options">
- <h3 class="tab-title" title="<?php _e('A collection of settings most likely to be modified are located under this tab.', 'breadcrumb-navxt');?>"><?php _e('General', 'breadcrumb-navxt'); ?></h3>
- <h3><?php _e('General', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_text(__('Breadcrumb Separator', 'breadcrumb-navxt'), 'hseparator', 'regular-text', false, __('Placed in between each breadcrumb.', 'breadcrumb-navxt'));
- ?>
- <tr valign="top">
- <th scope="row">
- <?php _e('Title Length', 'breadcrumb-navxt'); ?>
- </th>
- <td>
- <label>
- <input name="bcn_options[blimit_title]" type="checkbox" id="blimit_title" value="true" <?php checked(true, $this->opt['blimit_title']); ?> />
- <?php _e('Limit the length of the breadcrumb title.', 'breadcrumb-navxt'); ?>
- </label><br />
- <ul>
- <li>
- <label for="amax_title_length">
- <?php _e('Max Title Length: ','breadcrumb-navxt');?>
- <input type="number" name="bcn_options[amax_title_length]" id="amax_title_length" min="1" step="1" value="<?php echo esc_html($this->opt['amax_title_length'], ENT_COMPAT, 'UTF-8'); ?>" class="small-text" />
- </label>
- </li>
- </ul>
- </td>
- </tr>
- <?php
- do_action($this->unique_prefix . '_settings_general');
- ?>
- </table>
- <h3><?php _e('Current Item', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_check(__('Link Current Item', 'breadcrumb-navxt'), 'bcurrent_item_linked', __('Yes', 'breadcrumb-navxt'));
- $this->input_check(__('Paged Breadcrumb', 'breadcrumb-navxt'), 'bpaged_display', __('Include the paged breadcrumb in the breadcrumb trail.', 'breadcrumb-navxt'), false, __('Indicates that the user is on a page other than the first on paginated posts/pages.', 'breadcrumb-navxt'));
- $this->input_text(__('Paged Template', 'breadcrumb-navxt'), 'Hpaged_template', 'large-text', false, __('The template for paged breadcrumbs.', 'breadcrumb-navxt'));
- do_action($this->unique_prefix . '_settings_current_item');
- ?>
- </table>
- <h3><?php _e('Home Breadcrumb', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_check(__('Home Breadcrumb', 'breadcrumb-navxt'), 'bhome_display', __('Place the home breadcrumb in the trail.', 'breadcrumb-navxt'));
- $this->input_text(__('Home Template', 'breadcrumb-navxt'), 'Hhome_template', 'large-text', false, __('The template for the home breadcrumb.', 'breadcrumb-navxt'));
- $this->input_text(__('Home Template (Unlinked)', 'breadcrumb-navxt'), 'Hhome_template_no_anchor', 'large-text', false, __('The template for the home breadcrumb, used when the breadcrumb is not linked.', 'breadcrumb-navxt'));
- do_action($this->unique_prefix . '_settings_home');
- ?>
- </table>
- <h3><?php _e('Blog Breadcrumb', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_check(__('Blog Breadcrumb', 'breadcrumb-navxt'), 'bblog_display', __('Place the blog breadcrumb in the trail.', 'breadcrumb-navxt'), (get_option('show_on_front') !== "page"));
- $this->input_text(__('Blog Template', 'breadcrumb-navxt'), 'Hblog_template', 'large-text', (get_option('show_on_front') !== "page"), __('The template for the blog breadcrumb, used only in static front page environments.', 'breadcrumb-navxt'));
- $this->input_text(__('Blog Template (Unlinked)', 'breadcrumb-navxt'), 'Hblog_template_no_anchor', 'large-text', (get_option('show_on_front') !== "page"), __('The template for the blog breadcrumb, used only in static front page environments and when the breadcrumb is not linked.', 'breadcrumb-navxt'));
- do_action($this->unique_prefix . '_settings_blog');
- ?>
- </table>
- <h3><?php _e('Mainsite Breadcrumb', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_check(__('Main Site Breadcrumb', 'breadcrumb-navxt'), 'bmainsite_display', __('Place the main site home breadcrumb in the trail in an multisite setup.', 'breadcrumb-navxt'), !is_multisite());
- $this->input_text(__('Main Site Home Template', 'breadcrumb-navxt'), 'Hmainsite_template', 'large-text', !is_multisite(), __('The template for the main site home breadcrumb, used only in multisite environments.', 'breadcrumb-navxt'));
- $this->input_text(__('Main Site Home Template (Unlinked)', 'breadcrumb-navxt'), 'Hmainsite_template_no_anchor', 'large-text', !is_multisite(), __('The template for the main site home breadcrumb, used only in multisite environments and when the breadcrumb is not linked.', 'breadcrumb-navxt'));
- do_action($this->unique_prefix . '_settings_mainsite');
- ?>
- </table>
- <?php do_action($this->unique_prefix . '_after_settings_tab_general'); ?>
- </fieldset>
- <fieldset id="post" class="bcn_options">
- <h3 class="tab-title" title="<?php _e('The settings for all post types (Posts, Pages, and Custom Post Types) are located under this tab.', 'breadcrumb-navxt');?>"><?php _e('Post Types', 'breadcrumb-navxt'); ?></h3>
- <h3><?php _e('Posts', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_text(__('Post Template', 'breadcrumb-navxt'), 'Hpost_post_template', 'large-text', false, __('The template for post breadcrumbs.', 'breadcrumb-navxt'));
- $this->input_text(__('Post Template (Unlinked)', 'breadcrumb-navxt'), 'Hpost_post_template_no_anchor', 'large-text', false, __('The template for post breadcrumbs, used only when the breadcrumb is not linked.', 'breadcrumb-navxt'));
- $this->input_check(__('Post Hierarchy Display', 'breadcrumb-navxt'), 'bpost_post_taxonomy_display', __('Show the taxonomy leading to a post in the breadcrumb trail.', 'breadcrumb-navxt'));
- ?>
- <tr valign="top">
- <th scope="row">
- <?php _e('Post Hierarchy', 'breadcrumb-navxt'); ?>
- </th>
- <td>
- <?php
- $this->input_radio('Spost_post_taxonomy_type', 'category', __('Categories'));
- $this->input_radio('Spost_post_taxonomy_type', 'date', __('Dates'));
- $this->input_radio('Spost_post_taxonomy_type', 'post_tag', __('Tags'));
- //We use the value 'page' but really, this will follow the parent post hierarchy
- $this->input_radio('Spost_post_taxonomy_type', 'page', __('Post Parent'));
- //Loop through all of the taxonomies in the array
- foreach($wp_taxonomies as $taxonomy)
- {
- //Check for non-public taxonomies
- if(!apply_filters('bcn_show_tax_private', $taxonomy->public, $taxonomy->name))
- {
- continue;
- }
- //We only want custom taxonomies
- if(($taxonomy->object_type == 'post' || is_array($taxonomy->object_type) && in_array('post', $taxonomy->object_type)) && !$taxonomy->_builtin)
- {
- $this->input_radio('Spost_post_taxonomy_type', $taxonomy->name, mb_convert_case($taxonomy->label, MB_CASE_TITLE, 'UTF-8'));
- }
- }
- ?>
- <p class="description"><?php _e('The hierarchy which the breadcrumb trail will show. Note that the "Post Parent" option may require an additional plugin to behave as expected since this is a non-hierarchical post type.', 'breadcrumb-navxt'); ?></p>
- </td>
- </tr>
- </table>
- <h3><?php _e('Pages', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_text(__('Page Template', 'breadcrumb-navxt'), 'Hpost_page_template', 'large-text', false, __('The template for page breadcrumbs.', 'breadcrumb-navxt'));
- $this->input_text(__('Page Template (Unlinked)', 'breadcrumb-navxt'), 'Hpost_page_template_no_anchor', 'large-text', false, __('The template for page breadcrumbs, used only when the breadcrumb is not linked.', 'breadcrumb-navxt'));
- $this->input_text(__('Attachment Template', 'breadcrumb-navxt'), 'Hpost_attachment_template', 'large-text', false, __('The template for attachment breadcrumbs.', 'breadcrumb-navxt'));
- $this->input_text(__('Attachment Template (Unlinked)', 'breadcrumb-navxt'), 'Hpost_attachment_template_no_anchor', 'large-text', false, __('The template for attachment breadcrumbs, used only when the breadcrumb is not linked.', 'breadcrumb-navxt'));
- ?>
- </table>
- <?php
- //Loop through all of the post types in the array
- foreach($wp_post_types as $post_type)
- {
- //Check for non-public CPTs
- if(!apply_filters('bcn_show_cpt_private', $post_type->public, $post_type->name))
- {
- continue;
- }
- //We only want custom post types
- if(!$post_type->_builtin)
- {
- $singular_name_lc = mb_strtolower($post_type->labels->singular_name, 'UTF-8');
- ?>
- <h3><?php echo $post_type->labels->singular_name; ?></h3>
- <table class="form-table">
- <?php
- $this->input_text(sprintf(__('%s Template', 'breadcrumb-navxt'), $post_type->labels->singular_name), 'Hpost_' . $post_type->name . '_template', 'large-text', false, sprintf(__('The template for %s breadcrumbs.', 'breadcrumb-navxt'), $singular_name_lc));
- $this->input_text(sprintf(__('%s Template (Unlinked)', 'breadcrumb-navxt'), $post_type->labels->singular_name), 'Hpost_' . $post_type->name . '_template_no_anchor', 'large-text', false, sprintf(__('The template for %s breadcrumbs, used only when the breadcrumb is not linked.', 'breadcrumb-navxt'), $singular_name_lc));
- $optid = $this->get_valid_id('apost_' . $post_type->name . '_root');
- ?>
- <tr valign="top">
- <th scope="row">
- <label for="<?php echo $optid;?>"><?php printf(__('%s Root Page', 'breadcrumb-navxt'), $post_type->labels->singular_name);?></label>
- </th>
- <td>
- <?php wp_dropdown_pages(array('name' => $this->unique_prefix . '_options[apost_' . $post_type->name . '_root]', 'id' => $optid, 'echo' => 1, 'show_option_none' => __( '— Select —' ), 'option_none_value' => '0', 'selected' => $this->opt['apost_' . $post_type->name . '_root']));?>
- </td>
- </tr>
- <?php
- $this->input_check(sprintf(__('%s Archive Display', 'breadcrumb-navxt'), $post_type->labels->singular_name), 'bpost_' . $post_type->name . '_archive_display', sprintf(__('Show the breadcrumb for the %s post type archives in the breadcrumb trail.', 'breadcrumb-navxt'), $singular_name_lc), !$post_type->has_archive);
- $this->input_check(sprintf(__('%s Hierarchy Display', 'breadcrumb-navxt'), $post_type->labels->singular_name), 'bpost_' . $post_type->name . '_taxonomy_display', sprintf(__('Show the taxonomy leading to a %s in the breadcrumb trail.', 'breadcrumb-navxt'), $singular_name_lc));
- ?>
- <tr valign="top">
- <th scope="row">
- <?php printf(__('%s Hierarchy', 'breadcrumb-navxt'), $post_type->labels->singular_name); ?>
- </th>
- <td>
- <?php
- //We use the value 'page' but really, this will follow the parent post hierarchy
- $this->input_radio('Spost_' . $post_type->name . '_taxonomy_type', 'page', __('Post Parent'));
- //Loop through all of the taxonomies in the array
- foreach($wp_taxonomies as $taxonomy)
- {
- //Check for non-public taxonomies
- if(!apply_filters('bcn_show_tax_private', $taxonomy->public, $taxonomy->name))
- {
- continue;
- }
- //We only want custom taxonomies
- if($taxonomy->object_type == $post_type->name || in_array($post_type->name, $taxonomy->object_type))
- {
- $this->input_radio('Spost_' . $post_type->name . '_taxonomy_type', $taxonomy->name, $taxonomy->labels->singular_name);
- }
- }
- ?>
- <p class="description">
- <?php
- if($post_type->hierarchical)
- {
- _e('The hierarchy which the breadcrumb trail will show.', 'breadcrumb-navxt');
- }
- else
- {
- _e('The hierarchy which the breadcrumb trail will show. Note that the "Post Parent" option may require an additional plugin to behave as expected since this is a non-hierarchical post type.', 'breadcrumb-navxt');
- }
- ?>
- </p>
- </td>
- </tr>
- </table>
- <?php
- }
- }
- do_action($this->unique_prefix . '_after_settings_tab_post');
- ?>
- </fieldset>
- <fieldset id="tax" class="bcn_options alttab">
- <h3 class="tab-title" title="<?php _e('The settings for all taxonomies (including Categories, Tags, and custom taxonomies) are located under this tab.', 'breadcrumb-navxt');?>"><?php _e('Taxonomies', 'breadcrumb-navxt'); ?></h3>
- <h3><?php _e('Categories', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_text(__('Category Template', 'breadcrumb-navxt'), 'Hcategory_template', 'large-text', false, __('The template for category breadcrumbs.', 'breadcrumb-navxt'));
- $this->input_text(__('Category Template (Unlinked)', 'breadcrumb-navxt'), 'Hcategory_template_no_anchor', 'large-text', false, __('The template for category breadcrumbs, used only when the breadcrumb is not linked.', 'breadcrumb-navxt'));
- ?>
- </table>
- <h3><?php _e('Tags', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_text(__('Tag Template', 'breadcrumb-navxt'), 'Hpost_tag_template', 'large-text', false, __('The template for tag breadcrumbs.', 'breadcrumb-navxt'));
- $this->input_text(__('Tag Template (Unlinked)', 'breadcrumb-navxt'), 'Hpost_tag_template_no_anchor', 'large-text', false, __('The template for tag breadcrumbs, used only when the breadcrumb is not linked.', 'breadcrumb-navxt'));
- ?>
- </table>
- <h3><?php _e('Post Formats', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_text(__('Post Format Template', 'breadcrumb-navxt'), 'Hpost_format_template', 'large-text', false, __('The template for post format breadcrumbs.', 'breadcrumb-navxt'));
- $this->input_text(__('Post Format Template (Unlinked)', 'breadcrumb-navxt'), 'Hpost_format_template_no_anchor', 'large-text', false, __('The template for post_format breadcrumbs, used only when the breadcrumb is not linked.', 'breadcrumb-navxt'));
- ?>
- </table>
- <?php
- //Loop through all of the taxonomies in the array
- foreach($wp_taxonomies as $taxonomy)
- {
- //Check for non-public taxonomies
- if(!apply_filters('bcn_show_tax_private', $taxonomy->public, $taxonomy->name))
- {
- continue;
- }
- //We only want custom taxonomies
- if(!$taxonomy->_builtin)
- {
- $label_lc = mb_strtolower($taxonomy->label, 'UTF-8');
- ?>
- <h3><?php echo mb_convert_case($taxonomy->label, MB_CASE_TITLE, 'UTF-8'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_text(sprintf(__('%s Template', 'breadcrumb-navxt'), $taxonomy->labels->singular_name), 'H' . $taxonomy->name . '_template', 'large-text', false, sprintf(__('The template for %s breadcrumbs.', 'breadcrumb-navxt'), $label_lc));
- $this->input_text(sprintf(__('%s Template (Unlinked)', 'breadcrumb-navxt'), $taxonomy->labels->singular_name), 'H' . $taxonomy->name . '_template_no_anchor', 'large-text', false, sprintf(__('The template for %s breadcrumbs, used only when the breadcrumb is not linked.', 'breadcrumb-navxt'), $label_lc));
- ?>
- </table>
- <?php
- }
- }
- do_action($this->unique_prefix . '_after_settings_tab_taxonomy'); ?>
- </fieldset>
- <fieldset id="miscellaneous" class="bcn_options">
- <h3 class="tab-title" title="<?php _e('The settings for author and date archives, searches, and 404 pages are located under this tab.', 'breadcrumb-navxt');?>"><?php _e('Miscellaneous', 'breadcrumb-navxt'); ?></h3>
- <h3><?php _e('Author Archives', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_text(__('Author Template', 'breadcrumb-navxt'), 'Hauthor_template', 'large-text', false, __('The template for author breadcrumbs.', 'breadcrumb-navxt'));
- $this->input_text(__('Author Template (Unlinked)', 'breadcrumb-navxt'), 'Hauthor_template_no_anchor', 'large-text', false, __('The template for author breadcrumbs, used only when the breadcrumb is not linked.', 'breadcrumb-navxt'));
- $this->input_select(__('Author Display Format', 'breadcrumb-navxt'), 'Sauthor_name', array("display_name", "nickname", "first_name", "last_name"), false, __('display_name uses the name specified in "Display name publicly as" under the user profile the others correspond to options in the user profile.', 'breadcrumb-navxt'));
- ?>
- </table>
- <h3><?php _e('Miscellaneous', 'breadcrumb-navxt'); ?></h3>
- <table class="form-table">
- <?php
- $this->input_text(__('Date Template', 'breadcrumb-navxt'), 'Hdate_template', 'large-text', false, __('The template for date breadcrumbs.', 'breadcrumb-navxt'));
- $this->input_text(__('Date Template (Unlinked)', 'breadcrumb-navxt'), 'Hdate_template_no_anchor', 'large-text', false, __('The template for date breadcrumbs, used only when the breadcrumb is not linked.', 'breadcrumb-navxt'));
- $this->input_text(__('Search Template', 'breadcrumb-navxt'), 'Hsearch_template', 'large-text', false, __('The anchor template for search breadcrumbs, used only when the search results span several pages.', 'breadcrumb-navxt'));
- $this->input_text(__('Search Template (Unlinked)', 'breadcrumb-navxt'), 'Hsearch_template_no_anchor', 'large-text', false, __('The anchor template for search breadcrumbs, used only when the search results span several pages and the breadcrumb is not linked.', 'breadcrumb-navxt'));
- $this->input_text(__('404 Title', 'breadcrumb-navxt'), 'S404_title', 'regular-text');
- $this->input_text(__('404 Template', 'breadcrumb-navxt'), 'H404_template', 'large-text', false, __('The template for 404 breadcrumbs.', 'breadcrumb-navxt'));
- ?>
- </table>
- <?php do_action($this->unique_prefix . '_after_settings_tab_miscellaneous'); ?>
- </fieldset>
- </div>
- <p class="submit"><input type="submit" class="button-primary" name="bcn_admin_options" value="<?php esc_attr_e('Save Changes') ?>" /></p>
- </form>
- <?php
- //Need to add a separate menu thing for this
- $this->import_form(); ?>
- </div>
- <?php
- }
- function opts_fix(&$opts)
- {
- if($opts['amax_title_length'] < 1)
- {
- $opts['amax_title_length'] = 1;
- }
- }
- function opts_update_prebk(&$opts)
- {
- //Add custom post types
- $this->find_posttypes($opts);
- //Add custom taxonomy types
- $this->find_taxonomies($opts);
- }
- /**
- * Places settings into $opts array, if missing, for the registered post types
- *
- * @param array $opts
- */
- function find_posttypes(&$opts)
- {
- global $wp_post_types, $wp_taxonomies;
- //Loop through all of the post types in the array
- foreach($wp_post_types as $post_type)
- {
- //Check for non-public CPTs
- if(!apply_filters('bcn_show_cpt_private', $post_type->public, $post_type->name))
- {
- continue;
- }
- //We only want custom post types
- if(!$post_type->_builtin)
- {
- //If the post type does not have settings in the options array yet, we need to load some defaults
- if(!array_key_exists('Hpost_' . $post_type->name . '_template', $opts) || !$post_type->hierarchical && !array_key_exists('Spost_' . $post_type->name . '_taxonomy_type', $opts))
- {
- //Add the necessary option array members
- $opts['Hpost_' . $post_type->name . '_template'] = __('<a title="Go to %ftitle%." href="%link%">%htitle%</a>', 'breadcrumb-navxt');
- $opts['Hpost_' . $post_type->name . '_template_no_anchor'] = __('%htitle%', 'breadcrumb-navxt');
- $opts['bpost_' . $post_type->name . '_archive_display'] = $post_type->has_archive;
- //Do type dependent tasks
- if($post_type->hierarchical)
- {
- //Set post_root for hierarchical types
- $opts['apost_' . $post_type->name . '_root'] = get_option('page_on_front');
- //Default to displaying a 'taxonomy'
- $opts['bpost_' . $post_type->name . '_taxonomy_display'] = true;
- //The 'taxonomy' is the page/post hierarchy for hierarchical post types
- $opts['Spost_' . $post_type->name . '_taxonomy_type'] = 'page';
- }
- //If it is flat, we need a taxonomy selection
- else
- {
- //Set post_root for flat types
- $opts['apost_' . $post_type->name . '_root'] = get_option('page_for_posts');
- //Default to not displaying a taxonomy
- $opts['bpost_' . $post_type->name . '_taxonomy_display'] = false;
- //Loop through all of the possible taxonomies
- foreach($wp_taxonomies as $taxonomy)
- {
- //Check for non-public taxonomies
- if(!apply_filters('bcn_show_tax_private', $taxonomy->public, $taxonomy->name))
- {
- continue;
- }
- //Activate the first taxonomy valid for this post type and exit the loop
- if($taxonomy->object_type == $post_type->name || in_array($post_type->name, $taxonomy->object_type))
- {
- $opts['bpost_' . $post_type->name . '_taxonomy_display'] = true;
- $opts['Spost_' . $post_type->name . '_taxonomy_type'] = $taxonomy->name;
- break;
- }
- }
- }
- //If there are no valid taxonomies for this type, we default to not displaying taxonomies for this post type
- if(!isset($opts['Spost_' . $post_type->name . '_taxonomy_type']))
- {
- $opts['Spost_' . $post_type->name . '_taxonomy_type'] = 'page';
- }
- }
- }
- }
- }
- /**
- * Places settings into $opts array, if missing, for the registered taxonomies
- *
- * @param $opts
- */
- function find_taxonomies(&$opts)
- {
- global $wp_taxonomies;
- //We'll add our custom taxonomy stuff at this time
- foreach($wp_taxonomies as $taxonomy)
- {
- //Check for non-public taxonomies
- if(!apply_filters('bcn_show_tax_private', $taxonomy->public, $taxonomy->name))
- {
- continue;
- }
- //We only want custom taxonomies
- if(!$taxonomy->_builtin)
- {
- //If the taxonomy does not have settings in the options array yet, we need to load some defaults
- if(!array_key_exists('H' . $taxonomy->name . '_template', $opts))
- {
- //Add the necessary option array members
- $opts['H' . $taxonomy->name . '_template'] = __(sprintf('<a title="Go to the %%ftitle%% %s archives." href="%%link%%">%%htitle%%</a>', $taxonomy->labels->singular_name), 'breadcrumb-navxt');
- $opts['H' . $taxonomy->name . '_template_no_anchor'] = __(sprintf('%%htitle%%', $taxonomy->labels->singular_name), 'breadcrumb-navxt');
- }
- }
- }
- }
- /**
- * Hooks into the theme hook alliance tha_breadcrumb_navigation filter and replaces the trail
- * with one generated by Breadcrumb NavXT
- *
- * @param string $bradcrumb_trail The string breadcrumb trail that we will replace
- * @return string The Breadcrumb NavXT assembled breadcrumb trail
- */
- function tha_compat($breadcrumb_trail)
- {
- //Return our breadcrumb trail
- return $this->display(true);
- }
- /**
- * Outputs the breadcrumb trail
- *
- * @param bool $return Whether to return or echo the trail.
- * @param bool $linked Whether to allow hyperlinks in the trail or not.
- * @param bool $reverse Whether to reverse the output or not.
- */
- function display($return = false, $linked = true, $reverse = false)
- {
- //Grab the current settings from the db
- $this->breadcrumb_trail->opt = wp_parse_args(get_option('bcn_options'), $this->opt);
- //Generate the breadcrumb trail
- $this->breadcrumb_trail->fill();
- return $this->breadcrumb_trail->display($return, $linked, $reverse);
- }
- /**
- * Outputs the breadcrumb trail
- *
- * @since 3.2.0
- * @param bool $return Whether to return or echo the trail.
- * @param bool $linked Whether to allow hyperlinks in the trail or not.
- * @param bool $reverse Whether to reverse the output or not.
- */
- function display_list($return = false, $linked = true, $reverse = false)
- {
- //Grab the current settings from the db
- $this->breadcrumb_trail->opt = wp_parse_args(get_option('bcn_options'), $this->opt);
- //Generate the breadcrumb trail
- $this->breadcrumb_trail->fill();
- return $this->breadcrumb_trail->display_list($return, $linked, $reverse);
- }
- }
- //In the future there will be a hook for this so derivatives of bcn_breadcrumb_trail can use the admin
- $bcn_breadcrumb_trail = new bcn_breadcrumb_trail();
- //Let's make an instance of our object takes care of everything
- $bcn_admin = new bcn_admin($bcn_breadcrumb_trail);
- /**
- * A wrapper for the internal function in the class
- *
- * @param bool $return Whether to return or echo the trail. (optional)
- * @param bool $linked Whether to allow hyperlinks in the trail or not. (optional)
- * @param bool $reverse Whether to reverse the output or not. (optional)
- */
- function bcn_display($return = false, $linked = true, $reverse = false)
- {
- global $bcn_admin;
- if($bcn_admin !== null)
- {
- return $bcn_admin->display($return, $linked, $reverse);
- }
- }
- /**
- * A wrapper for the internal function in the class
- *
- * @param bool $return Whether to return or echo the trail. (optional)
- * @param bool $linked Whether to allow hyperlinks in the trail or not. (optional)
- * @param bool $reverse Whether to reverse the output or not. (optional)
- */
- function bcn_display_list($return = false, $linked = true, $reverse = false)
- {
- global $bcn_admin;
- if($bcn_admin !== null)
- {
- return $bcn_admin->display_list($return, $linked, $reverse);
- }
- }