• Resolved charliemcf

    (@charliemcf)


    Firstly, this is a sensational plugin, many congratulations to everyone involved in its development and support!

    Occasionally I need to change the default text to something better suited to my needs. For example on the membership-checkout form I’d like to replace ‘Billing Address’ with ‘Your Details’. This code *seems* to work:

    function my_gettext_billing_address($translated_text, $text, $domain)
    {
    		if($domain == "paid-memberships-pro" && $text == "Billing Address")
    		$translated_text = "Your Details";		//new text here	
    	return $translated_text;
    }
    add_filter('gettext', 'my_gettext_billing_address', 10, 3);

    However I note from another thread that using gettest isn’t recommended for performance reasons. I also wonder if it’s going to break something behind the scenes. So my questions are: is this an acceptable implementation of the filter? If not, is there a better way to use it, or would another strategy (maybe CSS?) be better? All advice very welcome, thanks.

Viewing 4 replies - 1 through 4 (of 4 total)
  • @charliemcf

    Thank you so much for bringing this to our attention. We do strive to keep our translations up-to-date, but as translations are on a volunteer basis from WordPress community members, it is difficult to maintain up-to-date translations. You can check on the status of your locale here: https://translate.www.ads-software.com/projects/wp-plugins/paid-memberships-pro/

    If you’d like to help out with your locale, please reach out to us, and perhaps we can work out an arrangement.

    For incomplete translations, we recommend the plugin Loco Translate. It’s not perfect and doesn’t appear to capture all of our translatable strings, but for the most part it works to correct incomplete or invalid translations.

    https://www.ads-software.com/plugins/loco-translate/

    If a string isn’t translatable by both WordPress and Loco Translate, unfortunately gettext is your best bet.

    The performance reasons you speak of are because every single translatable string gets passed to the filter. A simple text change will not cause that significant of a performance issue, but if there is any logic involved in the gettext filter, then you’ll start noticing a bottleneck/slowdown.

    Something like the Gist below should have a minimal performance impact, although I definitely agree that gettext should be used as a last resort.

    https://gist.github.com/ronalfy/0e4f5fc886af8af20cb75105518470e6

    I hope that helps get you started.

    Regards,

    Ronald Huereca

    Thread Starter charliemcf

    (@charliemcf)

    @ronalfy thanks for your advice, with regard to performance does using the domain ‘paid-memberships-pro’ help to reduce the impact on performance by restricting the filter to a subset of text strings rather than applying it to every string within the entire WordPress installation?

    @charliemcf

    It may, but it’s processing so often, it’s hard to record actual performance losses or gains without going deep in the command line. You can use a plugin like Query Monitor to monitor performance on the server level: https://www.ads-software.com/plugins/query-monitor/

    A good caching plugin/solution should minimize any obvious bottlenecks.

    Regards,

    Ronald Huereca

    Thread Starter charliemcf

    (@charliemcf)

    Got it, many thanks @ronalfy.

Viewing 4 replies - 1 through 4 (of 4 total)
  • The topic ‘Using the gettext filter – legit or not?’ is closed to new replies.