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

Support react 19 #1448

Open
lu-perfect opened this issue Dec 12, 2024 · 11 comments
Open

Support react 19 #1448

lu-perfect opened this issue Dec 12, 2024 · 11 comments
Labels
enhancement New feature or request @kubb/react

Comments

@lu-perfect
Copy link

lu-perfect commented Dec 12, 2024

What is the problem this feature would solve?

Support react 19

External documents/projects?

No response

What is the feature you are proposing to solve the problem?

No response

What alternatives have you considered?

No response

@lu-perfect lu-perfect added the enhancement New feature or request label Dec 12, 2024
Copy link

linear bot commented Dec 12, 2024

KUBB-85 Support react 19

@stijnvanhulle
Copy link
Collaborator

@lu-perfect I had a try with the latest Kubb version(3.3.0, react-query and React 19), seems to work fine here. See https://www.kubb.dev/examples/tanstack-query/react-query

@Rikard-Johansson97
Copy link

@lu-perfect I had a try with the latest Kubb version(3.3.0, react-query and React 19), seems to work fine here. See https://www.kubb.dev/examples/tanstack-query/react-query

I get validation error when its running the 2/5 | plugin-oas: buildStart

ERROR Warning: Invalid hook call. Hooks can only be called inside of the body of a function component. This could happen for one of the following reasons:

  1. You might have mismatching versions of React and the renderer (such as React DOM)
  2. You might be breaking the Rules of Hooks
  3. You might have more than one copy of React in the same app
    See https://reactjs.org/link/invalid-hook-call for tips about how to debug and fix this problem. (repeated 2361 times)

@stijnvanhulle
Copy link
Collaborator

@Rikard-Johansson97 Could you provide me an example project or your package.json/kubb.config.ts?

@geirsagberg
Copy link

I am also getting an error:

Cannot read properties of undefined (reading 'ReactCurrentOwner')

    at $$$reconciler (node_modules/react-reconciler/cjs/react-reconciler.development.js:491:46)
    at node_modules/@kubb/react/src/kubbRenderer.ts:75:3
    at import (node_modules/jiti/dist/jiti.cjs:1:199710)
    at node_modules/@kubb/plugin-oas/dist/chunk-BAU7PO7T.js:1:195
    at import (node_modules/jiti/dist/jiti.cjs:1:199710)
    at node_modules/@kubb/plugin-oas/dist/chunk-WBHFV7C2.js:1:256
    at import (node_modules/jiti/dist/jiti.cjs:1:199710)
    at node_modules/@kubb/plugin-oas/dist/index.js:2:21
    at import (node_modules/jiti/dist/jiti.cjs:1:199710)
    at kubb.config.ts:2:18
    at Function.import (node_modules/jiti/dist/jiti.cjs:1:199710)
    at tsLoader (node_modules/@kubb/cli/src/utils/getCosmiConfig.ts:21:15)
    at Explorer.#loadConfiguration (node_modules/cosmiconfig/src/Explorer.ts:160:30)
    at Explorer.#loadConfigFileWithImports (node_modules/cosmiconfig/src/Explorer.ts:114:27)
    at Explorer.#readConfiguration (node_modules/cosmiconfig/src/Explorer.ts:105:7)
    at search (node_modules/cosmiconfig/src/Explorer.ts:61:28)
    at Explorer.search (node_modules/cosmiconfig/src/Explorer.ts:95:12)
    at getCosmiConfig (node_modules/@kubb/cli/src/utils/getCosmiConfig.ts:60:57)
    at Object.run (node_modules/@kubb/cli/src/commands/generate.ts:81:20)
    at runCommand (node_modules/citty/dist/index.mjs:316:16)
    at runCommand (node_modules/citty/dist/index.mjs:307:11)
    at runMain (node_modules/citty/dist/index.mjs:445:7)
    at run (node_modules/@kubb/cli/src/index.ts:49:3) 

Relates to this line in react-reconciler:

var ReactSharedInternals = React.__SECRET_INTERNALS_DO_NOT_USE_OR_YOU_WILL_BE_FIRED;

