Skip to content

fix: missing remote attachments issue#243

Open
Kallyan01 wants to merge 4 commits into
mainfrom
fix/remote-attachment
Open

fix: missing remote attachments issue#243
Kallyan01 wants to merge 4 commits into
mainfrom
fix/remote-attachment

Conversation

@Kallyan01

@Kallyan01 Kallyan01 commented Jun 12, 2026

Copy link
Copy Markdown
Collaborator

What

Remote site post thumbnail issue on the search area.

Why

It's impacting search result functionality.

Related Issue(s):

Closes https://github.com/rtCamp/OnePress/issues/73

How

The thumbnails were not loading in the search results because remote posts were assigned negative post IDs. To address this, we intercepted those posts and generated the thumbnail data through filters, ensuring that thumbnails are displayed correctly in the search results.

AI Disclosure

Claude Opus 4.6 ( Research )

Testing Instructions

  • Set up both the Governing and Brand sites in a local environment using wp-env.
  • Upload a few media files to the Brand site and run the re-index process.
  • On the Governing site, search for the uploaded media file names.
  • Verify that the media results now display visible thumbnails, whereas previously the thumbnails were not appearing.

Screenshots

Before:
image

After:
image

Additional Info

Checklist

  • I have read the Contribution Guidelines.
  • I have read the Development Guidelines.
  • I have added necessary tests to cover my changes.
  • I have updated the project documentation as needed.
  • My code has detailed inline documentation.
  • My code is tested to the best of my abilities.
  • My code passes all lints, tests, and checks.
Open WordPress Playground Preview

@Kallyan01 Kallyan01 self-assigned this Jun 12, 2026
@Kallyan01 Kallyan01 added the Bug label Jun 12, 2026
@Kallyan01 Kallyan01 changed the title Fixed missing remote attachments issue fix:missing remote attachments issue Jun 12, 2026
@Kallyan01 Kallyan01 changed the title fix:missing remote attachments issue fix: missing remote attachments issue Jun 12, 2026
@Kallyan01 Kallyan01 requested a review from justlevine June 12, 2026 10:58

Copilot AI left a comment

Copy link
Copy Markdown
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Pull request overview

Fixes missing thumbnails for remote (Algolia-hydrated) attachment results in the search UI by carrying thumbnail metadata on mocked remote WP_Post objects and intercepting WordPress image/thumbnail rendering paths to use that metadata.

Changes:

  • Adds remote thumbnail plumbing by storing Algolia thumbnail record data on remote WP_Post objects.
  • Hooks into WordPress image/thumbnail/content rendering filters to output remote thumbnail URLs/HTML for negative-ID (remote) posts and attachments.
  • Updates PHPStan stubs to model the new dynamic onesearch_thumbnail property.

Reviewed changes

Copilot reviewed 2 out of 2 changed files in this pull request and generated 5 comments.

File Description
phpstan/stubs/wordpress-extended.php Adds PHPStan typing for the new WP_Post::$onesearch_thumbnail dynamic property.
inc/Modules/Search/Search.php Adds filters + helper logic to render remote thumbnails correctly for search results containing remote/negative-ID posts.

💡 Add Copilot custom instructions for smarter, more guided reviews. Learn how to get started.

Comment on lines +361 to +373
if ( ! empty( $thumbnail['url'] ) ) {
$block_content = (string) preg_replace(
'#(<img[^>]*\bsrc)="[^"]*"([^>]*>)#si',
'$1="' . esc_url( $thumbnail['url'] ) . '"$2',
$block_content,
1
);
$block_content = (string) preg_replace(
'#\s*(?:srcset|sizes)="[^"]*"#',
'',
$block_content
);
}
Comment on lines +576 to +581
$content = (string) preg_replace(
'#<p\s+class=["\']attachment["\']\s*>.*?</p>#s',
$attachment_html,
$content,
1
);
Comment thread inc/Modules/Search/Search.php
Comment on lines +468 to +470
if ( is_string( $attr ) && ! empty( $attr ) ) {
$attr_string = ' ' . ltrim( $attr );
}
Comment on lines +472 to +480
if ( is_array( $attr ) ) {
foreach ( $attr as $name => $value ) {
if ( 'class' === $name ) {
$attr_string .= sprintf( ' class="%s"', esc_attr( $value ) );
} else {
$attr_string .= sprintf( ' %s="%s"', esc_attr( $name ), esc_attr( $value ) );
}
}
}

@justlevine justlevine left a comment

Copy link
Copy Markdown
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ignore the copilot noise for now: this is what I was concerned about:

Image

(Left is the local post, right is the remote)

It's possible that the preg_replace can be fixed to better support other block image attachments, and even switching to the more ideal HTML API could catch even more. But ultimately the use of replacing the image output is always going to be flawed, fragile, and susceptible to edge cases.

As mentioned both in the GH issue and on slack, unless you have a reason otherwise, I think the best way to address the bug will be to:

  1. Programmatically create a single fictitious attachment at plugin activation (and checking/recreating it when using) and assign that number as the post attachment id instead of a non-existent negative post id. It should be hidden from the UX.
  2. Use the attachment hooks to swap out the metadata on the attachment to the specific remote file, instead of trying to finagle the post directly.

This way any attachment-related functionality work natively the image routing is an isolated implementation detail.

@codecov-commenter

Copy link
Copy Markdown

Codecov Report

