44 Replies
hey! yeah, the issue is that
parcel._id
is a special Id
class, not a plain string. when you put it into the URL with string substitution, it calls Id.toString()
on it.
so, what you can do is...
(assuming the name of the table is "parcels")
lmk if that workswhat do I import for Id?
for if im not using TS
ok figured it out
data:image/s3,"s3://crabby-images/f06e3/f06e3c26fe1361214c15a060031a184a5f5b7600" alt="No description"
im getting this error now
data:image/s3,"s3://crabby-images/6eb75/6eb75f254542479d80b4636d908102ad8755da03" alt="No description"
get parcel looks like this
ah, okay! so you need to change your URL to
same issue
huh, can you
console.log(idString)
and see what it's printing out?
before the useQuery
data:image/s3,"s3://crabby-images/6eb9c/6eb9cfa25aed6008dd31b3011982555331cd2d7c" alt="No description"
What are you importing to create your Id? There should be a class in
convex/_generated/dataModel.js
I believedata:image/s3,"s3://crabby-images/7bc1a/7bc1a17d3f0b87b4e6c66f2be40d40ef1076e8c4" alt="No description"
yep
also, I think changing it to
should work
(i thought
useParams
returns a string but it's actually an object ^^)yep, it works
thank you!
lifesaver
Yeah sorry -- I assumed you were printing the
Id
and not the useParams
. Glad everything's working now 🎉@sujayakar this is printing out undefined
data:image/s3,"s3://crabby-images/66eba/66ebae60d3c6d41f4746ce9149550c2adc2c9ce6" alt="No description"
for both items
data:image/s3,"s3://crabby-images/ac5d1/ac5d128c01b8be5ecdda0de5d09a22077e2fe8c5" alt="No description"
but these fields exist in my database
useQuery will return undefined on the initial render. After the query finishes executing, it will trigger a rerender that should have the result of the query
it appears to always show undefined
can you
console.log(parcel)
?data:image/s3,"s3://crabby-images/a5fa7/a5fa7752bddb6684ba272abd381480a834347b3b" alt="No description"
here is full code
data:image/s3,"s3://crabby-images/108a5/108a5752bd1fc9ce9662633239e6e1bcd5211528" alt="No description"
ah and actually doing something like
would help too
I wonder if we didn't recreate the
Id
correctly, which then means that db.get
is always returning null
data:image/s3,"s3://crabby-images/5f83f/5f83f84928f3395dd7e7cc0f59c4f97895af2db6" alt="No description"
cool. if you go to the dashboard for your deployment, do you see the
getParcels:getParcel
call in the logs view?yeah, latest from 5:34AM
Even if db.get were returning null, queryResult would only be undefined before the query has finished executing. Makes me think something is getting in the way of the rerender
Yeah I would perhaps try commenting out everything except the
useQuery
and console.log
s in my component and see if a re-render gives us the right resulteverything deleted
still shows up null
oh
i think i found the error
its parcel not parcels
mb
ahh nice! works now?
ok works when theres no react components rendering
but not when i add in the return
Is it possible that on the first render, when useQuery returns undefined, the undefined value makes the component throw an exception, so the rerender never happens?
possibly, but how do I fix it?
can you paste the rest of the component code? after the
useQuery
In my convex apps i sometimes do something like
if (queryResult === undefined) { return <div>Loading...</div> }
doesnt work for me
data:image/s3,"s3://crabby-images/2d0d5/2d0d5a8aac2d1219c3986144aa325f9a326e5b13" alt="No description"
fixed
thanks
(was going to tell you to remove the
|| {}
but looks like you figured it out!)