Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

🐛 BUG: Using preact/compat with solid-js leads to "Cannot read properties of null (reading 'useRef')" #4093

Closed
1 task
mayank99 opened this issue Jul 29, 2022 · 6 comments · Fixed by #4213
Assignees
Labels
- P4: important Violate documented behavior or significantly impacts performance (priority)

Comments

@mayank99
Copy link
Contributor

What version of astro are you using?

1.0.0-rc.1

Are you using an SSR adapter? If so, which one?

None

What package manager are you using?

npm

What operating system are you using?

Windows

Describe the Bug

See linked stackblitz. Using client:load causes the solid-js adapter to mess with preact components. Using client:only makes the error go away.

I've also seen other variations of this issue, e.g. the react adapter sometimes messes with solid-js components. Will update this issue with more links (or create a new one) if I bump into that again.

Link to Minimal Reproducible Example

https://stackblitz.com/edit/github-bltmyz?file=src%2Fpages%2Findex.astro

Participation

  • I am willing to submit a pull request for this issue.
@matthewp matthewp added - P4: important Violate documented behavior or significantly impacts performance (priority) s2-medium labels Jul 29, 2022
@matthewp matthewp self-assigned this Jul 29, 2022
@matthewp
Copy link
Contributor

matthewp commented Aug 3, 2022

I think this isn't directly related to Solid and is an issue with preact/compat and the downshift. Will report back after I investigate more.

@matthewp
Copy link
Contributor

matthewp commented Aug 4, 2022

Made a little bit of progress here: https://github.com/withastro/astro/tree/preact-compat-issue

Going to chat with @bluwy about this. The issues I'm running into are:

  • SSR seems to transform node_modules/preact/compat/dist/compat.module.js incorrectly, I think because it contains an import statement and an export from statement about the same module.

Here is my forked stackblitz: https://stackblitz.com/edit/github-bltmyz-5rgtvb?file=astro.config.mjs


Steps to get to where I left off:

  1. Download the stackblitz project locally.
  2. npm install
  3. Add the changes from https://github.com/withastro/astro/commit/d453f976dbb09cc8371783403f4fed38ee944115 to your local node_modules/@astrojs/preact/dist/index.js
  4. npm start
  5. Should see some error about __vite_ssr_import_1__ or something. This is a bug in Vite (I think).
    • this bug needs to be fixed to proceed. I think it's related to the fact that the module imports and exports from the same module.
  6. node --inspect-brk node_modules/.bin/astro dev will get you to a debugger.

@mayank99
Copy link
Contributor Author

mayank99 commented Aug 4, 2022

Oh that's super interesting. I think I got confused by the original error message because it says @astrojs/solid-js.

Does preact/compat not have full compatibility with all react (<18) packages?

Also, if solid-js is eliminated, does that make this issue a duplicate of #4107? Different package there, similar problem.

@matthewp
Copy link
Contributor

matthewp commented Aug 4, 2022

I'm sure that preact/compat is not compatible with all React packages, that's an impossible ask. But I don't yet know if its compatible with this one or not, there's an underlying bug we have to fix first.

#4107 could be the same issue, assigning it to myself until we figure this one out.

@bluwy
Copy link
Member

bluwy commented Aug 5, 2022

I managed to trim down the issue to Vite's SSR transform, which incorrectly transforms:

export * from 'vue'
import {createApp} from 'vue'
export {createApp as bar}

to

const __vite_ssr_import_1__ = await __vite_ssr_import__("vue");
__vite_ssr_exportAll__(__vite_ssr_import_1__);
Object.defineProperty(__vite_ssr_exports__, "bar", { enumerable: true, configurable: true, get(){ return __vite_ssr_import_0__.createApp }});

Note the __vite_ssr_import_0__ does not exists. I'll try to send a fix in Vite.

@bluwy
Copy link
Member

bluwy commented Aug 8, 2022

Note: This should be good when vitejs/vite#9554 is released and the Vite version used by Astro is bumped (currently pinned). And also a combination of the fix in this branch.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
- P4: important Violate documented behavior or significantly impacts performance (priority)
Projects
None yet
Development

Successfully merging a pull request may close this issue.

3 participants