- Issue created by @wim leers
- ๐บ๐ธUnited States effulgentsia
wim leers โ credited effulgentsia โ .
- ๐ช๐ธSpain penyaskito Seville ๐, Spain ๐ช๐ธ, UTC+2 ๐ช๐บ
An interesting error that prevented any blocks to be placed in XB: ๐ Undefined array key "base" in Drupal\views\Plugin\views\query\QueryPluginBase Active
- ๐ซ๐ฎFinland lauriii Finland
Tested this now that ๐ Improve server-side error handling Active landed. It seems that the preview rendering is somewhat working now. It would be great if the component was wrapped with the HTML comment so that it would be possible to see what is the name of the component in XB.
It looks like the library and the props forms fail to render โ because of the component is erroring. That is at least equally important with not crashing the whole preview. Is there an issue for that already?
I think we could de-prioritize โจ [PP-4] Present all component instances that fail to render using toasts Active and possibly even ๐ [PP-3] Server-rendered component instances failing to render should expose the meaningful error to the XB UI in a structured way Postponed until we have designs to not have to spend time on implement a temporary solution.
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
It looks like the library and the props forms fail to render because of the component is erroring. That is at least equally important with not crashing the whole preview. Is there an issue for that already?
No!
But: how did you make that component crash during rendering? It seems like you deleted an SDC, code component or a block plugin, instead of triggering one of the 6 failure modes described at the top of this issue?
If so: what you did is actually not related to this issue, because this issue is focused squarely on rendering of component instances never failing. AFAICT ๐ Cannot delete JS components due to component depending on them Active should fix both symptoms. If it doesn't, I'll file issues under ๐ฑ [META] Production-ready client-side data model + internal HTTP API Active .
until we have designs to not have to spend time on implement a temporary solution.
Well โฆ the point of the issue summary's sequencing (which you approved) is to do โจ [PP-4] Present all component instances that fail to render using toasts Active using Radix UI toasts to spend zero time on a temporary solution โ , but to allow the design team to be better informed when designing this.
It would be great if the component was wrapped with the HTML comment so that it would be possible to see what is the name of the component in XB.
That's a trivial change to
\Drupal\experience_builder\Element\RenderSafeComponentContainer::handleComponentException()
, which is why it was built that way ๐ However, why not just add adata-component-id
attribute in addition to the currentdata-component-uuid
?public static function handleComponentException(\Throwable $e, string $componentContext, bool $isPreview, string $componentUuid): array { \Drupal::logger('experience_builder')->error(\sprintf('%s occurred during rendering of component %s in %s: %s', $e::class, $componentUuid, $componentContext, $e->getMessage())); if ($isPreview) { return [ '#type' => 'container', '#attributes' => [ 'data-component-uuid' => $componentUuid, ], '#markup' => new TranslatableMarkup('Component failed to render, check logs for more detail.'), ]; } return [ '#type' => 'container', '#attributes' => ['data-component-uuid' => $componentUuid], '#markup' => new TranslatableMarkup('Oops, something went wrong! Site admins have been notified.'), ]; }
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
But: how did you make that component crash during rendering? It seems like you deleted an SDC, code component or a block plugin, instead of triggering one of the 6 failure modes described at the top of this issue?
Oh, perhaps you tested this by doing what @f.mazeikis also guessed over at #3519168-37: Handle components provided by ComponentSources disappearing ungracefully โ enables deleting JS components that are in use โ , i.e. by deleting a
Component
config entity by force? - ๐ซ๐ฎFinland lauriii Finland
But: how did you make that component crash during rendering? It seems like you deleted an SDC, code component or a block plugin, instead of triggering one of the 6 failure modes described at the top of this issue?
I did not delete a component but I added invalid Twig syntax to a template. The response to
/xb/api/v0/config/component
is 500 with message:Unknown \u0022nonExistingFilter\u0022 filter.
. I would not expect that having a component in an invalid state would lead into the XB UI being unusable which is why I'd like to prioritize it before the steps 3 and 4 here.I already showed the current error message to Callum and he's going to do some designs around this that might help make the process more efficient. ๐
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Will investigate tomorrow what issues this needs. I expected ๐ Improve server-side error handling Active to have handled the
/xb/api/v0/config/component
case at the very least ๐ฌ - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Looks like the work we've done so far missed at least one edge case: ๐ The component fails to render the library and props forms due to an unhandled runtime exception. Active .
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Confirmed that ๐ The component fails to render the library and props forms due to an unhandled runtime exception. Active was a missed edge case; and it's just been fixed ๐
- Status changed to Needs work
4 months ago 2:51pm 17 June 2025 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Following up on #15 and #16 (finally).
#15's
/xb/api/v0/config/component
case was indeed a bug, and was fixed since then in ๐ The component fails to render the library and props forms due to an unhandled runtime exception. Active , as described in #17.#3518201 and #3518203 are indeed "nice-to-haves" for ๐ฑ Milestone 1.0.0-beta1: Start creating non-throwaway sites Active .
So โฆ adopting the same structure as we have for ๐ฑ [META] Production-ready ComponentSource plugins Active and ๐ฑ [META] Production-ready data storage Active to signal beta vs stable vs post-stable.
- ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
As of #19โฆ I can confirm THE BETA PARTS ARE DONE! ๐ฅณ๐ฅณ๐ฅณ
Signaling this is "done for now", i.e. for ๐ฑ Milestone 1.0.0-beta1: Start creating non-throwaway sites Active but NOT for ๐ฑ Milestone 1.0.0: Production Sites Postponed , by marking this .
- Issue was unassigned.
- Status changed to Downport
2 months ago 10:23am 19 August 2025 - ๐ง๐ชBelgium wim leers Ghent ๐ง๐ช๐ช๐บ
Bug found: ๐ A component can break XB just by failing to render its preview Active .
Also, this issue's summary needs to be updated to reflect the updated 1.0 scope.