I recently modified this site to support English as well as Japanese by Polylang.
I am using Cocoon as WordPress theme made by Japanese engineer.
I found 1 deviation in breadcrumblist.
data:image/s3,"s3://crabby-images/55dab/55dabb02879fd79cb85aa6c0b1060bea0052a320" alt=""
Even if I switch this site English, there is “ホーム”.
– “ホーム” means “Home” in Japanese.
In this post I will show you how to show “Home” instead of “ホーム” when site is English version like this.
data:image/s3,"s3://crabby-images/64afc/64afc05d10ccb33fce55070a4bcc1a74e136d02c" alt=""
Official way how to change root text breadcrumblist in Cocoon
This is explained on the official website.
– Only in Japanese.
data:image/s3,"s3://crabby-images/0ddfc/0ddfc51be9838587f0b734fbd1fc0f7c8873784f" alt=""
To summarize what you need to do is to add a function with a child theme and specify a string.
On the official page mentioned earlier, the following code is a sample.
This code changes the string from “ホーム”(Home) to “トップ”(Top).
// Root text of breadcrumblist add_filter('breadcrumbs_single_root_text', 'breadcrumbs_root_text_custom'); add_filter('breadcrumbs_page_root_text', 'breadcrumbs_root_text_custom'); function breadcrumbs_root_text_custom(){ return 'トップ'; }
I’m also a programmer.
I came up with💡
data:image/s3,"s3://crabby-images/c9d64/c9d647980edce49dd7b549c83dd2b927a2e1767e" alt="yatch"
This can be customized to switch dynamically for each language!
How to do
Please take a look this code.
I added this to functions.php of child theme.
<?php //子テーマ用関数 if ( !defined( 'ABS_PATH' ) ) exit; //子テーマ用のビジュアルエディタースタイルを適用 add_editor_style(); //以下に子テーマ用の関数を書く // Switching root text by checking language of site // For post page add_filter('breadcrumbs_single_root_text', 'breadcrumbs_root_text_custom'); // For fixed page add_filter('breadcrumbs_page_root_text', 'breadcrumbs_root_text_custom'); function breadcrumbs_root_text_custom() { if('/en/' === substr($_SERVER['REQUEST_URI'], 0, 4)) { return 'Home'; } else { return 'ホーム'; } }
How it is realized
My site https://linuxfun.org/ switches between Japanese and English in directory format.
The link of the post is https://linuxfun.org/yyyy/mm/dd/%post-name%/.
data:image/s3,"s3://crabby-images/fb5d5/fb5d5b4faf9528d9d01d1030b44133a63f115653" alt=""
data:image/s3,"s3://crabby-images/06291/06291ac909c5bc55df7cf7c6c7cba716f098f174" alt=""
Therefore, if “/en/” continues after linuxfun.org in URL, I can assume this blog is configured as English mode.
If it is Japanese version, URL always starts with a number such as /2020/12/05/.
– And I do not have fixed page that starts with “/en/”.
This logic is also available if you want to add a Chinese site in the future.
However I think it annot be applied to identify American English and British English or so on.
I think there may exist more optimal way to realize, but this is reasonable for me.
Cocoon side mechanism
Let’s trace how this programmatic switching is realized.
We can find “apply_filters” function to decide breadcrumblist text.
grep -r breadcrumbs_page_root_text cocoon-master cocoon-master/tmp/breadcrumbs-page.php:$root_text = apply_filters('breadcrumbs_page_root_text', $root_text);
apply_filters function itself seems to be a built-in function of WordPress.
data:image/s3,"s3://crabby-images/9b274/9b27475f5a5f2fb384f8215b34a90ecc9142bdb9" alt=""
Now it is clear why this is realized.
Conclusion
How was it?
There are several other Places in Japanese that are In English sites.
– Button to encourage comment
– Placeholder of the search form
data:image/s3,"s3://crabby-images/cb210/cb210d8f184b32ca76c832cefd2bb9291c42de9b" alt=""
data:image/s3,"s3://crabby-images/7ec94/7ec94ef79f9813850c539c6f98d128d66cf9463a" alt=""
I want to find feasible way to switch them as well as breadcrumblist text!
By the way, Polylang itself is a very good plug-in!
data:image/s3,"s3://crabby-images/c816c/c816ce99c69a5fc3c4fbd249ea2add42683afa4f" alt=""
Comments