Adding component to component library results in component code and configuration being lost

Created on 15 March 2025, 22 days ago

Overview

When a component is added to the component library, its underlying code and configuration are not retained. Instead, the component appears empty causing the component code and configuration being lost.

Proposed resolution

User interface changes

🐛 Bug report
Status

Active

Version

0.0

Component

Theme builder

Created by

🇫🇮Finland lauriii Finland

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

  • Issue created by @lauriii
  • 🇫🇮Finland lauriii Finland
  • 🇳🇱Netherlands balintbrews Amsterdam, NL

    I took a look, and what happens here is that if we use the contextual menu from the sidebar list, we will send the canonical entity data with the PATCH request when we update the JavaScriptComponent entity to rename it or make it internal/exposed, because that's what we have available in the React component that outputs that list. With a new code component which hasn't been published since it was created, it means that only the auto-saved version has the data — and we lose all of that. 🙈

    This isn't a cache invalidation problem, because the endpoint that lists the code components doesn't use auto-saved data. To solve the issue, we need to:

    1. Fix 🐛 PATCH request for config entities reset values that are not sent Active (priority increased)
    2. Update our PATCH requests to include only the wanted changes:
      • ui/src/features/code-editor/dialogs/AddToComponentsDialog.tsx
      • ui/src/features/code-editor/dialogs/RemoveFromComponentsDialog.tsx
      • ui/src/features/code-editor/dialogs/RenameCodeComponentDialog.tsx
Production build 0.71.5 2024