This has been renamed in React 19. Can be fixed like this: https://github.com/microsoft/use-disposable/pull/32/files#diff-5971f63da29997ff64996c0f14497c4756ed24cf15d181141ea6a8f9c8d7a376R6, in react-reconciler

@geirsagberg
Copy link

Seems to have been fixed in latest version of react-reconciler. So @kubb/react should probably update their version

@obrassard
Copy link

obrassard commented Dec 31, 2024

It does not seems to be exclusively realted to the TanstackQuery plugin, because I have the same issue even if I remove pluginTanstackQuery()

@Rikard-Johansson97
Copy link

Rikard-Johansson97 commented Jan 16, 2025

@stijnvanhulle


Environment:
I’m using the Kubb generator in React 19 (Next.js 15) within a large monorepo. My current setup includes:

"@kubb/cli": "3.5.1",
"@kubb/core": "3.5.1",
"@kubb/oas": "3.5.1",
"@kubb/plugin-client": "3.5.1",
"@kubb/plugin-oas": "3.5.1",
"@kubb/plugin-react-query": "3.5.1",
"@kubb/plugin-ts": "3.5.1",
"@kubb/plugin-zod": "3.5.1",
"@kubb/react": "3.5.1",

Configuration:
Here’s my configuration file:

import { defineConfig } from "@kubb/core";
import { pluginClient } from "@kubb/plugin-client";
import { pluginOas } from "@kubb/plugin-oas";
import { pluginReactQuery } from "@kubb/plugin-react-query";
import { pluginTs } from "@kubb/plugin-ts";
import { pluginZod } from "@kubb/plugin-zod";

export default defineConfig({
  input: {
    path: `${process.env.NEXT_PUBLIC_API_URL}/swagger/v1/swagger.json`,
  },
  root: ".",
  name: "@ssil/generated",
  output: {
    path: "./src",
    write: true,
    clean: true,
    extension: undefined,
    barrelType: "named",
  },
  hooks: {
    done: ["pnpm turbo run format --force --continue -- --write"],
  },
  plugins: [
    pluginOas({ validate: true }),
    pluginTs({
      unknownType: "unknown",
      enumSuffix: "",
      transformers: {
        name: (name) => `${name}Type`,
      },
    }),
    pluginClient({
      importPath: "@ssil/client/socio",
      pathParamsType: "object",
    }),
    pluginReactQuery({
      client: {
        dataReturnType: "data",
        importPath: "@ssil/client/socio",
      },
      suspense: {},
    }),
    pluginZod({
      unknownType: "unknown",
      coercion: true,
      typed: true,
    }),
  ],
});

Problem:
When running the generator, I encounter the following error:

[@ssil/generated 07:41:39] ERROR Warning: Invalid hook call. Hooks can only be called inside of the body of a function component. This could happen for one of the following reasons:
1. You might have mismatching versions of React and the renderer (such as React DOM).
2. You might be breaking the Rules of Hooks.
3. You might have more than one copy of React in the same app.

See https://reactjs.org/link/invalid-hook-call for tips about how to debug and fix this problem.

Temporary Fix:
I can resolve the issue by overriding the React version in the root package.json:

"pnpm": {
  "overrides": {
    "react": "18.2.0",
    "react-dom": "18.2.0"
  }
}

@stijnvanhulle
Copy link
Collaborator

@Rikard-Johansson97 I tried with your settings here but without any issues, see https://github.com/kubb-labs/test-next-15. Could you point me to what is different between my test and your project?

@Rikard-Johansson97
Copy link

@Rikard-Johansson97 I tried with your settings here but without any issues, see https://github.com/kubb-labs/test-next-15. Could you point me to what is different between my test and your project?

It's only see a plain next-15 project. Have you uncommitted changes?

@stijnvanhulle
Copy link
Collaborator

@Rikard-Johansson97 yes indeed, forgot to push latest changes

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request @kubb/react
Projects
None yet
Development

No branches or pull requests

5 participants