Adam Goldstein
Adam Goldstein
SSolidJS
Created by sean on 10/30/2024 in #support
How to avoid temporary undefined values in template literals in solid-meta?
* If you want the title to render in order with the stream and you're rendering SSR, that is, which will ensure best SEO/OG support and such (though may not be strictly necessary these days). Otherwise wrapping them in a Suspense boundary should make cause load in later out of order, but skip the undefined values
3 replies
SSolidJS
Created by sean on 10/30/2024 in #support
How to avoid temporary undefined values in template literals in solid-meta?
I think you're missing adding deferStream: true to the async options
3 replies
SSolidJS
Created by Daniel Sousa @TutoDS on 10/28/2024 in #support
Default SEO vs Route SEO
I experienced what I think was a similar issue but kicked the can down the road, iirc it seemed like <Title> would override correctly but the other meta tags wouldn't (my memory could be failing me though). I thought about a solution like wrapping the Router in a context provider, and having a custom Meta wrapper component with a "default" boolean or "priority" integer prop which configures which meta component overrides which, then some whacky state setting in that context when the wrapper mounts (with onCleanup to reset it) so only the non-default/highest priority wrapped Meta children get rendered. If you end up implenting some solution, I'd definitely appreciate it if you shared it, I'll do the same if I get around to that first
14 replies
SSolidJS
Created by Andreas Roth on 9/16/2024 in #support
Cycles in dependency graph
Oh of course, duh 🤦. For some reason I was thinking of the signals calling themselves, of course it would be the computeds. The memo-like approach makes a lot of sense though, glad to see that seems to be working!
14 replies
SSolidJS
Created by Andreas Roth on 9/16/2024 in #support
Cycles in dependency graph
If that does end up working, please let me know! Would be great to note
14 replies
SSolidJS
Created by Andreas Roth on 9/16/2024 in #support
Cycles in dependency graph
Happy to help! I think it should work basically the exact same but just:
const wrapStoreMaybeWithCycles = (storeProxy) => {
let insideAccessorCall = false;
return new Proxy(storeProxy, {
get(...args) {
if (insideAccessorCall) {
throw new Error("Cycle!");
}
insideAccessorCall = true;
const val = Reflect.get(...args);
insideAccessorCall = false;
return val;
},
});
}
const wrapStoreMaybeWithCycles = (storeProxy) => {
let insideAccessorCall = false;
return new Proxy(storeProxy, {
get(...args) {
if (insideAccessorCall) {
throw new Error("Cycle!");
}
insideAccessorCall = true;
const val = Reflect.get(...args);
insideAccessorCall = false;
return val;
},
});
}
One of the joys of having a library where the abstractions aren't crazy deep 🙂
14 replies
SSolidJS
Created by Andreas Roth on 9/16/2024 in #support
Cycles in dependency graph
Would be curious to see the Excel-like application as well! Seems like potentially a great use case for Solid.js 🙂
14 replies
SSolidJS
Created by Andreas Roth on 9/16/2024 in #support
Cycles in dependency graph
And of course you could handle cycle errors however you want, return some null/undefined/NaN/empty object value, whatever
14 replies
SSolidJS
Created by Andreas Roth on 9/16/2024 in #support
Cycles in dependency graph
@Andreas Roth You may be long past this now, but this seems doable (at least at first glance) by taking advantage of batched updates, either with the batch utility or relying on automatic batching. As long as all the updates are running inside a single batch, I think something like the following might work:
const wrapSignalMaybeWithCycles = ([accessor, setter]) => {
let insideAccessorCall = false;
return ([
(...args) => {
if (insideAccessorCall) {
throw new Error("Cycle!");
}
insideAccessorCall = true;
const val = accessor(...args);
insideAccessorCall = false;
return val;
},
setter,
})

// Can use like any normal signal, I think, hopefully?
const [getIt, setIt] = wrapSignalMaybeWithCycles(createSignal());
const wrapSignalMaybeWithCycles = ([accessor, setter]) => {
let insideAccessorCall = false;
return ([
(...args) => {
if (insideAccessorCall) {
throw new Error("Cycle!");
}
insideAccessorCall = true;
const val = accessor(...args);
insideAccessorCall = false;
return val;
},
setter,
})

// Can use like any normal signal, I think, hopefully?
const [getIt, setIt] = wrapSignalMaybeWithCycles(createSignal());
Just a thought, not sure 🤷
14 replies
SSolidJS
Created by Mapo Doofus on 10/7/2024 in #support
Auth in layout?
This is Solid Start right? I ended up going with a <ProtectRoute> component which has an SSR-blocking resource for auth, and conditionally renders a <Navigate> component once auth is resolved as unauthenticated. Seems to work great with layouts
10 replies
SSolidJS
Created by mpeg on 10/1/2024 in #support
State sharing between Islands
My understanding is it should work fine as the roots handle disposal. If you create the signal statically, there shouldn't be a problem, you can have memory leaks if you create them dynamically though without wrapping them in a createRoot. Please someone correct me if I'm wrong though!
3 replies
SSolidJS
Created by chiefcll on 9/23/2024 in #support
createResource with a nested source signal doesn't retrigger
You might want to try adding some logging, a few log statements for the resource source array accessor, the fetcher, and an effect on the startTime signal might make it clearer what is updating when. Apologies if you've already tried that, I just had a similar error and that helped me solve my own silly mistake 😃
7 replies