[PR #22779] [CLOSED] fix: resolve ReferenceError in InputVariablesModal preventing prompt variable usage #49911

Closed
opened 2026-04-30 02:20:36 -05:00 by GiteaMirror · 0 comments
Owner

📋 Pull Request Information

Original PR: https://github.com/open-webui/open-webui/pull/22779
Author: @joaquinhuigomez
Created: 3/18/2026
Status: Closed

Base: devHead: fix/input-variables-modal-reference-error


📝 Commits (10+)

📊 Changes

1 file changed (+18 additions, -18 deletions)

View changed files

📝 src/lib/components/chat/MessageInput/InputVariablesModal.svelte (+18 -18)

📄 Description

Pull Request Checklist

  • Target branch: Verify that the pull request targets the dev branch.
  • Description: Provided below.
  • Changelog: Included below.
  • Testing: Manually verified the fix resolves the infinite spinner.
  • Agentic AI Code: This fix was human-reviewed and manually tested.
  • Code review: Self-reviewed.
  • Git Hygiene: Single atomic commit.

Changelog Entry

Description

Fixes #22748 — The InputVariablesModal component throws ReferenceError: idx is not defined at line 39, causing the prompt variables modal to show an infinite loading spinner. The entire prompt variable feature is broken.

Root cause: The {@const} destructuring with rest syntax ({ type, ...variableAttributes }) inside an {#each} block triggers a scoping issue in Svelte 5's legacy compatibility mode, where the loop index variable idx becomes undefined in the compiled output.

Fixed

  • Renamed loop index from idx to variableIdx to avoid the naming collision
  • Replaced {@const} rest destructuring with Object.fromEntries(Object.entries(...).filter(...)) to work around the Svelte 5 compilation scoping bug

Screenshots or Videos

Before: Modal shows infinite loading spinner, console shows ReferenceError: idx is not defined
After: Modal renders correctly, prompt variables can be filled in

Contributor License Agreement


🔄 This issue represents a GitHub Pull Request. It cannot be merged through Gitea due to API limitations.

## 📋 Pull Request Information **Original PR:** https://github.com/open-webui/open-webui/pull/22779 **Author:** [@joaquinhuigomez](https://github.com/joaquinhuigomez) **Created:** 3/18/2026 **Status:** ❌ Closed **Base:** `dev` ← **Head:** `fix/input-variables-modal-reference-error` --- ### 📝 Commits (10+) - [`fe6783c`](https://github.com/open-webui/open-webui/commit/fe6783c16699911c7be17392596d579333fb110c) Merge pull request #19030 from open-webui/dev - [`fc05e0a`](https://github.com/open-webui/open-webui/commit/fc05e0a6c5d39da60b603b4d520f800d6e36f748) Merge pull request #19405 from open-webui/dev - [`e3faec6`](https://github.com/open-webui/open-webui/commit/e3faec62c58e3a83d89aa3df539feacefa125e0c) Merge pull request #19416 from open-webui/dev - [`9899293`](https://github.com/open-webui/open-webui/commit/9899293f050ad50ae12024cbebee7e018acd851e) Merge pull request #19448 from open-webui/dev - [`140605e`](https://github.com/open-webui/open-webui/commit/140605e660b8186a7d5c79fb3be6ffb147a2f498) Merge pull request #19462 from open-webui/dev - [`6f1486f`](https://github.com/open-webui/open-webui/commit/6f1486ffd0cb288d0e21f41845361924e0d742b3) Merge pull request #19466 from open-webui/dev - [`d95f533`](https://github.com/open-webui/open-webui/commit/d95f533214e3fe5beb5e41ec1f349940bc4c7043) Merge pull request #19729 from open-webui/dev - [`a727153`](https://github.com/open-webui/open-webui/commit/a7271532f8a38da46785afcaa7e65f9a45e7d753) 0.6.43 (#20093) - [`6adde20`](https://github.com/open-webui/open-webui/commit/6adde203cd292a9e3af9c64a2ae36b603fed096a) Merge pull request #20394 from open-webui/dev - [`f9b0534`](https://github.com/open-webui/open-webui/commit/f9b0534e0c442631d1cb7205169588b9b6204179) Merge pull request #20522 from open-webui/dev ### 📊 Changes **1 file changed** (+18 additions, -18 deletions) <details> <summary>View changed files</summary> 📝 `src/lib/components/chat/MessageInput/InputVariablesModal.svelte` (+18 -18) </details> ### 📄 Description # Pull Request Checklist - [x] **Target branch:** Verify that the pull request targets the `dev` branch. - [x] **Description:** Provided below. - [x] **Changelog:** Included below. - [x] **Testing:** Manually verified the fix resolves the infinite spinner. - [x] **Agentic AI Code:** This fix was human-reviewed and manually tested. - [x] **Code review:** Self-reviewed. - [x] **Git Hygiene:** Single atomic commit. # Changelog Entry ### Description Fixes #22748 — The `InputVariablesModal` component throws `ReferenceError: idx is not defined` at line 39, causing the prompt variables modal to show an infinite loading spinner. The entire prompt variable feature is broken. **Root cause:** The `{@const}` destructuring with rest syntax (`{ type, ...variableAttributes }`) inside an `{#each}` block triggers a scoping issue in Svelte 5's legacy compatibility mode, where the loop index variable `idx` becomes undefined in the compiled output. ### Fixed - Renamed loop index from `idx` to `variableIdx` to avoid the naming collision - Replaced `{@const}` rest destructuring with `Object.fromEntries(Object.entries(...).filter(...))` to work around the Svelte 5 compilation scoping bug ### Screenshots or Videos Before: Modal shows infinite loading spinner, console shows `ReferenceError: idx is not defined` After: Modal renders correctly, prompt variables can be filled in ### Contributor License Agreement - [x] By submitting this pull request, I confirm that I have read and fully agree to the [Contributor License Agreement (CLA)](https://github.com/open-webui/open-webui/blob/main/CONTRIBUTOR_LICENSE_AGREEMENT), and I am providing my contributions under its terms. --- <sub>🔄 This issue represents a GitHub Pull Request. It cannot be merged through Gitea due to API limitations.</sub>
GiteaMirror added the pull-request label 2026-04-30 02:20:36 -05:00
Sign in to join this conversation.
1 Participants
Notifications
Due Date
No due date set.
Dependencies

No dependencies set.

Reference: github-starred/open-webui#49911