You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
I have an app that stores the result of createRestAPIClient (login in 5.x) in a React useState in order to then pass it through a React context. This all worked perfectly fine with masto.js 5.x. Unfortunately this seems to break with 6.x in weird ways I'm not sure I understand.
Hi @eramdam, sorry for the inconvenience. Starting from 6.x, we have introduced Proxy JavaScript API for the mastodon.Client object for reducing the bundle size.
Although it largely committed to lessening the size, the Client object itself no longer provides a clue for types or existence of its property at runtime. This means the following code can happen:
I suspect that the same thing is happening in this case. Since the second element in the return value of useState takes a function as well, the runtime code has no hints about whether the argument is a value or a closure.
const[count,setCount]=useState(0);// Both usage are validsetCount(1)setCount(k=>k+1)const[client,setClient]=useState(undefined)setCount(createRestAPIClient(...))// ^^^^^^^^^^^^^^^^^^^^^^^^^// React has no idea whether this is a function or a value
As a workaround, you can avoid the error by turning it into a verbose closure call
const[client,setClient]=useState(undefined)setCount(()=>createRestAPIClient(...))// ^^^^^^^^^^^^^^^^^^^^^// Wrap by a function that returns mastodon.Client
The current implementation with Proxy API is performant and robust, so there are currently no plans to get rid of it. However, it'd be better if we could provide more ergonomic experience with tools like React, at least provide more friendly error messages for unexpected calls. So please let me leave this issue open!
I have an app that stores the result of
createRestAPIClient
(login
in 5.x) in a ReactuseState
in order to then pass it through a React context. This all worked perfectly fine withmasto.js
5.x. Unfortunately this seems to break with 6.x in weird ways I'm not sure I understand.I have set up a repo with a minimal reproduction case to show the error
https://github.com/eramdam/masto.js-bug-repro
Triggers the following errors (most interesting is the
data:image/s3,"s3://crabby-images/9b577/9b5777eaa72f971472672ccd250e5514ae2cc227" alt="image"
/api
request that feels like shouldn't be happening)The text was updated successfully, but these errors were encountered: