Commit af195b6
committed
[LiveComponent] Rebuild Component on reconnect when props changed in between
When a parent action removes and re-adds a child live component that lives
on the same DOM element, Stimulus reuses the controller instance — it only
calls disconnect() then connect() again, not initialize(). createComponent()
is therefore never re-run, so the Component keeps a stale ValueStore that no
longer matches the freshly rendered HTML, and Component.set() throws
"Invalid model name" the next time the user types into a field.
Detect the divergence in connect() by comparing the current propsValue with
the props the Component was originally built with, and rebuild it when they
differ. Behavior is unchanged on the first connect() (props match by
construction) and on plain reconnects without any prop change.
Fixes #34241 parent 68129d2 commit af195b6
2 files changed
Lines changed: 39 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
93 | 93 | | |
94 | 94 | | |
95 | 95 | | |
| 96 | + | |
| 97 | + | |
| 98 | + | |
| 99 | + | |
| 100 | + | |
| 101 | + | |
| 102 | + | |
| 103 | + | |
| 104 | + | |
| 105 | + | |
96 | 106 | | |
97 | 107 | | |
98 | 108 | | |
| |||
Lines changed: 29 additions & 1 deletion
| Original file line number | Diff line number | Diff line change | |
|---|---|---|---|
| |||
12 | 12 | | |
13 | 13 | | |
14 | 14 | | |
15 | | - | |
| 15 | + | |
16 | 16 | | |
17 | 17 | | |
18 | 18 | | |
| |||
52 | 52 | | |
53 | 53 | | |
54 | 54 | | |
| 55 | + | |
| 56 | + | |
| 57 | + | |
| 58 | + | |
| 59 | + | |
| 60 | + | |
| 61 | + | |
| 62 | + | |
| 63 | + | |
| 64 | + | |
| 65 | + | |
| 66 | + | |
| 67 | + | |
| 68 | + | |
| 69 | + | |
| 70 | + | |
| 71 | + | |
| 72 | + | |
| 73 | + | |
| 74 | + | |
| 75 | + | |
| 76 | + | |
| 77 | + | |
| 78 | + | |
| 79 | + | |
| 80 | + | |
| 81 | + | |
| 82 | + | |
55 | 83 | | |
0 commit comments