[{"data":1,"prerenderedAt":-1},["ShallowReactive",2],{"$fkc6cQfQYP7d99CSI8wauXAAsZyrmlxBRos2sOUjDLIA":3},{"slug":4,"name":5,"version":6,"author":7,"author_profile":8,"description":9,"short_description":10,"active_installs":11,"downloaded":12,"rating":13,"num_ratings":14,"last_updated":15,"tested_up_to":16,"requires_at_least":17,"requires_php":18,"tags":19,"homepage":25,"download_link":26,"security_score":27,"vuln_count":28,"unpatched_count":28,"last_vuln_date":29,"fetched_at":30,"vulnerabilities":31,"developer":32,"crawl_stats":29,"alternatives":40,"analysis":143,"fingerprints":194},"wp-override-translations","WP Override String Translations","3.0.0","Vincenzo","https:\u002F\u002Fprofiles.wordpress.org\u002Fvluongo\u002F","\u003Cp>Lets you override default texts from your admin panel.\u003Cbr \u002F>\nThe plugin trades both the Woocommerce texts and the well written WordPress core texts and its plugins or widgets.\u003Cbr \u002F>\n\u003Cbr \u002F>\nThe plugin also allows you to replace strings with text composed of HTML.\u003Cbr \u002F>\nIt will translate all _e(”) or __(”) string calls, so check the PHP sourcecode of the plugin or theme you need to translate.\u003Cbr \u002F>\n\u003Cbr \u002F>\nIt will NOT translate any dynamic strings like %s or %d, so “%s has been added to your cart.” is not translatable.\u003C\u002Fp>\n","Thanks to this plugin you can translate all the strings of your portal through the admin panel.",1000,12497,78,7,"2025-10-03T19:34:00.000Z","5.9.13","5.0","7.0",[20,21,22,23,24],"gettext","ngettext","override-translation","string-translations","woocommerce-translate","https:\u002F\u002Fwordpress-plugins.luongovincenzo.it\u002F#wp-override-translations","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fwp-override-translations.zip",100,0,null,"2026-03-15T15:16:48.613Z",[],{"slug":33,"display_name":7,"profile_url":8,"plugin_count":34,"total_installs":35,"avg_security_score":36,"avg_patch_time_days":37,"trust_score":38,"computed_at":39},"vluongo",5,1530,94,30,90,"2026-04-04T14:48:08.658Z",[41,64,85,104,126],{"slug":42,"name":43,"version":44,"author":45,"author_profile":46,"description":47,"short_description":48,"active_installs":49,"downloaded":50,"rating":36,"num_ratings":37,"last_updated":51,"tested_up_to":52,"requires_at_least":53,"requires_php":54,"tags":55,"homepage":60,"download_link":61,"security_score":27,"vuln_count":62,"unpatched_count":28,"last_vuln_date":63,"fetched_at":30},"simple-yearly-archive","Simple Yearly Archive","2.2.4","wpseek","https:\u002F\u002Fprofiles.wordpress.org\u002Falphawolf\u002F","\u003Cp>Simple Yearly Archive is a rather neat and simple WordPress plugin that allows you to \u003Cstrong>display your archives in a year-based list\u003C\u002Fstrong>. It works mostly like the usual WP archive, but displays all published posts seperated by their year of publication. That said, it’s also possible to restrict the output to certain categories, and much more.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>See \u003Ca href=\"https:\u002F\u002Fwww.schloebe.de\u002Fwordpress\u002Fsimple-yearly-archive-plugin\u002F#tabwidget-27592\" title=\"Usage\" rel=\"nofollow ugc\">Usage\u003C\u002Fa> for examples, available parameters and more.\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Included languages:\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cul>\n\u003Cli>English\u003C\u002Fli>\n\u003Cli>German (de_DE) (Thanks to me ;-))\u003C\u002Fli>\n\u003Cli>German (de_DE_formal) (Thanks for contributing formal german language goes to \u003Ca href=\"https:\u002F\u002Fgithub.com\u002Fpavog\" rel=\"nofollow ugc\">Paul Vogel\u003C\u002Fa>)\u003C\u002Fli>\n\u003Cli>Italian (it_IT) (Thanks for contributing italian language goes to \u003Ca href=\"https:\u002F\u002Fgidibao.net\" rel=\"nofollow ugc\">Gianni Diurno\u003C\u002Fa>)\u003C\u002Fli>\n\u003Cli>Russian (ru_RU) (Thanks for contributing russian language goes to \u003Ca href=\"https:\u002F\u002Fgrugl.me\" rel=\"nofollow ugc\">Dimitry German\u003C\u002Fa>)\u003C\u002Fli>\n\u003Cli>Belorussian (by_BY) (Thanks for contributing belorussian language goes to \u003Ca href=\"https:\u002F\u002Fwww.fatcow.com\" rel=\"nofollow ugc\">Marcis Gasuns\u003C\u002Fa>)\u003C\u002Fli>\n\u003Cli>Uzbek (uz_UZ) (Thanks for contributing uzbek language goes to \u003Ca href=\"https:\u002F\u002Fwww.comfi.com\" rel=\"nofollow ugc\">Alexandra Bolshova\u003C\u002Fa>)\u003C\u002Fli>\n\u003Cli>French (fr_FR) (Thanks for contributing french language goes to \u003Ca href=\"https:\u002F\u002Fwww.li-an.fr\u002Fblog\" rel=\"nofollow ugc\">Jean-Michel Meyer\u003C\u002Fa>)\u003C\u002Fli>\n\u003Cli>Chinese (zh_CN) (Thanks for contributing chinese language goes to \u003Ca href=\"https:\u002F\u002Fmarianama.net\" rel=\"nofollow ugc\">Mariana Ma\u003C\u002Fa>)\u003C\u002Fli>\n\u003Cli>Japanese (ja) (Thanks for contributing japanese language goes to \u003Ca href=\"https:\u002F\u002Fstaff.blog.bng.net\" rel=\"nofollow ugc\">Chestnut\u003C\u002Fa>)\u003C\u002Fli>\n\u003Cli>Portuguese Brazil (pt_BR) (Thanks for contributing portuguese brazil language goes to LucasTolle)\u003C\u002Fli>\n\u003Cli>Dutch (nl_NL) (Thanks for contributing dutch language goes to Bart Verkerk)\u003C\u002Fli>\n\u003Cli>Spanish (es) (Spanish translation by \u003Ca href=\"https:\u002F\u002Fwww.ibidemgroup.com\" rel=\"nofollow ugc\">Ibidem Group\u003C\u002Fa>)\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>\u003Ca href=\"https:\u002F\u002Fwww.schloebe.de\u002Farchiv\u002F\" title=\"Click here for a demo\" rel=\"nofollow ugc\">Click here for a demo\u003C\u002Fa>\u003C\u002Fp>\n\u003Cp>\u003Ca href=\"https:\u002F\u002Fx.com\u002Fwpseek\" title=\"Developer on X\" rel=\"nofollow ugc\">Developer on X\u003C\u002Fa> \u003Ca href=\"https:\u002F\u002Fbsky.app\u002Fprofile\u002Fcyberblitzbirne.bsky.social\" title=\"Developer on Bluesky\" rel=\"nofollow ugc\">Developer on Bluesky\u003C\u002Fa>\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Looking for more WordPress plugins? Visit \u003Ca href=\"https:\u002F\u002Fwww.schloebe.de\u002Fportfolio\u002F\" rel=\"nofollow ugc\">www.schloebe.de\u002Fportfolio\u002F\u003C\u002Fa>\u003C\u002Fstrong>\u003C\u002Fp>\n","Simple Yearly Archive is a rather neat and simple Wordpress plugin that allows you to display your archives in a year-based list.",6000,188503,"2026-02-15T14:05:00.000Z","6.9.99","3.7","",[56,57,20,58,59],"archive","archives","wpml","wp_query","https:\u002F\u002Fwww.schloebe.de\u002Fwordpress\u002Fsimple-yearly-archive-plugin\u002F","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fsimple-yearly-archive.zip",1,"2023-02-13 00:00:00",{"slug":65,"name":66,"version":67,"author":68,"author_profile":69,"description":70,"short_description":71,"active_installs":72,"downloaded":73,"rating":27,"num_ratings":14,"last_updated":74,"tested_up_to":75,"requires_at_least":76,"requires_php":54,"tags":77,"homepage":54,"download_link":82,"security_score":83,"vuln_count":62,"unpatched_count":28,"last_vuln_date":84,"fetched_at":30},"gettext-override-translations","Gettext override translations","2.0.2","ramon fincken","https:\u002F\u002Fprofiles.wordpress.org\u002Framon-fincken\u002F","\u003Cp>Lets you override default texts from your admin panel.\u003Cbr \u002F>\nOriginally built to override texts from Woocommerce, but also works for all neatly added texts by WordPress Core and plugins.\u003Cbr \u002F>\n\u003Cbr \u002F>\nIt will translate all _e(”) or __(”) string calls, so check the PHP sourcecode of the plugin or theme you need to translate.\u003Cbr \u002F>\n\u003Cbr \u002F>\nIt will NOT translate any dynamic strings like %s or %d, so “%s has been added to your cart.” is not translatable.\u003Cbr \u002F>\n\u003Cbr \u002F>\nIt will NOT translate any strings that contain HTML tags at all.\u003Cbr \u002F>\n\u003Cbr \u002F>\nSome WooCommerce examples:\u003Cbr \u002F>\nWooCommerce “Select option” (dropdown value) setting\u003Cbr \u002F>\n\u003Ca href=\"https:\u002F\u002Fs.w.org\u002Fextend\u002Fplugins\u002Fgettext-override-translations\u002Fscreenshot-3.png\" rel=\"nofollow ugc\">Fullscreen Screenshot 3\u003C\u002Fa>\u003Cbr \u002F>\nWooCommerce “Select option” (dropdown value) translation result\u003Cbr \u002F>\n\u003Ca href=\"https:\u002F\u002Fs.w.org\u002Fextend\u002Fplugins\u002Fgettext-override-translations\u002Fscreenshot-4.png\" rel=\"nofollow ugc\">Fullscreen Screenshot 4\u003C\u002Fa>\u003Cbr \u002F>\nWooCommerce “Order notes” setting\u003Cbr \u002F>\n\u003Ca href=\"https:\u002F\u002Fs.w.org\u002Fextend\u002Fplugins\u002Fgettext-override-translations\u002Fscreenshot-5.png\" rel=\"nofollow ugc\">Fullscreen Screenshot 5\u003C\u002Fa>\u003Cbr \u002F>\nWooCommerce “Order notes” translation result\u003Cbr \u002F>\n\u003Ca href=\"https:\u002F\u002Fs.w.org\u002Fextend\u002Fplugins\u002Fgettext-override-translations\u002Fscreenshot-6.png\" rel=\"nofollow ugc\">Fullscreen Screenshot 6\u003C\u002Fa>\u003C\u002Fp>\n\u003Cp>Coding by: \u003Ca href=\"https:\u002F\u002Fwww.mijnpress.nl\" rel=\"nofollow ugc\">MijnPress.nl\u003C\u002Fa> \u003Ca href=\"https:\u002F\u002Ftwitter.com\u002F#!\u002Framonfincken\" rel=\"nofollow ugc\">Twitter profile\u003C\u002Fa> \u003Ca href=\"https:\u002F\u002Fprofiles.wordpress.org\u002Framon-fincken\u002F\" rel=\"nofollow ugc\">More plugins\u003C\u002Fa>\u003C\u002Fp>\n","GUI in backend to override texts and translations without any programming knowledge.",2000,24578,"2024-05-27T07:09:00.000Z","6.5.8","4.0",[20,78,79,80,81],"override","text","translation","translations","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fgettext-override-translations.2.0.2.zip",92,"2022-08-29 00:00:00",{"slug":86,"name":87,"version":88,"author":89,"author_profile":90,"description":91,"short_description":92,"active_installs":27,"downloaded":93,"rating":27,"num_ratings":94,"last_updated":54,"tested_up_to":95,"requires_at_least":96,"requires_php":54,"tags":97,"homepage":101,"download_link":102,"security_score":27,"vuln_count":28,"unpatched_count":28,"last_vuln_date":29,"fetched_at":103},"speed-up-translation","Speed Up – Translation Cache","1.0.19","nigro.simone","https:\u002F\u002Fprofiles.wordpress.org\u002Fnigrosimone\u002F","\u003Cp>The translations reduces speed of WordPress.\u003C\u002Fp>\n\u003Cp>For localized WordPress the loading time of translation files accounts for 30% of the entire processing time (less or more 40 milliseconds per page).\u003C\u002Fp>\n\u003Cp>For each translation file, WordPress unpacks it and then everyone will be converted in an “Translation_Entry” object. This process, repeated at each page view, is a waste time and resource.\u003C\u002Fp>\n\u003Cp>You can make this process 3 times faster by just installing this plugin. This plugin offers a caching solution using the WordPress standard cache mechanism that reduces this effects on performance.\u003C\u002Fp>\n\u003Cp>Configurations are not required! You just have to install it and after the plugin does it all, none further action it’s required.\u003C\u002Fp>\n\u003Cp>This plugin is very light: only 5 kB.\u003C\u002Fp>\n\u003Ch3>Features\u003C\u002Fh3>\n\u003Cul>\n\u003Cli>No configuration\u003C\u002Fli>\n\u003Cli>Supports multiple languages\u003C\u002Fli>\n\u003Cli>Supports plugin’s translation files caching\u003C\u002Fli>\n\u003Cli>Supports WordPress Network\u002FMultisite installation\u003C\u002Fli>\n\u003Cli>Cache automatically expire when translation file is updated\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>Recommended Installation\u003C\u002Fh3>\n\u003Cp>For better performance, verify that \u003Ccode>\u002Fwp-content\u002Fobject-cache.php\u003C\u002Fcode> is installed (see https:\u002F\u002Fcodex.wordpress.org\u002FClass_Reference\u002FWP_Object_Cache#Persistent_Cache_Plugins).\u003C\u002Fp>\n","The translations reduces speed of Wordpress. This plugin offers a caching solution that reduces this effects on performance.",11456,2,"6.0.11","3.0",[98,20,99,100,80],"fast","performance","speed","http:\u002F\u002Fwordpress.org\u002Fplugins\u002Fspeed-up-translation\u002F","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fspeed-up-translation.1.0.19.zip","2026-03-15T10:48:56.248Z",{"slug":105,"name":106,"version":107,"author":108,"author_profile":109,"description":110,"short_description":111,"active_installs":112,"downloaded":113,"rating":27,"num_ratings":114,"last_updated":115,"tested_up_to":116,"requires_at_least":117,"requires_php":118,"tags":119,"homepage":124,"download_link":125,"security_score":27,"vuln_count":28,"unpatched_count":28,"last_vuln_date":29,"fetched_at":30},"easy-text-replace","Text Replace – Find and Replace WordPress Strings","1.0.5","SH Sajal Chowdhury","https:\u002F\u002Fprofiles.wordpress.org\u002Fshsajalchowdhury\u002F","\u003Cp>\u003Cstrong>Text Replace\u003C\u002Fstrong> is a lightweight, performance-optimized WordPress plugin that lets you find and replace any text string on your website without modifying theme or plugin files. Perfect for customizing WooCommerce buttons, changing form labels, or personalizing any text across your site.\u003C\u002Fp>\n\u003Ch4>Why Choose Text Replace?\u003C\u002Fh4>\n\u003Cul>\n\u003Cli>\u003Cstrong>No Code Editing Required\u003C\u002Fstrong> – Find and replace text without touching theme or plugin files\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Update-Safe\u003C\u002Fstrong> – Your string replacements survive theme and plugin updates\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Performance Optimized\u003C\u002Fstrong> – Single database query per page load with intelligent caching\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Text Domain Filtering\u003C\u002Fstrong> – Target specific plugins, themes, or apply changes globally\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Priority Control\u003C\u002Fstrong> – Manage the order of multiple text replacements\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Bulk Operations\u003C\u002Fstrong> – Enable, disable, or delete multiple replacements at once\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Import\u002FExport\u003C\u002Fstrong> – Transfer configurations between sites easily\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Cache Compatible\u003C\u002Fstrong> – Works with WP Rocket, W3 Total Cache, WP Super Cache, and more\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Perfect For\u003C\u002Fh4>\n\u003Cul>\n\u003Cli>Changing WooCommerce “Add to Cart” to “Buy Now”\u003C\u002Fli>\n\u003Cli>Customizing Contact Form 7 button labels\u003C\u002Fli>\n\u003Cli>Replacing WordPress admin bar text\u003C\u002Fli>\n\u003Cli>Modifying theme-specific strings\u003C\u002Fli>\n\u003Cli>Personalizing plugin messages\u003C\u002Fli>\n\u003Cli>Translating or localizing specific phrases\u003C\u002Fli>\n\u003Cli>A\u002FB testing different button labels\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>Key Features\u003C\u002Fh4>\n\u003Cp>\u003Cstrong>Simple String Replacement\u003C\u002Fstrong>\u003Cbr \u002F>\nFind and replace any text from themes, plugins, or WordPress core with just a few clicks. No coding knowledge required.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Text Domain Filtering\u003C\u002Fstrong>\u003Cbr \u002F>\nTarget specific plugins or themes by their text domain, or apply replacements globally across your entire site. This prevents unintended replacements in other plugins.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Case Sensitivity Control\u003C\u002Fstrong>\u003Cbr \u002F>\nChoose whether replacements should match exact case or be case-insensitive for maximum flexibility.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Priority Ordering\u003C\u002Fstrong>\u003Cbr \u002F>\nControl the order in which replacements are applied using priority numbers (1-999). Lower numbers apply first.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Enable\u002FDisable Toggle\u003C\u002Fstrong>\u003Cbr \u002F>\nQuickly activate or deactivate replacements without deleting them. Perfect for testing and seasonal changes.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Bulk Operations\u003C\u002Fstrong>\u003Cbr \u002F>\nSelect multiple replacements and enable, disable, or delete them all at once to save time.\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Import\u002FExport\u003C\u002Fstrong>\u003Cbr \u002F>\nExport your replacement configurations to JSON files for backup or transfer to other sites. Import with automatic duplicate detection.\u003C\u002Fp>\n\u003Ch3>Performance Optimized\u003C\u002Fh3>\n\u003Cul>\n\u003Cli>Single database query per page load\u003C\u002Fli>\n\u003Cli>Intelligent 24-hour caching system\u003C\u002Fli>\n\u003Cli>Lazy loading of admin assets\u003C\u002Fli>\n\u003Cli>No frontend JavaScript overhead\u003C\u002Fli>\n\u003Cli>Indexed database for fast queries\u003C\u002Fli>\n\u003Cli>Unlimited replacements with optimized performance\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>WordPress Native UI\u003C\u002Fh3>\n\u003Cp>Clean, intuitive interface using WordPress design patterns. Feels like a natural part of WordPress.\u003C\u002Fp>\n\u003Ch3>Search & Sort\u003C\u002Fh3>\n\u003Cp>Easily find and organize your text replacements with built-in search and sorting capabilities.\u003C\u002Fp>\n\u003Ch4>Use Cases\u003C\u002Fh4>\n\u003Ch3>WooCommerce Text Customization\u003C\u002Fh3>\n\u003Cul>\n\u003Cli>Change “Add to Cart” to “Add to Bag” or “Buy Now”\u003C\u002Fli>\n\u003Cli>Modify “Proceed to Checkout” to “Complete Purchase”\u003C\u002Fli>\n\u003Cli>Customize product page labels\u003C\u002Fli>\n\u003Cli>Personalize shipping and payment text\u003C\u002Fli>\n\u003Cli>Replace price labels and currency text\u003C\u002Fli>\n\u003Cli>Modify sale badge text\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>Contact Form 7 Customization\u003C\u002Fh3>\n\u003Cul>\n\u003Cli>Change submit button text\u003C\u002Fli>\n\u003Cli>Modify form field labels\u003C\u002Fli>\n\u003Cli>Customize validation messages\u003C\u002Fli>\n\u003Cli>Personalize success messages\u003C\u002Fli>\n\u003Cli>Replace error message text\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>WordPress Core Text Replacement\u003C\u002Fh3>\n\u003Cul>\n\u003Cli>Replace “Howdy” in admin bar\u003C\u002Fli>\n\u003Cli>Change “Dashboard” to “Control Panel”\u003C\u002Fli>\n\u003Cli>Modify menu labels\u003C\u002Fli>\n\u003Cli>Customize admin notices\u003C\u002Fli>\n\u003Cli>Replace login page text\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch3>Theme Text Customization\u003C\u002Fh3>\n\u003Cul>\n\u003Cli>Change “Read More” links\u003C\u002Fli>\n\u003Cli>Modify navigation labels\u003C\u002Fli>\n\u003Cli>Customize footer text\u003C\u002Fli>\n\u003Cli>Personalize call-to-action buttons\u003C\u002Fli>\n\u003Cli>Replace copyright text\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Ch4>How It Works\u003C\u002Fh4>\n\u003Cp>Text Replace hooks into WordPress’s translation system (gettext) to intercept and replace text strings before they’re displayed. This means:\u003C\u002Fp>\n\u003Col>\n\u003Cli>\u003Cstrong>No file modifications\u003C\u002Fstrong> – Your theme and plugin files remain untouched\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Update-safe\u003C\u002Fstrong> – String replacements persist through updates\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Reversible\u003C\u002Fstrong> – Simply disable or delete replacements to restore original text\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Efficient\u003C\u002Fstrong> – Replacements are cached for optimal performance\u003C\u002Fli>\n\u003C\u002Fol>\n\u003Ch3>How to Change WooCommerce “Add to Cart” Text\u003C\u002Fh3>\n\u003Cp>One of the most common uses for Text Replace is customizing WooCommerce button text. Here’s how:\u003C\u002Fp>\n\u003Col>\n\u003Cli>Navigate to \u003Cstrong>Text Replace > Add New\u003C\u002Fstrong> in your WordPress admin\u003C\u002Fli>\n\u003Cli>In the \u003Cstrong>Source String\u003C\u002Fstrong> field, enter: \u003Ccode>Add to cart\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>In the \u003Cstrong>Replacement String\u003C\u002Fstrong> field, enter your desired text (e.g., \u003Ccode>Buy Now\u003C\u002Fcode>)\u003C\u002Fli>\n\u003Cli>In the \u003Cstrong>Text Domain\u003C\u002Fstrong> field, enter: \u003Ccode>woocommerce\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>Leave \u003Cstrong>Case Sensitive\u003C\u002Fstrong> unchecked (default)\u003C\u002Fli>\n\u003Cli>Set \u003Cstrong>Priority\u003C\u002Fstrong> to 10 (default)\u003C\u002Fli>\n\u003Cli>Make sure status is set to \u003Cstrong>Active\u003C\u002Fstrong>\u003C\u002Fli>\n\u003Cli>Click \u003Cstrong>Save Replacement\u003C\u002Fstrong>\u003C\u002Fli>\n\u003Cli>Clear your site cache if using a caching plugin\u003C\u002Fli>\n\u003Cli>Visit a WooCommerce product page to see the change\u003C\u002Fli>\n\u003C\u002Fol>\n\u003Cp>\u003Cstrong>Pro Tip:\u003C\u002Fstrong> To change “Add to cart” on single products but keep it on shop\u002Farchive pages, you’ll need to target the specific string used in that context. Check WooCommerce source code or use browser inspect to find the exact string.\u003C\u002Fp>\n\u003Ch3>How to Replace Contact Form 7 Button Labels\u003C\u002Fh3>\n\u003Cp>Customize Contact Form 7 submit buttons without editing form code:\u003C\u002Fp>\n\u003Col>\n\u003Cli>Go to \u003Cstrong>Text Replace > Add New\u003C\u002Fstrong>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Source String\u003C\u002Fstrong>: \u003Ccode>Send\u003C\u002Fcode> (or your current button text)\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Replacement String\u003C\u002Fstrong>: Your desired button text (e.g., \u003Ccode>Submit Message\u003C\u002Fcode>)\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Text Domain\u003C\u002Fstrong>: \u003Ccode>contact-form-7\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>Status: \u003Cstrong>Active\u003C\u002Fstrong>\u003C\u002Fli>\n\u003Cli>Click \u003Cstrong>Save Replacement\u003C\u002Fstrong>\u003C\u002Fli>\n\u003Cli>Clear cache and test your contact form\u003C\u002Fli>\n\u003C\u002Fol>\n\u003Cp>\u003Cstrong>Note:\u003C\u002Fstrong> If you have multiple forms with different button text, create separate replacements for each or leave Text Domain empty to replace globally.\u003C\u002Fp>\n\u003Ch3>How to Customize Theme Text Without Editing Files\u003C\u002Fh3>\n\u003Cp>Replace any theme text without touching template files:\u003C\u002Fp>\n\u003Col>\n\u003Cli>First, identify the exact text you want to replace (copy it exactly as it appears)\u003C\u002Fli>\n\u003Cli>Navigate to \u003Cstrong>Text Replace > Add New\u003C\u002Fstrong>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Source String\u003C\u002Fstrong>: The exact theme text (e.g., \u003Ccode>Read More\u003C\u002Fcode>)\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Replacement String\u003C\u002Fstrong>: Your new text (e.g., \u003Ccode>Continue Reading\u003C\u002Fcode>)\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Text Domain\u003C\u002Fstrong>: Leave empty for global replacement, or enter your theme’s text domain\u003C\u002Fli>\n\u003Cli>Enable \u003Cstrong>Case Sensitive\u003C\u002Fstrong> if exact capitalization matters\u003C\u002Fli>\n\u003Cli>Status: \u003Cstrong>Active\u003C\u002Fstrong>\u003C\u002Fli>\n\u003Cli>Save and clear cache\u003C\u002Fli>\n\u003C\u002Fol>\n\u003Cp>\u003Cstrong>Finding Your Theme’s Text Domain:\u003C\u002Fstrong> Check your theme’s style.css file header for the “Text Domain” field.\u003C\u002Fp>\n\u003Ch3>How to Find Text Domain for Any Plugin\u003C\u002Fh3>\n\u003Cp>To target a specific plugin with text replacement, you need its text domain:\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Method 1: Check Plugin Main File\u003C\u002Fstrong>\u003Cbr \u002F>\n1. Go to Plugins > Plugin File Editor\u003Cbr \u002F>\n2. Select the plugin from dropdown\u003Cbr \u002F>\n3. Look for \u003Ccode>Text Domain:\u003C\u002Fcode> in the file header at the top\u003Cbr \u002F>\n4. Copy the text domain value\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Method 2: Check Translation Files\u003C\u002Fstrong>\u003Cbr \u002F>\n1. Navigate to \u003Ccode>\u002Fwp-content\u002Fplugins\u002F[plugin-name]\u002Flanguages\u002F\u003C\u002Fcode>\u003Cbr \u002F>\n2. Look for .po or .pot files\u003Cbr \u002F>\n3. The filename usually contains the text domain (e.g., \u003Ccode>woocommerce-en_US.po\u003C\u002Fcode> = text domain is \u003Ccode>woocommerce\u003C\u002Fcode>)\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Method 3: Common Plugin Text Domains\u003C\u002Fstrong>\u003Cbr \u002F>\n* WooCommerce: \u003Ccode>woocommerce\u003C\u002Fcode>\u003Cbr \u002F>\n* Contact Form 7: \u003Ccode>contact-form-7\u003C\u002Fcode>\u003Cbr \u002F>\n* Yoast SEO: \u003Ccode>wordpress-seo\u003C\u002Fcode>\u003Cbr \u002F>\n* Elementor: \u003Ccode>elementor\u003C\u002Fcode>\u003Cbr \u002F>\n* Advanced Custom Fields: \u003Ccode>acf\u003C\u002Fcode>\u003Cbr \u002F>\n* Gravity Forms: \u003Ccode>gravityforms\u003C\u002Fcode>\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Pro Tip:\u003C\u002Fstrong> If you can’t find the text domain, leave it blank to replace the text globally across your entire site.\u003C\u002Fp>\n\u003Ch3>How to Set Up Multiple Text Replacements\u003C\u002Fh3>\n\u003Cp>When you need to replace several strings, use priority to control the order:\u003C\u002Fp>\n\u003Col>\n\u003Cli>\u003Cstrong>Plan your replacements\u003C\u002Fstrong> – List all the text you want to change\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Create each replacement\u003C\u002Fstrong> – Go to Text Replace > Add New for each one\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Set priorities:\u003C\u002Fstrong>\n\u003Cul>\n\u003Cli>Use priority 10 for most replacements (default)\u003C\u002Fli>\n\u003Cli>Use lower numbers (1-9) for replacements that should happen first\u003C\u002Fli>\n\u003Cli>Use higher numbers (11-99) for replacements that depend on others\u003C\u002Fli>\n\u003C\u002Ful>\n\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Use Text Domain filtering\u003C\u002Fstrong> – Specify text domain to avoid conflicts\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Test in stages\u003C\u002Fstrong> – Enable a few at a time to verify they work correctly\u003C\u002Fli>\n\u003C\u002Fol>\n\u003Cp>\u003Cstrong>Example Priority Setup:\u003C\u002Fstrong>\u003Cbr \u002F>\n* Priority 5: Replace “product” with “item” (happens first)\u003Cbr \u002F>\n* Priority 10: Replace “Add to cart” with “Buy Now” (normal priority)\u003Cbr \u002F>\n* Priority 15: Replace “item price” with “cost” (happens after priority 5 and 10)\u003C\u002Fp>\n\u003Ch3>How to Replace Text Site-Wide vs Plugin-Specific\u003C\u002Fh3>\n\u003Cp>Control where your text replacements apply:\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Site-Wide Replacement (Global):\u003C\u002Fstrong>\u003Cbr \u002F>\n1. Create your replacement as normal\u003Cbr \u002F>\n2. \u003Cstrong>Leave Text Domain field EMPTY\u003C\u002Fstrong>\u003Cbr \u002F>\n3. This will replace the text everywhere it appears on your site\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Plugin-Specific Replacement:\u003C\u002Fstrong>\u003Cbr \u002F>\n1. Create your replacement\u003Cbr \u002F>\n2. \u003Cstrong>Enter the plugin’s text domain\u003C\u002Fstrong> (e.g., \u003Ccode>woocommerce\u003C\u002Fcode>)\u003Cbr \u002F>\n3. Text will ONLY be replaced when generated by that specific plugin\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Theme-Specific Replacement:\u003C\u002Fstrong>\u003Cbr \u002F>\n1. Find your theme’s text domain (check style.css)\u003Cbr \u002F>\n2. Enter the theme text domain in the Text Domain field\u003Cbr \u002F>\n3. Text will ONLY be replaced in theme-generated content\u003C\u002Fp>\n\u003Cp>\u003Cstrong>When to Use Each:\u003C\u002Fstrong>\u003Cbr \u002F>\n* \u003Cstrong>Global (empty text domain):\u003C\u002Fstrong> When you want to replace text regardless of source\u003Cbr \u002F>\n* \u003Cstrong>Plugin-specific:\u003C\u002Fstrong> When text appears in multiple places but you only want to change it in one plugin\u003Cbr \u002F>\n* \u003Cstrong>Theme-specific:\u003C\u002Fstrong> When replacing navigation, headers, footers, or theme-specific UI text\u003C\u002Fp>\n\u003Ch3>How to Test Text Replacements Without Affecting Live Site\u003C\u002Fh3>\n\u003Cp>Test your replacements safely before going live:\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Method 1: Use Enable\u002FDisable Toggle\u003C\u002Fstrong>\u003Cbr \u002F>\n1. Create your replacement with status \u003Cstrong>Inactive\u003C\u002Fstrong>\u003Cbr \u002F>\n2. Save the replacement\u003Cbr \u002F>\n3. Log out and view your site in an incognito window\u003Cbr \u002F>\n4. Log back in and toggle to \u003Cstrong>Active\u003C\u002Fstrong> when ready\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Method 2: Test on Staging Site\u003C\u002Fstrong>\u003Cbr \u002F>\n1. Create replacements on your staging site\u003Cbr \u002F>\n2. Test thoroughly\u003Cbr \u002F>\n3. Export via \u003Cstrong>Text Replace > Import\u002FExport\u003C\u002Fstrong>\u003Cbr \u002F>\n4. Import the JSON file on your live site\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Method 3: Use Priority to Test Incrementally\u003C\u002Fstrong>\u003Cbr \u002F>\n1. Set test replacements to high priority (90-99)\u003Cbr \u002F>\n2. This makes them easy to identify and remove\u003Cbr \u002F>\n3. Once tested, adjust priority to normal (10)\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Pro Tip:\u003C\u002Fstrong> Always clear your cache after making changes, then test in an incognito\u002Fprivate browser window to see changes immediately.\u003C\u002Fp>\n\u003Ch3>How to Export and Import Text Replacements\u003C\u002Fh3>\n\u003Cp>Transfer your text replacements between sites easily:\u003C\u002Fp>\n\u003Cp>\u003Cstrong>To Export:\u003C\u002Fstrong>\u003Cbr \u002F>\n1. Go to \u003Cstrong>Text Replace > Import\u002FExport\u003C\u002Fstrong>\u003Cbr \u002F>\n2. Click \u003Cstrong>Export All Replacements\u003C\u002Fstrong>\u003Cbr \u002F>\n3. A JSON file will download to your computer\u003Cbr \u002F>\n4. This file contains all your active and inactive replacements\u003C\u002Fp>\n\u003Cp>\u003Cstrong>To Import:\u003C\u002Fstrong>\u003Cbr \u002F>\n1. Go to \u003Cstrong>Text Replace > Import\u002FExport\u003C\u002Fstrong> on the destination site\u003Cbr \u002F>\n2. Click \u003Cstrong>Choose File\u003C\u002Fstrong> and select your exported JSON file\u003Cbr \u002F>\n3. Click \u003Cstrong>Import\u003C\u002Fstrong>\u003Cbr \u002F>\n4. The plugin will automatically detect and skip duplicates\u003Cbr \u002F>\n5. New replacements will be imported with all settings intact\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Use Cases for Import\u002FExport:\u003C\u002Fstrong>\u003Cbr \u002F>\n* Transfer replacements from staging to production\u003Cbr \u002F>\n* Backup your replacements before major updates\u003Cbr \u002F>\n* Share replacement configurations between multiple sites\u003Cbr \u002F>\n* Migrate from one server to another\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Pro Tip:\u003C\u002Fstrong> Export your replacements monthly as a backup. Store the JSON file in your site backups.\u003C\u002Fp>\n\u003Ch3>How to Find and Replace Text in WooCommerce Emails\u003C\u002Fh3>\n\u003Cp>Customize WooCommerce email text without editing templates:\u003C\u002Fp>\n\u003Col>\n\u003Cli>Identify the exact text in the email you want to change\u003C\u002Fli>\n\u003Cli>Go to \u003Cstrong>Text Replace > Add New\u003C\u002Fstrong>\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Source String\u003C\u002Fstrong>: The email text (e.g., \u003Ccode>Thank you for your order\u003C\u002Fcode>)\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Replacement String\u003C\u002Fstrong>: Your custom text (e.g., \u003Ccode>Thanks for shopping with us!\u003C\u002Fcode>)\u003C\u002Fli>\n\u003Cli>\u003Cstrong>Text Domain\u003C\u002Fstrong>: \u003Ccode>woocommerce\u003C\u002Fcode>\u003C\u002Fli>\n\u003Cli>Status: \u003Cstrong>Active\u003C\u002Fstrong>\u003C\u002Fli>\n\u003Cli>Save and send a test email\u003C\u002Fli>\n\u003C\u002Fol>\n\u003Cp>\u003Cstrong>Common WooCommerce Email Strings:\u003C\u002Fstrong>\u003Cbr \u002F>\n* “Order received” \u003Cspan aria-hidden=\"true\" class=\"wp-exclude-emoji\">→\u003C\u002Fspan> Your custom text\u003Cbr \u002F>\n* “Payment method” \u003Cspan aria-hidden=\"true\" class=\"wp-exclude-emoji\">→\u003C\u002Fspan> Your custom text\u003Cbr \u002F>\n* “Billing address” \u003Cspan aria-hidden=\"true\" class=\"wp-exclude-emoji\">→\u003C\u002Fspan> Your custom text\u003Cbr \u002F>\n* “Order details” \u003Cspan aria-hidden=\"true\" class=\"wp-exclude-emoji\">→\u003C\u002Fspan> Your custom text\u003C\u002Fp>\n\u003Cp>\u003Cstrong>Testing:\u003C\u002Fstrong> Use WooCommerce > Settings > Emails > Send test email to verify changes.\u003C\u002Fp>\n\u003Ch4>Developer Friendly\u003C\u002Fh4>\n\u003Cp>Includes hooks and filters for developers:\u003C\u002Fp>\n\u003Cul>\n\u003Cli>\u003Ccode>etrp_replacement_text\u003C\u002Fcode> – Filter text before replacement\u003C\u002Fli>\n\u003Cli>\u003Ccode>etrp_replacement_result\u003C\u002Fcode> – Filter text after replacement\u003C\u002Fli>\n\u003Cli>\u003Ccode>etrp_active_replacements\u003C\u002Fcode> – Modify active replacements array\u003C\u002Fli>\n\u003Cli>\u003Ccode>etrp_max_replacements\u003C\u002Fcode> – Adjust maximum replacement limit (default: unlimited)\u003C\u002Fli>\n\u003Cli>\u003Ccode>etrp_before_replacement_apply\u003C\u002Fcode> – Action before replacement\u003C\u002Fli>\n\u003Cli>\u003Ccode>etrp_after_replacement_apply\u003C\u002Fcode> – Action after replacement\u003C\u002Fli>\n\u003C\u002Ful>\n\u003Cp>\u003Cstrong>Example: Programmatically Add Replacement\u003C\u002Fstrong>\u003C\u002Fp>\n\u003Cpre>\u003Ccode>`php\n\u003C\u002Fcode>\u003C\u002Fpre>\n\u003Cp>add_filter(‘etrp_active_replacements’, function($replacements) {\u003Cbr \u002F>\n    $replacements[] = array(\u003Cbr \u002F>\n        ‘source’ => ‘Add to cart’,\u003Cbr \u002F>\n        ‘replacement’ => ‘Buy Now’,\u003Cbr \u002F>\n        ‘text_domain’ => ‘woocommerce’,\u003Cbr \u002F>\n        ‘case_sensitive’ => false,\u003Cbr \u002F>\n        ‘priority’ => 10\u003Cbr \u002F>\n    );\u003Cbr \u002F>\n    return $replacements;\u003Cbr \u002F>\n});\u003Cbr \u002F>\n    `\u003C\u002Fp>\n\u003Ch4>Support\u003C\u002Fh4>\n\u003Cp>Need help? Visit our \u003Ca href=\"https:\u002F\u002Fwordpress.org\u002Fsupport\u002Fplugin\u002Feasy-text-replace\u002F\" rel=\"ugc\">support forum\u003C\u002Fa> for assistance.\u003C\u002Fp>\n\u003Ch3>Privacy Policy\u003C\u002Fh3>\n\u003Cp>Text Replace does not collect, store, or transmit any personal data. All replacement configurations are stored locally in your WordPress database.\u003C\u002Fp>\n\u003Ch3>Credits\u003C\u002Fh3>\n\u003Cp>Developed with ❤️ for the WordPress community.\u003C\u002Fp>\n\u003Ch3>Support\u003C\u002Fh3>\n\u003Cp>For bug reports, feature requests, and support, please visit:\u003Cbr \u002F>\n\u003Ca href=\"https:\u002F\u002Fwordpress.org\u002Fsupport\u002Fplugin\u002Feasy-text-replace\u002F\" rel=\"ugc\">Support Forum\u003C\u002Fa>\u003C\u002Fp>\n\u003Ch3>Translations\u003C\u002Fh3>\n\u003Cp>Text Replace is translation-ready and includes:\u003Cbr \u002F>\nEnglish (default)\u003C\u002Fp>\n\u003Cp>Want to translate Text Replace into your language? Visit \u003Ca href=\"https:\u002F\u002Ftranslate.wordpress.org\u002Fprojects\u002Fwp-plugins\u002Feasy-text-replace\u002F\" rel=\"nofollow ugc\">WordPress Translate\u003C\u002Fa>.\u003C\u002Fp>\n","Find and replace any WordPress text without coding. Change WooCommerce buttons, form labels, and theme text. Update-safe and cached.",50,554,3,"2026-03-01T05:06:00.000Z","6.9.4","5.8","7.4",[120,20,121,122,123],"find-and-replace","string-replacement","text-replace","woocommerce","https:\u002F\u002Fwordpress.org\u002Fplugins\u002Feasy-text-replace\u002F","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Feasy-text-replace.1.0.5.zip",{"slug":127,"name":128,"version":129,"author":130,"author_profile":131,"description":132,"short_description":133,"active_installs":134,"downloaded":135,"rating":27,"num_ratings":114,"last_updated":136,"tested_up_to":137,"requires_at_least":138,"requires_php":139,"tags":140,"homepage":141,"download_link":142,"security_score":83,"vuln_count":28,"unpatched_count":28,"last_vuln_date":29,"fetched_at":30},"native-gettext","Native Gettext for WordPress","1.1.4","colinleroy","https:\u002F\u002Fprofiles.wordpress.org\u002Fcolinleroy\u002F","\u003Cp>This plugin has no setting or UI. It just does one thing : use the php-gettext library to handle translations. This results in much faster translation than using the default PHP gettext implementation of WordPress.\u003C\u002Fp>\n\u003Cp>If the extension is not available, the plugin will simply do nothing.\u003C\u002Fp>\n\u003Cp>You can verify that the plugin is working by looking for an HTTP header: X-Native-Gettext: 1, that will be sent as soon as a string will be translated by the native library.\u003C\u002Fp>\n\u003Cp>If your WordPress install is in English, this plugin has no purpose. Otherwise, it can help speed up your install quite a lot.\u003C\u002Fp>\n\u003Cp>Requirements:\u003Cbr \u002F>\n– php-gettext\u003Cbr \u002F>\n– OS-level support for the locale(s) you want to translate to.\u003C\u002Fp>\n","A very light wrapper plugin that uses the native gettext library for faster localization.",40,2795,"2024-09-04T06:48:00.000Z","6.6.5","4.7","5.3",[20,99,80],"https:\u002F\u002Fgithub.com\u002Fcolinleroy\u002Fnative-gettext-for-wp","https:\u002F\u002Fdownloads.wordpress.org\u002Fplugin\u002Fnative-gettext.1.1.4.zip",{"attackSurface":144,"codeSignals":171,"taintFlows":186,"riskAssessment":187,"analyzedAt":193},{"hooks":145,"ajaxHandlers":167,"restRoutes":168,"shortcodes":169,"cronEvents":170,"entryPointCount":28,"unprotectedCount":28},[146,152,156,161,163],{"type":147,"name":148,"callback":149,"file":150,"line":151},"action","admin_init","settings_init","php\\admin.php",15,{"type":147,"name":153,"callback":154,"file":150,"line":155},"admin_menu","add_menu_admin",16,{"type":157,"name":20,"callback":158,"file":159,"line":160},"filter","apply_translate_string","php\\frontend.php",12,{"type":157,"name":21,"callback":158,"file":159,"line":162},13,{"type":147,"name":164,"callback":165,"file":159,"line":166},"wp_enqueue_scripts","apply_translate_string_javascript",14,[],[],[],[],{"dangerousFunctions":172,"sqlUsage":173,"outputEscaping":175,"fileOperations":28,"externalRequests":28,"nonceChecks":28,"capabilityChecks":62,"bundledLibraries":185},[],{"prepared":28,"raw":28,"locations":174},[],{"escaped":176,"rawEcho":114,"locations":177},10,[178,181,183],{"file":150,"line":179,"context":180},99,"raw output",{"file":150,"line":182,"context":180},107,{"file":150,"line":184,"context":180},113,[],[],{"summary":188,"deductions":189},"The \"wp-override-translations\" plugin version 3.0.0 demonstrates a generally strong security posture based on the provided static analysis. The plugin has no identified CVEs, a clean vulnerability history, and no critical or high-severity taint flows.  Furthermore, it exhibits good practices by not utilizing dangerous functions, performing all SQL queries using prepared statements, and avoiding file operations and external HTTP requests. The limited attack surface, with zero AJAX handlers, REST API routes, shortcodes, or cron events, also contributes positively to its security.  However, there are minor areas for improvement. A capability check is present, but the absence of nonce checks on any potential entry points (though none are explicitly listed) could be a concern if the attack surface were to expand. Additionally, while 77% of output is properly escaped, the remaining 23% represents a potential avenue for cross-site scripting (XSS) vulnerabilities, albeit likely low severity given the absence of identified taint flows.",[190],{"reason":191,"points":192},"Unescaped output present",4,"2026-03-16T18:57:53.849Z",{"wat":195,"direct":201},{"assetPaths":196,"generatorPatterns":198,"scriptPaths":199,"versionParams":200},[197],"\u002Fwp-content\u002Fplugins\u002Fwp-override-translations\u002Fjs\u002Fmain.js",[],[197],[],{"cssClasses":202,"htmlComments":204,"htmlAttributes":205,"restEndpoints":207,"jsGlobals":208,"shortcodeOutput":209},[203],"deleteTranslateAction",[],[206],"wpOverrideTranslations",[],[206],[]]