❌ Patch coverage is 0% with 105 lines in your changes missing coverage. Please review.
✅ Project coverage is 57.85%. Comparing base (4de80a8) to head (06d302e).

Files with missing lines Patch % Lines
inc/Modules/Search/Search.php 0.00% 105 Missing ⚠️
Additional details and impacted files

Impacted file tree graph

@@             Coverage Diff              @@
##               main     #243      +/-   ##
============================================
- Coverage     60.91%   57.85%   -3.06%     
- Complexity      543      592      +49     
============================================
  Files            22       22              
  Lines          1988     2093     +105     
============================================
  Hits           1211     1211              
- Misses          777      882     +105     
Flag Coverage Δ
unit 57.85% <0.00%> (-3.06%) ⬇️

Flags with carried forward coverage won't be shown. Click here to find out more.

Files with missing lines Coverage Δ
inc/Modules/Search/Search.php 0.00% <0.00%> (ø)
🚀 New features to boost your workflow:
  • ❄️ Test Analytics: Detect flaky tests, report on failures, and find test suite problems.
  • 📦 JS Bundle Analysis: Save yourself from yourself by tracking and limiting bundle sizes in JS merges.

@Kallyan01

Copy link
Copy Markdown
Collaborator Author

@justlevine, the issue with the current fix isn't clear to me. Could you please help me if I'm missing any details or edge cases? All I can see is a missing publish date and a bit smaller thumbnail size.

Source Site Result
image

Remote Site Result
image

@justlevine

justlevine commented Jun 18, 2026

Copy link
Copy Markdown
Collaborator

@justlevine, the issue with the current fix isn't clear to me. Could you please help me if I'm missing any details or edge cases? All I can see is a missing publish date and a bit smaller thumbnail size.

Inspect the actual html for both. Different blocks (and settings) render images differently with different html attributes and patterns. Your search-replace ditches all of that for a specific <img > , and trying to manually enumerate the specific blocks as conditionals means that we need to manually add support for every new block and anything the end-user has custom is SOL.

@justlevine

justlevine commented Jun 18, 2026

Copy link
Copy Markdown
Collaborator

Here's the dummy post from above that you can use for testing. Don't forget to update the images after you paste it in.

<!-- wp:paragraph -->
<p>image</p>
<!-- /wp:paragraph -->

<!-- wp:image {"id":7,"sizeSlug":"full","linkDestination":"none"} -->
<figure class="wp-block-image size-full"><img src="http://localhost:8888/wp-content/uploads/2026/06/900-536x354-1.jpg" alt="Some picsum for my testsum" class="wp-image-7"/><figcaption class="wp-element-caption">Picsum ID: 900</figcaption></figure>
<!-- /wp:image -->

<!-- wp:paragraph -->
<p>Gallery</p>
<!-- /wp:paragraph -->

<!-- wp:gallery {"linkTo":"none"} -->
<figure class="wp-block-gallery has-nested-images columns-default is-cropped"><!-- wp:image {"id":7,"sizeSlug":"large","linkDestination":"none"} -->
<figure class="wp-block-image size-large"><img src="http://localhost:8888/wp-content/uploads/2026/06/900-536x354-1.jpg" alt="Some picsum for my testsum" class="wp-image-7"/><figcaption class="wp-element-caption">Picsum ID: 900</figcaption></figure>
<!-- /wp:image --></figure>
<!-- /wp:gallery -->

<!-- wp:paragraph -->
<p>Media/Text</p>
<!-- /wp:paragraph -->

<!-- wp:media-text {"mediaId":7,"mediaLink":"http://localhost:8888/picsum-id-900/","linkDestination":"none","mediaType":"image"} -->
<div class="wp-block-media-text is-stacked-on-mobile"><figure class="wp-block-media-text__media"><img src="http://localhost:8888/wp-content/uploads/2026/06/900-536x354-1.jpg" alt="Some picsum for my testsum" class="wp-image-7 size-full"/></figure><div class="wp-block-media-text__content"><!-- wp:paragraph {"placeholder":"Content…"} -->
<p>Media text</p>
<!-- /wp:paragraph --></div></div>
<!-- /wp:media-text -->

<!-- wp:cover {"url":"http://localhost:8888/wp-content/uploads/2026/06/900-536x354-1.jpg","id":7,"alt":"Some picsum for my testsum","dimRatio":50,"customOverlayColor":"#9b7861","isUserOverlayColor":false,"isDark":false,"sizeSlug":"full","layout":{"type":"constrained"}} -->
<div class="wp-block-cover is-light"><img class="wp-block-cover__image-background wp-image-7 size-full" alt="Some picsum for my testsum" src="http://localhost:8888/wp-content/uploads/2026/06/900-536x354-1.jpg" data-object-fit="cover"/><span aria-hidden="true" class="wp-block-cover__background has-background-dim" style="background-color:#9b7861"></span><div class="wp-block-cover__inner-container"><!-- wp:paragraph {"placeholder":"Write title…","style":{"typography":{"textAlign":"center"}},"fontSize":"large"} -->
<p class="has-text-align-center has-large-font-size">Cover Image</p>
<!-- /wp:paragraph --></div></div>
<!-- /wp:cover -->

<!-- wp:post-featured-image /-->

Co-authored-by: Copilot Autofix powered by AI <175728472+Copilot@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

Projects

None yet

Development

Successfully merging this pull request may close these issues.

4 participants