-
Notifications
You must be signed in to change notification settings - Fork 11
Dokan WPML Guides
- Text Detected in WPML String List but Not Translating after saving from Menu Manager
- JS String translation issue
- Dynamic text translation not working for large content
- Custom String Translation Guide
- Translate product categories for vendor product add/edit page by WPML
Issue Description: If any specific text is not being translated even when detected in the string list using WPML after saving the Menu manager
- Go to WPML β String Translation.
- Click on the "Translate texts in admin screens" link at the bottom of the page.
(Applicable for versions below v4.7) - Expand "Not seeing strings that you are looking for?" & click on the "Admin Texts Translation" located at the bottom of the expanded details.
(Applicable for version v4.7 and above) - Search for the text you want to translate on the next page.
- Select the text and click "Add to String Translation".
- Go back to String Translation and proceed to translate the selected text.
I hope this helps resolve your issue! ππ»
Note:
For the first time, this menu will function perfectly without requiring any steps.
WPML (WordPress Multilingual Plugin) currently has a limitation in its handling of JavaScript translations. While WPML successfully translates strings in PHP files, it does not automatically generate the necessary JSON files for translating strings in JavaScript files.
-
WordPress Translation Function: WordPress introduced the
wp_set_script_translations()
function to facilitate translations for JavaScript files. -
WPML's Current Behavior:
- WPML generates
.mo
files for PHP strings in the/wp-content/languages/wpml
directory. - However, WPML does not create the required JSON translation files for JavaScript strings.
- WPML generates
-
Result: JavaScript strings are not automatically translated by WPML, even when properly set up using WordPress's built-in localization functions.
This issue is documented in WPML's official errata: WPML Errata: Translating strings from JavaScript files using wp_set_script_translations()
https://wpml.org/errata/woocommerce-checkout-block-fails-to-translate-some-values/
- Multilingual websites using WPML may have inconsistent translations, with PHP-based content correctly translated but JavaScript-based content remaining in the original language.
- This can affect user experience, especially in dynamic parts of the website that rely heavily on JavaScript.
Until WPML addresses this issue,
Loco Translate: An Alternative Solution:
Unlike WPML, Loco Translate does support the creation of JSON files for JavaScript translations. This makes it a viable alternative for projects that heavily rely on JavaScript and require multilingual support.
- Install and activate the Loco Translate plugin.
- In your JavaScript file, use WordPress i18n functions as normal:
- In PHP file, set up script translations:
-
wp_set_script_translations('your-script-handle', 'your-text-domain', plugin_dir_path(__FILE__) . 'languages')
; - Use Loco Translate's interface to provide translations for your strings.
- Loco Translate will generate both .mo and .json files in your language directory.
Video Reference: Link
The permanent solution to this issue requires action from the WPML development team:
- WPML needs to implement support for generating JSON translation files for JavaScript strings.
- These JSON files should be automatically created alongside the existing
.mo
files. - WPML should ensure compatibility with WordPress's
wp_set_script_translations()
function.
- Navigate to WPML β String Translation.
- Find the text that you need to translate.
- Check the name of that string (Note: The string will not translate without a name).
- If the name is correct, search the code for any preset text(if any) and check the length of the concatenated value we use for the register. If the key or name length exceeds 260 characters, WPML cannot translate it.
I hope this will help you to resolve your issue! ππ»
For more, you can check out this issue and the related PR: https://github.com/getdokan/client-issue/issues/182
This guide explains how to register and retrieve custom translatable strings using the Dokan WPML integration.
Dokan WPML provides two main methods for handling custom string translations:
-
register_single_string()
- Registers a string for translation -
get_translated_single_string()
- Retrieves a translated string
public function register_single_string( $context, $name, $value )
-
$context
(string) - A grouping identifier for the string (e.g., 'dokan') -
$name
(string) - Unique identifier/name for the string -
$value
(string) - The actual string content to be translated
// Register a button text for translation
$this->register_single_string(
'dokan',
'Dokan Request Quote Button Text: ' . $rule_id,
$button_text
);
// Register a shipping status
$this->register_single_string(
'dokan',
'Dokan Shipping Status: ' . $status,
$status
);
public function get_translated_single_string( $original_value, $domain, $name, $language_code = null )
-
$original_value
(string) - The original untranslated string -
$domain
(string) - The context used when registering (e.g., 'dokan') -
$name
(string) - The unique identifier used when registering -
$language_code
(string|null) - Optional language code to retrieve specific translation
// Get translated button text
$translated_text = $this->get_translated_single_string(
$text,
'dokan',
'Dokan Request Quote Button Text: ' . $rule->id
);
// Get translated shipping status
$translated_status = $this->get_translated_single_string(
$status,
'dokan',
'Dokan Shipping Status: ' . $status
);
- DO action to register string .
example : after creation of RFQ rule . path:modules/request-for-quotation/includes/Helper.php
do_action( 'dokan_quote_rule_created', $inserted, $args, $wpdb->insert_id );
- Filter Text to get translatable string with required arguments example : To get button text of RFQ rule button text . path:modules/request-for-quotation/includes/Helper.php
$rule->button_text = apply_filters( 'dokan_request_quote_button_text', $rule->button_text, $rule );
Path : dokan-wpml.php
- Register String:
// In your action/hook handler
public function register_quote_button_text($action, $args, $rule_id) {
if (!$action) {
return;
}
$button_text = $args['button_text'];
$this->register_single_string(
'dokan',
'Dokan Request Quote Button Text: ' . $rule_id,
$button_text
);
}
- Add Action Hook:
add_action('dokan_quote_rule_created', [$this, 'register_quote_button_text'], 10, 3);
- Retrieve Translation:
// In your display/render function
public function get_translated_dokan_request_quote_button_text($text, $rule) {
return $this->get_translated_single_string(
$text,
'dokan',
'Dokan Request Quote Button Text: ' . $rule->id
);
}
- Add Filter:
add_filter('dokan_request_quote_button_text', [$this, 'get_translated_dokan_request_quote_button_text'], 10, 2);
-
Consistent Context: Use consistent context strings (first parameter in registration) to group related translations.
-
Unique Names: Create unique identifiers for strings by combining a descriptive prefix with dynamic IDs or Uniqe name:
'Dokan Request Quote Button Text: ' . $rule_id
-
If translations aren't appearing:
- Verify string registration is successful
- Check WPML String Translation module is active
- Clear WPML's string translation cache
- Ensure proper language is set
-
For debugging, use WPML's string translation interface to verify:
- String registration status
- Correct context and name
- Translation availability
-
Common Issues:
- Missing string registration
- Incorrect context/name matching
- Cache issues
- WPML configuration problems
https://github.com/getdokan/client-issue/issues/220
Issue Description: Translate vendor dashboard product categories & set category hierarchy for multiple languages.
- (WPML Multilingual CMS, WooCommerce Multilingual & Multicurrency, Dokan - WPML Integration) plugins is required.
(Applicable for versions below v4.7)
- Go to WPML β Settings β Taxonomies Translation β Product categories (product_cat) <<<-------- (set as translatable)
- Go to WooCoomerce β WooCommerce Multilingual & Multicurrency β Categories β Translate all categories β Hierarchy Synchronization β Translate with base language <<<------------ (translate categories with base lang not translated lang)
- Flash the object/transient cache using
Redis object cache
plugin for maintain category hierarchy perfectly. - Go to WoooCommerce Products β Categories <<<------------ (check the order of categories by visiting the translated category page)
- Set it up according to hierarchy, and re-check it in your vendor product edit/add page.
(Applicable for version v4.7 and above)
- Go to WooCoomerce β WooCommerce Multilingual & Multicurrency β Multilingual
- Click on Translate Taxonomy β Select Product Categories (as taxonomy)
- Translate all the Categories in your selected language.
- Click on Hierarchy Synchronization β Update Taxonomy Hierarchy (see the output)
I hope this helps resolve your issue! ππ»