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

chore(deps): Migrate to react 19 #15358

Open
wants to merge 53 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 25 commits
Commits
Show all changes
53 commits
Select commit Hold shift + click to select a range
908d9af
fix(deps): update react monorepo to v19
renovate[bot] Jan 3, 2025
c597643
update Combobox
0xTxbi Jan 3, 2025
9dfc172
update Button
0xTxbi Jan 3, 2025
f35b475
update ui package.json
0xTxbi Jan 3, 2025
5839d6f
update ui vite config
0xTxbi Jan 3, 2025
c60d2ef
update ui react entry file
0xTxbi Jan 3, 2025
4f051d4
update yarn.lock
0xTxbi Jan 3, 2025
1514e02
update static site
0xTxbi Jan 6, 2025
a08f4e4
Merge branch 'master' into react-19-upgrade
julien51 Jan 6, 2025
cfe7145
fix return
0xTxbi Jan 6, 2025
cfd0592
update combobox
0xTxbi Jan 6, 2025
21d4400
Merge branch 'master' into react-19-upgrade
0xTxbi Jan 6, 2025
5d9762d
Merge branch 'master' into react-19-upgrade
0xTxbi Jan 9, 2025
3440d12
Merge branch 'master' into react-19-upgrade
0xTxbi Jan 9, 2025
de8d760
update ui package.json
0xTxbi Jan 9, 2025
aa75f0e
remove redundant tests
0xTxbi Jan 20, 2025
ab24e80
remove redundant components
0xTxbi Jan 20, 2025
c3f4876
update test
0xTxbi Jan 20, 2025
e0f4952
update yarn.lock
0xTxbi Jan 20, 2025
62dfef7
Merge branch 'master' into react-19-upgrade
0xTxbi Jan 20, 2025
8a16735
update package.json
0xTxbi Jan 20, 2025
b04d0d4
update yarn.lock
0xTxbi Jan 20, 2025
cb888bd
fix unused directives
0xTxbi Jan 20, 2025
9cc6d43
update recaptcha usage
0xTxbi Jan 20, 2025
e88937d
update useref usage
0xTxbi Jan 20, 2025
dd37f71
Revert "fix unused directives"
0xTxbi Jan 31, 2025
da635ea
Revert "update recaptcha usage"
0xTxbi Jan 31, 2025
e4509e2
Revert "update useref usage"
0xTxbi Jan 31, 2025
4f9218a
unpin deps
0xTxbi Jan 31, 2025
ad2422c
Merge branch 'master' into react-19-upgrade
0xTxbi Jan 31, 2025
fcf131e
update ui components wip
0xTxbi Jan 31, 2025
92103b0
Merge branch 'master' into react-19-upgrade
0xTxbi Feb 27, 2025
dccf93a
update yarn.lock
0xTxbi Feb 27, 2025
44d9ccd
update package.json
0xTxbi Feb 27, 2025
fcde6f9
fix headless ui type errors
0xTxbi Feb 27, 2025
8c6185c
Merge branch 'master' into react-19-upgrade
0xTxbi Feb 27, 2025
c1812e2
update Placeholder
0xTxbi Feb 27, 2025
8c50e67
update Placeholder
0xTxbi Feb 27, 2025
4fd51a8
improve cryptoicon package build
0xTxbi Feb 28, 2025
6fb1ae7
update cryptoicon package build
0xTxbi Feb 28, 2025
9f74c67
update cryptoicon
0xTxbi Feb 28, 2025
3c996a7
update ui package build
0xTxbi Feb 28, 2025
b6556af
update ui package components
0xTxbi Feb 28, 2025
bdd8661
unlock-app type fixes
0xTxbi Feb 28, 2025
6be3ca6
update unlock-app package.json
0xTxbi Feb 28, 2025
0baa5fe
update yarn.lock
0xTxbi Feb 28, 2025
89c21ae
ui package build update
0xTxbi Feb 28, 2025
30c0d49
ui package build update
0xTxbi Feb 28, 2025
34cd426
unlock-app react types update
0xTxbi Feb 28, 2025
483338a
more unlock-app typescript fixes
0xTxbi Feb 28, 2025
79f3e82
update yarn.lock
0xTxbi Feb 28, 2025
5a1920d
update crypto-icon package
0xTxbi Feb 28, 2025
13bcd81
update yarn.lock
0xTxbi Feb 28, 2025
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions docs/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@
"docusaurus-theme-openapi-docs": "4.3.1",
"ethers": "6.13.4",
"prism-react-renderer": "2.4.1",
"react": "18.3.1",
"react-dom": "18.3.1",
"react": "19.0.0",
"react-dom": "19.0.0",
"react-icons": "5.4.0"
},
"scripts": {
Expand Down
2 changes: 1 addition & 1 deletion locksmith/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -82,7 +82,7 @@
"pdfmake": "0.2.17",
"pg": "8.13.1",
"rate-limiter-flexible": "5.0.4",
"react": "18.3.1",
"react": "19.0.0",
"remark-html": "16.0.1",
"remark-parse": "11.0.0",
"satori": "0.12.0",
Expand Down
12 changes: 6 additions & 6 deletions packages/crypto-icon/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -21,8 +21,8 @@
"build-storybook": "storybook build"
},
"peerDependencies": {
"react": "18.3.1",
"react-dom": "18.3.1"
"react": "19.0.0",
"react-dom": "19.0.0"
},
"repository": {
"type": "git",
Expand All @@ -36,11 +36,11 @@
"@storybook/addon-links": "8.4.7",
"@storybook/react": "8.4.7",
"@storybook/react-vite": "8.4.7",
"@types/react": "18.3.18",
"@types/react-dom": "18.3.5",
"@types/react": "19.0.2",
"@types/react-dom": "19.0.2",
"@vitejs/plugin-react": "4.3.4",
"react": "18.3.1",
"react-dom": "18.3.1",
"react": "19.0.0",
"react-dom": "19.0.0",
"storybook": "8.4.7",
"tsup": "8.3.5",
"tsx": "4.19.2",
Expand Down
12 changes: 7 additions & 5 deletions packages/ui/lib/components/Button/Button.tsx
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import type { ReactNode, ForwardedRef } from 'react'
import type { ReactNode } from 'react'
import type { SizeStyleProp } from '../../types'
import { twMerge } from 'tailwind-merge'
import { forwardRef } from 'react'
Expand Down Expand Up @@ -45,8 +45,8 @@ const VARIANTS_STYLES: Record<Variant, string> = {
'bg-transparent text-black transition ease-in-out duration-300 text-brand-ui-primary disabled:text-brand-gray disabled:hover:text-brand-gray disabled:hover:bg-opacity-75 font-medium p-0',
}

export const Button = forwardRef(
(props: Props, ref: ForwardedRef<HTMLButtonElement>) => {
export const Button = forwardRef<HTMLButtonElement, Props>(
function Button(props, ref) {
let {
children,
size = 'medium',
Expand Down Expand Up @@ -84,14 +84,16 @@ export const Button = forwardRef(
<Icon
icon={SpinnerIcon}
size={size}
className="animate-spin motion-reduce:invisible "
className="animate-spin motion-reduce:invisible"
/>
) : (
iconLeft
)}
<span> {children}</span>
{children && <span>{children}</span>}
{!loading && iconRight}
</Box>
)
}
)

Button.displayName = 'Button'
12 changes: 7 additions & 5 deletions packages/ui/lib/components/Form/Combobox.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -354,7 +354,9 @@ export function Combobox({
{displayedOptions.map((option, index) => (
<li
key={`${option.value}-${index}`}
ref={(el) => (optionsRef.current[index] = el)}
ref={(el) => {
optionsRef.current[index] = el
}}
className={clsx(
'flex cursor-pointer mx-2 rounded-sm items-center gap-2 py-2 px-3 text-base min-w-0',
'hover:bg-ui-main-50',
Expand Down Expand Up @@ -402,10 +404,10 @@ export function Combobox({
query === '' &&
moreOptions.length > 0 && (
<li
ref={(el) =>
(optionsRef.current[displayedOptions.length] =
el)
}
ref={(el) => {
optionsRef.current[displayedOptions.length] =
el
}}
className={clsx(
'flex cursor-pointer mx-2 rounded-sm items-center justify-center gap-2 py-3 px-3 text-base font-semibold min-w-0',
'hover:bg-ui-main-50 text-brand-ui-primary',
Expand Down
31 changes: 21 additions & 10 deletions packages/ui/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -11,16 +11,22 @@
".": {
"types": "./dist/index.d.ts",
"import": "./dist/index.es.js",
"require": "./dist/index.umd.js"
"require": "./dist/index.umd.js",
"default": "./dist/index.es.js"
},
"./dist/style.css": {
"import": "./dist/style.css",
"require": "./dist/style.css"
"require": "./dist/style.css",
"default": "./dist/style.css"
},
"./dist/unlock-tailwind-preset": {
"require": "./dist/unlock-tailwind-preset.js"
"require": "./dist/unlock-tailwind-preset.js",
"default": "./dist/unlock-tailwind-preset.js"
}
},
"sideEffects": [
"**/*.css"
],
"version": "0.4.8",
"scripts": {
"preview": "yarn build && vite --config ./vite.config.ts src",
Expand All @@ -47,9 +53,14 @@
"tailwindcss": "3.4.17"
},
"peerDependencies": {
"@headlessui/react": "2.2.0",
"react": "18.3.1",
"react-dom": "18.3.1"
"@headlessui/react": "^2.2.0",
"react": "^19.0.0",
"react-dom": "^19.0.0"
},
"peerDependenciesMeta": {
"@headlessui/react": {
"optional": true
}
},
"repository": {
"type": "git",
Expand All @@ -65,14 +76,14 @@
"@storybook/addon-links": "8.4.7",
"@storybook/react": "8.4.7",
"@storybook/react-vite": "8.4.7",
"@types/react": "18.3.18",
"@types/react-dom": "18.3.5",
"@types/react": "19.0.2",
"@types/react-dom": "19.0.2",
"@unlock-protocol/unlock-js": "workspace:./packages/unlock-js",
"@vitejs/plugin-react": "4.3.4",
"autoprefixer": "10.4.20",
"postcss": "8.4.49",
"react": "18.3.1",
"react-dom": "18.3.1",
"react": "19.0.0",
"react-dom": "19.0.0",
"storybook": "8.4.7",
"tailwindcss": "3.4.17",
"tsup": "8.3.5",
Expand Down
2 changes: 1 addition & 1 deletion packages/ui/src/main.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import React from 'react'
import { createRoot } from 'react-dom/client'
import { Button } from './..'
import { Button } from '../lib/components/Button/Button'
import '../dist/style.css'

function App() {
Expand Down
45 changes: 42 additions & 3 deletions packages/ui/vite.config.ts
Original file line number Diff line number Diff line change
Expand Up @@ -22,28 +22,67 @@ export default defineConfig({
entry: path.resolve(__dirname, 'lib/index.tsx'),
name: '@unlock-protocol/ui',
fileName: (format) => `index.${format}.js`,
formats: isCDN ? ['umd'] : ['es'],
},
rollupOptions: {
external: isCDN ? Object.keys(peerDependencies) : external,
external: [
...(isCDN ? Object.keys(peerDependencies) : external),
'react/jsx-runtime',
],
shimMissingExports: true,
output: {
globals: {
react: 'React',
'react-dom': 'ReactDOM',
'react/jsx-runtime': 'jsxRuntime',
},
assetFileNames: (assetInfo) => {
if (assetInfo.name?.endsWith('.css')) {
return 'style.css'
}
// Return a default name if assetInfo.name is undefined
return assetInfo.name ?? 'asset'
},
exports: 'named',
...(isCDN
? {}
: {
preserveModules: true,
preserveModulesRoot: 'lib',
format: 'es',
}),
},
},
sourcemap: true,
commonjsOptions: {
include: [/node_modules/],
requireReturnsDefault: 'auto',
},
},
plugins: [
tsconfigPaths(),
react(),
react({
jsxRuntime: 'automatic',
jsxImportSource: 'react',
babel: {
plugins: [
['@babel/plugin-transform-react-jsx', { runtime: 'automatic' }],
],
},
}),
svgr(),
nodePolyfills({
protocolImports: true,
}),
],
resolve: {
alias: {
'@': path.resolve(__dirname, './lib'),
},
},
optimizeDeps: {
include: ['react', 'react-dom'],
esbuildOptions: {
target: 'es2020',
},
},
})
8 changes: 4 additions & 4 deletions unlock-app/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,8 +3,8 @@
"version": "0.1.0",
"private": true,
"peerDependencies": {
"react": "18.3.1",
"react-dom": "18.3.1"
"react": "19.0.0",
"react-dom": "19.0.0"
},
"dependencies": {
"@airstack/airstack-react": "0.6.4",
Expand Down Expand Up @@ -77,7 +77,7 @@
"@types/file-saver": "2.0.7",
"@types/postmate": "1.5.4",
"@types/qrcode.react": "1.0.5",
"@types/react": "18.3.18",
"@types/react": "19.0.2",
"@types/react-google-recaptcha": "2.1.9",
"@types/react-gtm-module": "2.0.4",
"@types/remove-markdown": "0.3.4",
Expand All @@ -86,7 +86,7 @@
"autoprefixer": "10.4.20",
"jsdom": "25.0.1",
"postcss": "8.4.49",
"react-test-renderer": "18.3.1",
"react-test-renderer": "19.0.0",
"tailwindcss": "3.4.17",
"vitest": "2.1.8",
"vitest-fetch-mock": "0.4.3",
Expand Down
53 changes: 0 additions & 53 deletions unlock-app/src/__tests__/components/page/TwitterTags.test.jsx

This file was deleted.

61 changes: 0 additions & 61 deletions unlock-app/src/__tests__/components/page/opengraph.test.jsx

This file was deleted.

Loading
Loading