{"id":266559,"date":"2026-03-14T22:03:48","date_gmt":"2026-03-14T22:03:48","guid":{"rendered":"https:\/\/wordpress.org\/plugins\/parallax-ai-content\/"},"modified":"2026-05-15T16:24:21","modified_gmt":"2026-05-15T16:24:21","slug":"ai-content-by-parallax","status":"publish","type":"plugin","link":"https:\/\/test.wordpress.org\/plugins\/ai-content-by-parallax\/","author":23426430,"comment_status":"closed","ping_status":"closed","template":"","meta":{"_crdt_document":"","version":"1.43.1","stable_tag":"1.43.1","tested":"6.9.4","requires":"6.9","requires_php":"8.1","requires_plugins":null,"header_name":"AI Content by Parallax","header_author":"Parallax","header_description":"Connects WordPress WooCommerce stores with Parallax AI API to generate SEO-optimized product content.","assets_banners_color":"cccccc","last_updated":"2026-05-15 16:24:21","external_support_url":"","external_repository_url":"","donate_link":"","header_plugin_uri":"https:\/\/eparallax.com\/","header_author_uri":"https:\/\/eparallax.com\/","rating":0,"author_block_rating":0,"active_installs":0,"downloads":415,"num_ratings":0,"support_threads":0,"support_threads_resolved":0,"author_block_count":0,"sections":["description","installation","faq","changelog"],"tags":{"1.0.0":{"tag":"1.0.0","author":"eparallax","date":"2026-03-14 23:17:59"},"1.1.0":{"tag":"1.1.0","author":"eparallax","date":"2026-04-09 19:10:02"},"1.42.0":{"tag":"1.42.0","author":"eparallax","date":"2026-04-09 19:16:01"},"1.42.1":{"tag":"1.42.1","author":"eparallax","date":"2026-04-15 22:56:06"},"1.42.2":{"tag":"1.42.2","author":"eparallax","date":"2026-04-21 05:20:23"},"1.42.3":{"tag":"1.42.3","author":"eparallax","date":"2026-05-04 20:08:26"},"1.43.0":{"tag":"1.43.0","author":"eparallax","date":"2026-05-15 02:05:48"},"1.43.1":{"tag":"1.43.1","author":"eparallax","date":"2026-05-15 16:24:21"}},"upgrade_notice":[],"ratings":[],"assets_icons":{"icon-128x128.png":{"filename":"icon-128x128.png","revision":3502787,"resolution":"128x128","location":"assets","locale":"","width":128,"height":128},"icon-256x256.png":{"filename":"icon-256x256.png","revision":3502787,"resolution":"256x256","location":"assets","locale":"","width":256,"height":256}},"assets_banners":{"banner-1544x500.png":{"filename":"banner-1544x500.png","revision":3502787,"resolution":"1544x500","location":"assets","locale":"","width":1544,"height":500},"banner-772x250.png":{"filename":"banner-772x250.png","revision":3502787,"resolution":"772x250","location":"assets","locale":"","width":772,"height":250}},"assets_blueprints":{},"all_blocks":[],"tagged_versions":["1.0.0","1.1.0","1.42.0","1.42.1","1.42.2","1.42.3","1.43.0","1.43.1"],"block_files":[],"assets_screenshots":{"screenshot-1.png":{"filename":"screenshot-1.png","revision":3482779,"resolution":"1","location":"assets","locale":"","width":3202,"height":1374},"screenshot-2.png":{"filename":"screenshot-2.png","revision":3482779,"resolution":"2","location":"assets","locale":"","width":3196,"height":1114}},"screenshots":{"1":"Optimize Products \u2014 bulk optimization queue with per-field toggles, credit tracking, and status indicators across the full catalog.","2":"Approval \/ Import \u2014 batch status tables for product and category optimizations, with snapshot and reset controls for safe rollbacks.","3":"Connection Settings \u2014 API key configuration, model selection, and sync options.","4":"WooCommerce Product List \u2014 inline optimization controls and status indicators directly on the WooCommerce products list.","5":"Plugins Page \u2014 Settings action link on the WordPress plugins list for quick access to plugin configuration."},"jetpack_post_was_ever_published":false},"plugin_section":[],"plugin_tags":[2353,243839,186,286],"plugin_category":[45],"plugin_contributors":[257768,82932],"plugin_business_model":[],"class_list":["post-266559","plugin","type-plugin","status-publish","hentry","plugin_tags-ai","plugin_tags-product-optimization","plugin_tags-seo","plugin_tags-woocommerce","plugin_category-ecommerce","plugin_contributors-eparallax","plugin_contributors-hawkeye126","plugin_committers-eparallax"],"banners":{"banner":"https:\/\/ps.w.org\/ai-content-by-parallax\/assets\/banner-772x250.png?rev=3502787","banner_2x":"https:\/\/ps.w.org\/ai-content-by-parallax\/assets\/banner-1544x500.png?rev=3502787","banner_rtl":false,"banner_2x_rtl":false},"icons":{"svg":false,"icon":"https:\/\/ps.w.org\/ai-content-by-parallax\/assets\/icon-128x128.png?rev=3502787","icon_2x":"https:\/\/ps.w.org\/ai-content-by-parallax\/assets\/icon-256x256.png?rev=3502787","generated":false},"screenshots":[{"src":"https:\/\/ps.w.org\/ai-content-by-parallax\/assets\/screenshot-1.png?rev=3482779","caption":"Optimize Products \u2014 bulk optimization queue with per-field toggles, credit tracking, and status indicators across the full catalog."},{"src":"https:\/\/ps.w.org\/ai-content-by-parallax\/assets\/screenshot-2.png?rev=3482779","caption":"Approval \/ Import \u2014 batch status tables for product and category optimizations, with snapshot and reset controls for safe rollbacks."}],"raw_content":"<!--section=description-->\n<p>Parallax is not a wrapper around a single LLM. It is <strong>custom AI logic<\/strong> purpose-built for WooCommerce, combining a multi-model engine, structured SEO frameworks, and real-world eCommerce expertise to generate product and category content that is optimized to rank, convert, and scale.<\/p>\n\n<p>Developed by <strong>Parallax<\/strong> \u2014 a team with 15+ years of experience building and optimizing high-performance WooCommerce stores \u2014 Parallax is designed to solve the real challenges of growing catalogs, inconsistent supplier data, and underperforming SEO.<\/p>\n\n<p>The plugin seamlessly connects your WooCommerce store to the Parallax AI Platform, allowing you to generate, review, and apply optimized content directly within WordPress.<\/p>\n\n<h4>Why Parallax is Different<\/h4>\n\n<p><strong>Multi-Model AI Engine (Not Just One LLM)<\/strong><\/p>\n\n<p>Parallax's custom AI logic intelligently routes each task to the best-fit model, rather than forcing every job through the same general-purpose LLM:<\/p>\n\n<ul>\n<li>Structured SEO content generation<\/li>\n<li>Data cleanup and normalization<\/li>\n<li>Attribute and taxonomy alignment<\/li>\n<li>Conversion-focused product copy<\/li>\n<\/ul>\n\n<p>This avoids the \"generic AI output\" problem and produces <strong>more accurate, consistent, and usable content at scale<\/strong>.<\/p>\n\n<p><strong>Built for eCommerce SEO (Not Generic AI Writing)<\/strong><\/p>\n\n<p>Most AI tools generate text. Parallax generates <strong>search-optimized content designed for real WooCommerce stores<\/strong>:<\/p>\n\n<ul>\n<li>SEO meta titles and descriptions aligned with search intent<\/li>\n<li>Category content structured for indexing and internal linking<\/li>\n<li>Keyword-aware product descriptions<\/li>\n<li>Google Shopping category alignment<\/li>\n<\/ul>\n\n<p>Every output is shaped by proven eCommerce SEO strategies, not just prompts.<\/p>\n\n<p><strong>Designed for Large, Complex Catalogs<\/strong><\/p>\n\n<p>Parallax is built for stores dealing with:<\/p>\n\n<ul>\n<li>Distributor feeds and inconsistent product data<\/li>\n<li>Thousands of SKUs<\/li>\n<li>Ongoing catalog updates<\/li>\n<\/ul>\n\n<p>Use batch workflows to process large datasets efficiently while maintaining quality and consistency.<\/p>\n\n<p><strong>Human-in-the-Loop Workflow<\/strong><\/p>\n\n<p>AI doesn't replace your team \u2014 it accelerates it:<\/p>\n\n<ul>\n<li>Review and approve content before publishing<\/li>\n<li>Track changes across batches and items<\/li>\n<li>Maintain full control over your catalog<\/li>\n<\/ul>\n\n<h4>Key Features<\/h4>\n\n<ul>\n<li>Secure API connection to the Parallax AI Platform<\/li>\n<li>Multi-model AI content generation and optimization via Parallax's custom AI logic<\/li>\n<li><p>Product content generation:<\/p>\n\n<ul>\n<li>Titles<\/li>\n<li>Descriptions<\/li>\n<li>Specifications<\/li>\n<li>SEO metadata<\/li>\n<\/ul><\/li>\n<li><p>Category optimization:<\/p>\n\n<ul>\n<li>Meta titles and descriptions<\/li>\n<li>Short and long-form content<\/li>\n<li>Internal linking suggestions<\/li>\n<\/ul><\/li>\n<li><p>Batch processing for large catalogs<\/p><\/li>\n<li>Structured workflows for review and approval<\/li>\n<li>Optional request\/response logging via WooCommerce's log system \u2014 errors and warnings are recorded by default; full info-level request\/response payloads are gated behind the \"Enable Debug Support\" setting<\/li>\n<li>Native WooCommerce + WordPress admin UI integration<\/li>\n<li>No storefront UI output \u2014 interactive workflows live in the WordPress admin (a lightweight WP-Cron job polls pending batches in the background; see disclosure below)<\/li>\n<\/ul>\n\n<h4>Who This Is For<\/h4>\n\n<ul>\n<li>Growing WooCommerce stores struggling with SEO performance<\/li>\n<li>Teams managing large or messy product catalogs<\/li>\n<li>Businesses relying on distributor or supplier data<\/li>\n<li>Agencies managing multiple WooCommerce clients<\/li>\n<\/ul>\n\n<h4>SaaS Disclosure (Required)<\/h4>\n\n<p>This plugin depends on a third-party SaaS service: Parallax AI (https:\/\/eparallax.com).<\/p>\n\n<p>When you trigger optimization actions, the plugin sends:<\/p>\n\n<ul>\n<li>Product titles, descriptions, excerpts, and selected metadata<\/li>\n<li>Category names and descriptions<\/li>\n<li>The Client Name and Client Description you entered in the plugin settings (sent as <code>clientBrand<\/code> and <code>clientBrandDescription<\/code> on every optimize request)<\/li>\n<li>A per-request <code>clientProductIdentifier<\/code> or <code>clientCategoryIdentifier<\/code> derived from your site host via <code>Client::get_client_identifier()<\/code><\/li>\n<li>Your site URL \/ host (sent in the <code>X-Client-Website<\/code> request header and used as the Parallax account identifier)<\/li>\n<li>The Parallax account API key you configured in the plugin settings<\/li>\n<\/ul>\n\n<p>Data is sent to:<\/p>\n\n<ul>\n<li><code>https:\/\/api.eparallax.com\/api<\/code> (configurable by defining the <code>EPARALLAX_API_BASE<\/code> PHP constant in <code>wp-config.php<\/code>)<\/li>\n<\/ul>\n\n<p>The Parallax API processes the data and returns optimized content fields.<\/p>\n\n<p>This plugin requires a Parallax AI account and API key. The service operates on a usage-based (credits) pricing model.<\/p>\n\n<p>Optimization runs are always initiated by an authorized user action \u2014 either through the WordPress admin UI or the <code>wp parallax optimize*<\/code> WP-CLI commands (see <code>src\/CLI\/Commands.php<\/code>). While a batch is pending, the plugin additionally runs a WP-Cron job every 15 minutes (<code>ai_content_by_parallax_pull_all_batch_requests<\/code>) that polls the Parallax API for that batch's status and results. No polling happens when there are no incomplete batches.<\/p>\n\n<h4>External Service Policy Compliance<\/h4>\n\n<ul>\n<li>No visitor tracking or behavioral data collection<\/li>\n<li>Only the optimization content and the account\/site identifiers enumerated in the SaaS Disclosure above are transmitted \u2014 no browsing, analytics, or customer data<\/li>\n<li>The only background network activity is the batch-status polling described above. The WP-Cron event is scheduled every 15 minutes, but the callback exits immediately when no incomplete batches exist \u2014 API requests only go out while a batch is in progress<\/li>\n<\/ul>\n\n<p>Privacy Policy: https:\/\/eparallax.com\/privacy-policy<\/p>\n\n<!--section=installation-->\n<ol>\n<li>Upload the plugin to <code>\/wp-content\/plugins\/ai-content-by-parallax\/<\/code><\/li>\n<li>Activate through <strong>Plugins \u2192 Installed Plugins<\/strong><\/li>\n<li>Go to <strong>WooCommerce \u2192 Parallax AI<\/strong><\/li>\n<li>Enter your API key<\/li>\n<li>Begin optimizing your products or categories<\/li>\n<\/ol>\n\n<!--section=faq-->\n<dl>\n<dt id=\"does%20this%20plugin%20work%20without%20a%20parallax%20ai%20account%3F\"><h3>Does this plugin work without a Parallax AI account?<\/h3><\/dt>\n<dd><p>No. A Parallax AI account and API key are required.<\/p><\/dd>\n<dt id=\"does%20this%20affect%20my%20storefront%20performance%3F\"><h3>Does this affect my storefront performance?<\/h3><\/dt>\n<dd><p>The plugin renders no storefront UI and does no optimization work on front-end requests. A lightweight 15-minute WP-Cron job polls the Parallax API for the status of any batches you've already submitted; like any WP-Cron task, it can fire on whichever request triggers the scheduler, but it exits immediately when there are no pending batches.<\/p><\/dd>\n<dt id=\"is%20any%20personal%20customer%20data%20sent%3F\"><h3>Is any personal customer data sent?<\/h3><\/dt>\n<dd><p>No customer or order data is ever sent. The plugin transmits exactly what the SaaS Disclosure section above enumerates: the product and category content being optimized, the Client Name \/ Client Description you entered in plugin settings, a site-host-derived client identifier, your site URL (in the <code>X-Client-Website<\/code> header and as the account identifier), and your Parallax account API key. Nothing else leaves the site.<\/p><\/dd>\n<dt id=\"can%20i%20sync%20parallax%20term%20seo%20to%20yoast%20seo%3F\"><h3>Can I sync Parallax term SEO to Yoast SEO?<\/h3><\/dt>\n<dd><p>Yes. Syncing is enabled by default. Check \"Disable sync term SEO to Yoast\" in\nthe settings to stop mirroring the term meta title\/description into Yoast's\nwpseo_title\/wpseo_desc fields for supported product taxonomies, and only when\nYoast SEO is installed.<\/p><\/dd>\n\n<\/dl>\n\n<!--section=changelog-->\n<h4>1.43.1<\/h4>\n\n<ul>\n<li>Display batch dates in the user's local browser timezone via client-side timestamp conversion.<\/li>\n<li>Add optimization UI to the WooCommerce category list: per-row optimize button, status indicator, and credit usage display.<\/li>\n<li>Add Optimize All button to the product list for batch-submitting all visible products to the optimization queue.<\/li>\n<li>Detect and surface orphaned batch items (processing too long without a status update); show a Refresh Status CTA and wire a refresh-status AJAX endpoint to re-fetch live status.<\/li>\n<li>Harden middleware error responses: handle 410 Gone (item deleted upstream), 5xx server errors, and unexpected 4xx responses with proper logging and user-facing status.<\/li>\n<\/ul>\n\n<h4>1.43.0<\/h4>\n\n<ul>\n<li>Refactor internal HTTP dispatch in MiddlewareRequest into a private runner, reducing duplication ahead of v2.0.0 catalog sync endpoints.<\/li>\n<li>Declare v2.0.0 Catalog Data Sync option-key names as class constants in Settings.php, pinning the key strings ahead of time so the v2.0.0 release does not need a settings migration.<\/li>\n<li>Declare the schema for <code>_parallax_id<\/code> post and term meta keys via <code>register_post_meta<\/code>\/<code>register_term_meta<\/code> ahead of the v2.0.0 Catalog Data Sync feature; keys are not written in 1.x.<\/li>\n<li>Add Sanitize::truncate_meta() helper to enforce middleware Postgres column caps (meta_title=100 chars, product_subtitle=500, product_brand=200, client_category_identifier=200) using mb_substr for UTF-8-safe truncation; adopt in product and category meta title import paths.<\/li>\n<li>Wire AJAX dismiss handler for the reset notice to delete the server-side option on dismissal, preventing re-appearance on next page load. Add <code>data-notice=\"reset\"<\/code> attribute to the reset notice div for JS targeting. Clean up the option on plugin activation so reinstalls start fresh.<\/li>\n<li>Move git hooks wiring out of composer post-install\/post-update scripts (which ran in CI) into an opt-in <code>composer install-hooks<\/code> command; document the step in README.md.<\/li>\n<\/ul>\n\n<h4>1.42.3<\/h4>\n\n<ul>\n<li>Refresh wp.org landing page copy to stress the value of Parallax's custom AI logic: sharper Description opening, stronger multi-model positioning, and a restructured Key Features list with nested product\/category bullets.<\/li>\n<\/ul>\n\n<h4>1.42.2<\/h4>\n\n<ul>\n<li>Refresh wp.org plugin description, FAQ, and screenshots section.<\/li>\n<li>Add SEO Rating and Rating Change Explanation rows to the product\/category import detail popup, surfacing Google Gemini's original vs. optimized scores with a tooltip.<\/li>\n<\/ul>\n\n<h4>1.42.1<\/h4>\n\n<ul>\n<li>Rename the Yoast term sync setting to a disable toggle and default new installs to syncing enabled.<\/li>\n<\/ul>","raw_excerpt":"Parallax AI Content for WooCommerce is built specifically for serious eCommerce teams that need more than generic AI copy.","jetpack_sharing_enabled":true,"_links":{"self":[{"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin\/266559","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin"}],"about":[{"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/types\/plugin"}],"replies":[{"embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/comments?post=266559"}],"author":[{"embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wporg\/v1\/users\/eparallax"}],"wp:attachment":[{"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/media?parent=266559"}],"wp:term":[{"taxonomy":"plugin_section","embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_section?post=266559"},{"taxonomy":"plugin_tags","embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_tags?post=266559"},{"taxonomy":"plugin_category","embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_category?post=266559"},{"taxonomy":"plugin_contributors","embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_contributors?post=266559"},{"taxonomy":"plugin_business_model","embeddable":true,"href":"https:\/\/test.wordpress.org\/plugins\/wp-json\/wp\/v2\/plugin_business_model?post=266559"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}