This thread is resolved. Here is a description of the problem and solution.
Problem: The site is using the Header Footer Code Manager to load a snippet with a noindex tag into the head of the source code for specific pages. They are trying to ensure that the translated pages on your site have the same noindex tag as the original pages. The noindex tag is present in the original page's code, but it is missing in the translated versions. Solution: To include the noindex tag in the translated pages using WPML, you need to modify the code in the header-footer-code-manager plugin. Follow these steps: 1. Open the
file. 2. Locate line 550. 3. Open the .../wp-content/plugins/header-footer-code-manager/99robots-header-footer-code-manager.php file
Look for line 550
Replace:
case 's_pages':
$is_not_empty_s_pages = self::hfcm_not_empty( $scriptdata, 's_pages' );
if ( $is_not_empty_s_pages ) {
// Gets the page ID of the blog page
$blog_page = get_option( 'page_for_posts' );
// Checks if the blog page is present in the array of selected pages
if ( in_array( $blog_page, json_decode( $scriptdata->s_pages ) ) ) {
if ( is_page( json_decode( $scriptdata->s_pages ) ) || (!is_front_page() && is_home()) ) {
$out = self::hfcm_render_snippet( $scriptdata );
}
} elseif ( is_page( json_decode( $scriptdata->s_pages ) ) ) {
$out = self::hfcm_render_snippet( $scriptdata );
}
}
break;
With:
case 's_pages':
$is_not_empty_s_pages = self::hfcm_not_empty( $scriptdata, 's_pages' );
if ( $is_not_empty_s_pages ) {
// WPML workaround for compsupp-7802
$original_ids = json_decode( $scriptdata->s_pages);
foreach ( $original_ids as $original_id ) {
$translated_ids[] = apply_filters( 'wpml_object_id', $original_id, 'page');
}
// Gets the page ID of the blog page
$blog_page = get_option( 'page_for_posts' );
// Checks if the blog page is present in the array of selected pages
if ( in_array( $blog_page, json_decode( $scriptdata->s_pages ) ) ) {
if ( is_page( $translated_ids ) || (!is_front_page() && is_home()) ) {
$out = self::hfcm_render_snippet( $scriptdata );
}
} elseif ( is_page( $translated_ids ) ) {
$out = self::hfcm_render_snippet( $scriptdata );
}
}
break;
This modification ensures that the noindex tag is applied to translated pages as well. If this solution does not resolve your issue or seems outdated, please check the related known issues and confirm that you have installed the latest versions of themes and plugins. If necessary, do not hesitate to open a new support ticket.
This is the technical support forum for WPML - the multilingual WordPress plugin.
Everyone can read, but only WPML clients can post here. WPML team is replying on the forum 6 days per week, 22 hours per day.
Background of the issue:
I am trying to ensure that the translated pages on my site, hidden link, have the same noindex tag as the original pages. The noindex tag is present in the original page's code, but it is missing in the translated versions. For example, the original page hidden link includes the noindex tag, but the translated page hidden link does not.
Symptoms:
The translated pages do not have the noindex tag which is present in the original pages.
Questions:
How can I ensure that the noindex tag is included in the translated pages using WPML?
It is added with HFCM plugin:
<!-- HFCM by 99 Robots - Snippet # 1: Noindex -->
<meta name="robots" content="noindex">
<!-- /end HFCM by 99 Robots -->
You should see at in the source!
Your proposal is hardly acceptable (many pages and many languages) and not clear:
Re 1. The page in default language is correct
Re 2. The language switcher is not available in WP editor, only in preview
Re 3. Where and how should be the tag added - manually in HTML? I do not do it!
Please answer the questions above and provide a proper solution ASAP!
Now, you should be able to translate these custom posts and create one code snippet per language.
If you translate those custom posts with the WPML Translation Editor, you might need to take a look into WPML > Settings > Custom Field Translation and make sure that fields that come from this plugin are set properly to "Copy" or "Translate".
Take note, that if you implement a snippet per shortcode, then each shortcode in each language will have a unique ID. You would need to place those shortcodes manually on each page, post, or template in such cases.
If this will not solve the issue, please let us know.
1. Your responce looks for me as not 100% relevant - may be you have confused me with somebody else.
You write about POSTS - I was asking about NOINDEX tag in PAGES
so the guide: https://wpml.org/documentation/getting-started-guide/translating-custom-posts/
is to the best of my understanding irrelevant (I checked it), pls correct if not
2. I do not see any fields coming from HFCM in CustomFieldsTranslation, cf. screenshot. Which field would be expected?
3. For the development site where search engines are prohibited in WP.Settings NOINDEX is present, however coming from another plugin (All in One SEO), cf. screenshots
3. As I have said I implement the NOINDEX tag with HFCM plugin. Do you call it snippet? Cf screenshot.
How to place shortcodes manually on each page?
4.Please answer my questions about your colleague’s proposal:
Bobby.2. Use the language switcher dropdown and switch to the secondary language (exit fullscreen if guttenberg is used)
The language switcher is not available in WP editor, only in preview - where no editing is possible
Bobby.3. Add the noindex tag if you are using a custom field to enable it and update
Where and how should be the tag added - manually in HTML - please elaborate!
Languages: English (English )Spanish (Español )German (Deutsch )
Timezone: America/Lima (GMT-05:00)
Thank you for your message.
I can see that the meta tag is not loaded here:
view-source:hidden link
I created a test site and tried to replicate the issue. You can see here on the "Sample Page" and its translation that the meta tag is appearing as expected:
Could you please increase the WordPress memory limit (WP Memory Limit) to at least 256 MB? WPML requires at least 128M.
Your current values are:
PHP MemoryLimit 512M
WP Memory Limit 40M
You need to connect to your website's server and open the wp-config.php file in a text editor. The file is located in the WordPress root directory.
Add this code to the wp-config.php file to increase WordPress memory:
define ('WP_MEMORY_LIMIT', '256M');
Add this just before this comment:
// That's all, stop editing! Happy blogging.
The current values can be viewed under WPML > Support > WordPress.
These settings can be restricted directly by your hosting provider. Therefore, I recommend contacting them and asking them to change them directly if the changes are not applied immediately.
If adjusting the limit will not solve the issue, please let me know.
1. Regretfully I must state that you do not read my communication diligently (cf. 2.) and you do not answer my question with regards to yours and Bobby’s instructions which I try to follow.
If you are not willing or not able to do this, please transfer the case to somebody else e.g. Marcel or Prosenjit.
My questions are of general importance for me as well.
2. Re your test site:
The ”noindex” tag is due to
Discourage search engines from indexing this site.
I have the same behavior at the development site, cf.
DEV.WP-Settings.Noindex_20250111.jpg – provided before. Read!
3. It is not true that WP Memory Limit is 40M, cf. Prod.WP-config_20250111.jpg and Prod.WPML.Support_20250111.jpg – it is 128Mb
You may check it by requesting the debug information
Languages: English (English )Spanish (Español )German (Deutsch )
Timezone: America/Lima (GMT-05:00)
My apologies, it seems like Bobby and I did not capture the issue directly.
The HFCM plugin is not fully compatible with WPML.
The problem is the display condition for specific pages, as each page has a different ID and this is why the code is not showing up on the translated pages.
Example:
Go to your code snippet, switch the language inside the top admin bar and you will see that the Page List field is empty. You can now select a page here, and the code will show up on the selected page in a second language, but this will empty the field on the site's default language.
To fix this issue compatibility code WPML would need to be implemented into this plugin. I can offer to find a solution for this issue and escalate the problem to the compatibility team for further revision.
Alternative: Try a different plugin like "Code Snippets" or "WP Code".
Better late than never - thank you!
I would appreciate if you escalate, I hope it will be not months.
Regarding my questions – please answer:
A
Bobby.2. Use the language switcher dropdown and switch to the secondary language (exit fullscreen if guttenberg is used)
The language switcher is not available in WP editor, only in preview - where no editing is possible
Bobby.3. Add the noindex tag if you are using a custom field to enable it and update
Where and how should be the tag added - manually in HTML? - please elaborate!
B (you)
1 WPML > Settings > Custom Field Translation and make sure that fields that come from this plugin are set properly to "Copy" or "Translate".
Take note, that if you implement a snippet per shortcode, then each shortcode in each language will have a unique ID. You would need to place those shortcodes manually on each page, post, or template in such cases.
If HFCM would work properly which field would be expected?
How to place shortcodes manually on each page?
Basically, it is about where, how and if I can edit a translated page – WP editor or only WPML advance editor
Thx
Languages: English (English )Spanish (Español )German (Deutsch )
Timezone: America/Lima (GMT-05:00)
WORKAROUND:
In the file \wp-content\plugins\header-footer-code-manager\includes\hfcm-add-edit.php on line 206 replace the SELECT element with this version:
<select name="data[s_pages][]" multiple>
<?php
foreach ( $nnr_hfcm_pages as $pdata ) {
if ( class_exists( 'sitepress' ) ) {
// WPML is active, fetch translations
$translations = apply_filters( 'wpml_get_element_translations', null, $pdata->ID, 'post_page' );
// Loop through each translation and display it in the select field
foreach ( $translations as $lang_code => $translation ) {
$lang_name = isset($translation->language_name) ? $translation->language_name : ''; // Get language name (optional)
$selected = in_array( $pdata->ID, $s_pages ) ? 'selected="selected"' : ''; // Check if page is selected
printf(
'<option value="%1$s" %2$s>%3$s (%4$s)</option>',
esc_attr( $translation->element_id ),
esc_attr( $selected ),
esc_html( $translation->post_title ),
esc_html( $lang_code ) // Display language code or language name
);
}
} else {
// WPML is not active, use the default logic
$selected = in_array( $pdata->ID, $s_pages ) ? 'selected="selected"' : ''; // Check if page is selected
printf(
'<option value="%1$s" %2$s>%3$s</option>',
esc_attr( $pdata->ID ),
esc_attr( $selected ),
esc_html( $pdata->post_title )
);
}
}
?>
</select>
This way the select field will display all pages including their language code and you will be able to set display conditions for pages in different languages.
Take note, that other display condition fields of the plugin need similar implementations to be able to work with WPML.
I will be escalating the issue now to the compatibility team for further revision, but please take note that it requires the cooperation of the author from HFCM to make it possible for the plugin will work with WPML.
As this plugin offers a PRO it is very likely that if the author considers implementing compatibility code for WPML, then this will likely only be the case for the PRO version of the plugin.
I suggest you reach out to the author on wordpress.org and invite the author to join our Go Global program so that we can assist in making the plugin compatible with WPML. Our compatibility and partnership team might try to obtain the cooperation of the author as well.
Thank you for the workaround, however there is no “select…” on line 206, something similar is in lines 174-184, cf. screenshots.
Line 206 reads:
$nnr_hfcm_location_style = 'manual' === $display_on ? 'display:none;' : '';
Please clarify
Please answer my question (resulting from yours and Bobby’s instruction:
How and if I can edit a translated page – WP editor or only WPML advance editor?
Languages: English (English )Spanish (Español )German (Deutsch )
Timezone: America/Lima (GMT-05:00)
My apologies, the line I mentioned is not correct, as I took further edits on the file to make other inputs work for testing.
Search for:
<select name="data[s_pages][]" multiple>
This way you will find the section.
If you need my assistance with applying the workaround, and would like to provide admin access to your site, please let me know and I will enable the private reply form.
Great, it works!
Thank you very much.
Some observations:
1 If I add a page to the Page List for snippet NOINDEX in HFCM plugin, like the page
Coffee table B-604 from Univerzal Factory, 1950s
HFCM adds the tag to the page hidden link
but the page is not seen in the Page List of the snippet, cf. enclosure. The newly translation does no difference.
2. The page
Jindřich Halabala, Cocktail Armchair “C”, 1950s (N/A)
was initially newly translated and it appeared in the Page List of the snippet with no activity from my side, cf. enclosure.
3. What do you mean by “Take note, that other display condition fields of the plugin need similar implementations to be able to work with WPML.”
There is only one Page List, or am I wrong?
Thx
PS I have implemented you solution on the DEV environment, tomorrow I will do it in PROD
Languages: English (English )Spanish (Español )German (Deutsch )
Timezone: America/Lima (GMT-05:00)
1) I wrote code that adds all the pages in all languages. What you see behind the title is the language code of each page, like (en) for English.
2) The code I wrote will make sure that the dropdown displays everything that exists at Pages > All pages and will add a language code for each language. If you see unexpected pages in the list, then this must be because the page exists at Pages > All Pages.
3) Other display conditions of the plugin might have similar issues, like for example if you filter by post or other conditions. In this case, the plugin needs further adjustment.
Take note, that updating the plugin will overwrite the workaround.
I suggest you inform the author about the issue and ask if there are any plans to make the plugin compatible with WPML.