You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
177 lines
4.4 KiB
177 lines
4.4 KiB
<?php
|
|
/**
|
|
* @package Polylang
|
|
*/
|
|
|
|
/**
|
|
* Manages custom menus translations
|
|
* Common to admin and frontend for the customizer
|
|
*
|
|
* @since 1.7.7
|
|
*/
|
|
class PLL_Nav_Menu {
|
|
/**
|
|
* Stores the plugin options.
|
|
*
|
|
* @var array
|
|
*/
|
|
public $options;
|
|
|
|
/**
|
|
* @var PLL_Model
|
|
*/
|
|
public $model;
|
|
|
|
/**
|
|
* Theme name.
|
|
*
|
|
* @var string
|
|
*/
|
|
protected $theme;
|
|
|
|
/**
|
|
* Array of menu ids in a given language used when auto add pages to menus.
|
|
*
|
|
* @var int[]
|
|
*/
|
|
protected $auto_add_menus = array();
|
|
|
|
/**
|
|
* Constructor: setups filters and actions.
|
|
*
|
|
* @since 1.7.7
|
|
*
|
|
* @param object $polylang The Polylang object.
|
|
*/
|
|
public function __construct( &$polylang ) {
|
|
$this->model = &$polylang->model;
|
|
$this->options = &$polylang->options;
|
|
|
|
$this->theme = get_option( 'stylesheet' );
|
|
|
|
add_filter( 'wp_setup_nav_menu_item', array( $this, 'wp_setup_nav_menu_item' ) );
|
|
|
|
// Integration with WP customizer
|
|
add_action( 'customize_register', array( $this, 'create_nav_menu_locations' ), 5 );
|
|
|
|
// Filter _wp_auto_add_pages_to_menu by language
|
|
add_action( 'transition_post_status', array( $this, 'auto_add_pages_to_menu' ), 5, 3 ); // before _wp_auto_add_pages_to_menu
|
|
}
|
|
|
|
/**
|
|
* Assigns the title and label to the language switcher menu items
|
|
*
|
|
* @since 2.6
|
|
*
|
|
* @param stdClass $item Menu item.
|
|
* @return stdClass
|
|
*/
|
|
public function wp_setup_nav_menu_item( $item ) {
|
|
if ( isset( $item->url ) && '#pll_switcher' === $item->url ) {
|
|
$item->post_title = __( 'Languages', 'polylang' );
|
|
$item->type_label = __( 'Language switcher', 'polylang' );
|
|
}
|
|
return $item;
|
|
}
|
|
|
|
/**
|
|
* Create temporary nav menu locations ( one per location and per language ) for all non-default language
|
|
* to do only one time
|
|
*
|
|
* @since 1.2
|
|
*
|
|
* @return void
|
|
*/
|
|
public function create_nav_menu_locations() {
|
|
static $once;
|
|
global $_wp_registered_nav_menus;
|
|
|
|
$arr = array();
|
|
|
|
if ( isset( $_wp_registered_nav_menus ) && ! $once ) {
|
|
foreach ( $_wp_registered_nav_menus as $loc => $name ) {
|
|
foreach ( $this->model->get_languages_list() as $lang ) {
|
|
$arr[ $this->combine_location( $loc, $lang ) ] = $name . ' ' . $lang->name;
|
|
}
|
|
}
|
|
|
|
$_wp_registered_nav_menus = $arr;
|
|
$once = true;
|
|
}
|
|
}
|
|
|
|
/**
|
|
* Creates a temporary nav menu location from a location and a language
|
|
*
|
|
* @since 1.8
|
|
*
|
|
* @param string $loc Nav menu location.
|
|
* @param PLL_Language $lang Language object.
|
|
* @return string
|
|
*/
|
|
public function combine_location( $loc, $lang ) {
|
|
return $loc . ( strpos( $loc, '___' ) || $lang->is_default ? '' : '___' . $lang->slug );
|
|
}
|
|
|
|
/**
|
|
* Get nav menu locations and language from a temporary location.
|
|
*
|
|
* @since 1.8
|
|
*
|
|
* @param string $loc Temporary location.
|
|
* @return string[] {
|
|
* @type string $location Nav menu location.
|
|
* @type string $lang Language code.
|
|
* }
|
|
*/
|
|
public function explode_location( $loc ) {
|
|
$infos = explode( '___', $loc );
|
|
if ( 1 == count( $infos ) ) {
|
|
$infos[] = $this->options['default_lang'];
|
|
}
|
|
return array_combine( array( 'location', 'lang' ), $infos );
|
|
}
|
|
|
|
/**
|
|
* Filters the option nav_menu_options for auto added pages to menu.
|
|
*
|
|
* @since 0.9.4
|
|
*
|
|
* @param array $options Options stored in the option nav_menu_options.
|
|
* @return array Modified options.
|
|
*/
|
|
public function nav_menu_options( $options ) {
|
|
$options['auto_add'] = array_intersect( $options['auto_add'], $this->auto_add_menus );
|
|
return $options;
|
|
}
|
|
|
|
/**
|
|
* Filters _wp_auto_add_pages_to_menu by language.
|
|
*
|
|
* @since 0.9.4
|
|
*
|
|
* @param string $new_status Transition to this post status.
|
|
* @param string $old_status Previous post status.
|
|
* @param WP_Post $post Post object.
|
|
* @return void
|
|
*/
|
|
public function auto_add_pages_to_menu( $new_status, $old_status, $post ) {
|
|
if ( 'publish' != $new_status || 'publish' == $old_status || 'page' != $post->post_type || ! empty( $post->post_parent ) ) {
|
|
return;
|
|
}
|
|
|
|
if ( ! empty( $this->options['nav_menus'][ $this->theme ] ) ) {
|
|
$lang = $this->model->post->get_language( $post->ID );
|
|
$lang = empty( $lang ) ? $this->options['default_lang'] : $lang->slug; // If the page has no language yet, the default language will be assigned
|
|
|
|
// Get all the menus in the page language
|
|
foreach ( $this->options['nav_menus'][ $this->theme ] as $loc ) {
|
|
if ( ! empty( $loc[ $lang ] ) ) {
|
|
$this->auto_add_menus[] = $loc[ $lang ];
|
|
}
|
|
}
|
|
|
|
add_filter( 'option_nav_menu_options', array( $this, 'nav_menu_options' ) );
|
|
}
|
|
}
|
|
}
|
|
|