@blueshed/railroad 0.3.1 → 0.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -89,3 +89,6 @@ loggedRequest(tag, handler): Handler // wrap route handler with access logging
89
89
  3. **No `text()` for attributes.** `text()` creates a DOM node. Use `computed()` for reactive attributes.
90
90
  4. **No JSX in effects without dispose scopes.** Any effect that rebuilds DOM must use `pushDisposeScope`/`popDisposeScope` and return a cleanup function. See `jsx.ts` source for the pattern.
91
91
  5. **No `transition-all` in CSS** near layout boundaries. Use specific properties.
92
+ 6. **No bare nested `when()`.** `when()` returns a fragment — nesting fragments inside another `when()` breaks dispose scope tracking. Always wrap an inner `when()` in a real element: `<div>{when(...)}</div>`.
93
+ 7. **No shared DOM nodes across `when()` branches.** Nodes must be created fresh inside each branch function. A node created outside and reused across branches will be torn out of the DOM when the other branch activates.
94
+ 8. **Guard against null inside `when()` branches.** Signal cascade order is not guaranteed — an inner `when()` can fire before the outer `when()` swaps it away. Always null-check even inside a branch that "shouldn't" be reached (e.g. `text(() => item.get()?.name ?? "")`).
package/jsx.ts CHANGED
@@ -327,6 +327,16 @@ export function list<T>(
327
327
  // Existing keyed item — push new value into its signal
328
328
  entry.item!.set(arr[i]!);
329
329
  entry.index!.set(i);
330
+ } else {
331
+ // Index-based — dispose old, recreate with new item
332
+ const oldNode = entry.node;
333
+ entry.dispose();
334
+ pushDisposeScope();
335
+ const node = (keyFnOrRender as (item: T, index: number) => Node)(arr[i]!, i);
336
+ const dispose = popDisposeScope();
337
+ entry = { node, dispose };
338
+ entries.set(key, entry);
339
+ if (oldNode.parentNode) oldNode.parentNode.replaceChild(node, oldNode);
330
340
  }
331
341
 
332
342
  // Move or insert into correct position
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@blueshed/railroad",
3
- "version": "0.3.1",
3
+ "version": "0.3.3",
4
4
  "description": "Signals, JSX, and routes — a micro UI framework for Bun",
5
5
  "type": "module",
6
6
  "main": "index.ts",