Polylangは便利なWordpress多言語化プラグインです。
でも使っていて不便なことがあります。
それは、ログイン状態でサイトを閲覧している時のadmin barの表示が選択した言語に切り替わってしまうことです。
英語と日本語の多言語サイトなら困ることはないのですが、中国語や英語以外の言語の場合、サイトを閲覧しながらページの編集をしたいと思った時に、メニューの表記が読めなくてイライラすることがあります。
ある程度時間が経てば慣れてくるのですが、出来ればadmin barの言語は固定にしたい。
そこで、この記事ではPolylangを使っている時にadmin barの言語が切り替わらないようにするカスタマイズをご紹介します。
結論から申し上げますと、以下のプラグインを導入することで、ユーザーの言語設定でadmin barが表示されるようになります。
GitHub - aucor/preserve-admin-language-in-admin-bar: A polylang add-on to preserve the user selected administration language also in front-end admin bar.
A polylang add-on to preserve the user selected administration language also in front-end admin bar. - aucor/preserve-ad...
必要なファイルは1つだけなので、プラグインとしてインストールするのが面倒という場合は、functions.phpに張り付けたり、Code snippetsなどに張り付けることで回避できます。
<?php
/**
Plugin Name: Polylang add-on: Preserve admin language in admin bar
Plugin Description:
Author: Aucor Oy
Version: 1.0.1
Author URI: https://www.aucor.fi
*/
/**
* Checks if current view may require admin bar language switching
*
* The function is based on is_admin_bar_showing() but cannot use it directly
* as `is_embed()` inside that function causes notices in this hook.
*
* @see https://developer.wordpress.org/reference/functions/is_admin_bar_showing/
*/
function preserve_admin_language_is_needed() {
global $show_admin_bar, $pagenow;
// for all these types of requests, we never want an admin bar.
if (defined( 'XMLRPC_REQUEST' ) || defined( 'DOING_AJAX' ) || defined( 'IFRAME_REQUEST' ) || (function_exists('wp_is_json_request') && wp_is_json_request())) {
return false;
}
if (!isset($show_admin_bar)) {
if (!is_user_logged_in() || 'wp-login.php' == $pagenow) {
$show_admin_bar = false;
} else {
$show_admin_bar = _get_admin_bar_pref();
}
}
/**
* Filters whether to show the admin bar.
*
* Returning false to this hook is the recommended way to hide the admin bar.
* The user's display preference is used for logged in users.
*
* @since 3.1.0
*
* @param bool $show_admin_bar Whether the admin bar should be shown. Default false.
*/
$show_admin_bar = apply_filters('show_admin_bar', $show_admin_bar);
return $show_admin_bar;
}
/**
* If user has picked their preferred language, keep admin bar in that locale.
*
* @param string $mofile path to the MO file
* @param string $domain text domain
*
* @return string $mofile
*/
function preserve_admin_language_in_admin_bar($mofile, $domain) {
if (preserve_admin_language_is_needed() && $domain == 'default' ) {
$user_id = get_current_user_id();
$user_language = get_user_meta($user_id, 'user_lang', true);
if ($user_language !== '') {
$user_language = get_option('WPLANG');
}
$mofile = WP_LANG_DIR . "/$user_language.mo";
}
return $mofile;
}
add_filter('load_textdomain_mofile', 'preserve_admin_language_in_admin_bar', 10, 2);
関数 preserve_admin_language_is_needed
function preserve_admin_language_is_needed() {
global $show_admin_bar, $pagenow;
// 特定のリクエストタイプでは管理バーを表示しない
if (defined('XMLRPC_REQUEST') || defined('DOING_AJAX') || defined('IFRAME_REQUEST') || (function_exists('wp_is_json_request') && wp_is_json_request())) {
return false;
}
if (!isset($show_admin_bar)) {
if (!is_user_logged_in() || 'wp-login.php' == $pagenow) {
$show_admin_bar = false;
} else {
$show_admin_bar = _get_admin_bar_pref();
}
}
$show_admin_bar = apply_filters('show_admin_bar', $show_admin_bar);
return $show_admin_bar;
}
- この関数は、現在のリクエストが管理バーを表示する必要があるかを判断します。
- XML-RPCリクエスト、AJAXリクエスト、iframeリクエストなど、特定のリクエストでは管理バーを表示しません。
- ユーザーがログインしていない、またはログインページにいる場合は、管理バーを表示しないように設定します。
- 最終的に、
show_admin_bar
フィルターを適用し、管理バーを表示するかどうかを決定します。
関数 preserve_admin_language_in_admin_bar
function preserve_admin_language_in_admin_bar($mofile, $domain) {
if (preserve_admin_language_is_needed() && $domain == 'default') {
$user_id = get_current_user_id();
$user_language = get_user_meta($user_id, 'user_lang', true);
if ($user_language !== '') {
$user_language = get_option('WPLANG');
}
$mofile = WP_LANG_DIR . "/$user_language.mo";
}
return $mofile;
}
add_filter('load_textdomain_mofile', 'preserve_admin_language_in_admin_bar', 10, 2);
- この関数は、管理バーにおいてユーザーが選択した言語を保持するためのものです。
preserve_admin_language_is_needed
関数が真を返し、ドメインが「default」の場合、ユーザーの言語設定を取得します。- ユーザーの言語が設定されている場合、それに基づいてMOファイルのパスを変更します。
- 最後に、フィルター
load_textdomain_mofile
を使って、適切なMOファイルを読み込むように設定します。