chore: update dependencies

- Replace `next lint` with `eslint .` (next lint removed in v16)
- Migrate to ESLint flat config format
- Fix React 19 purity errors in FeatureImage and TopFade components
- Update components for Next.js 16 compatibility
This commit is contained in:
Petri Partio
2025-12-02 10:29:11 +02:00
parent fa9a15fb68
commit 0db0e45239
10 changed files with 47 additions and 50 deletions

View File

@@ -1 +0,0 @@
out

BIN
bun.lockb

Binary file not shown.

View File

@@ -1,4 +1,5 @@
import Image from 'next/image'; import Image from 'next/image';
import { useId } from 'react';
export default function FeatureImage({ export default function FeatureImage({
src, src,
@@ -11,13 +12,16 @@ export default function FeatureImage({
height: number | `${number}`; height: number | `${number}`;
alt: string; alt: string;
}) { }) {
const id = useId();
const delay = (id.charCodeAt(1) % 5) + 0.5;
return ( return (
<div className="relative rounded-[18px] p-px shadow-2xl"> <div className="relative rounded-[18px] p-px shadow-2xl">
<div <div
className="fade-in-out absolute top-0 right-0 bottom-0 left-0 z-0 rounded-[17px] bg-linear-to-tr from-[#4d094e] to-pink-500/70 p-[2px]" className="fade-in-out absolute top-0 right-0 bottom-0 left-0 z-0 rounded-[17px] bg-linear-to-tr from-[#4d094e] to-pink-500/70 p-[2px]"
style={{ style={{
WebkitMask: 'linear-gradient(to bottom, rgba(0,0,0,1), rgba(0,0,0,0))', WebkitMask: 'linear-gradient(to bottom, rgba(0,0,0,1), rgba(0,0,0,0))',
animationDelay: `${Math.floor(Math.random() * 5) + 1 * 0.5}s`, animationDelay: `${delay}s`,
}} }}
></div> ></div>

View File

@@ -1,42 +1,23 @@
'use client'; 'use client';
import { useEffect, useState } from 'react'; import { useSyncExternalStore } from 'react';
const calculatedBrightnessValue = () => { const calculateBrightness = () => {
if (typeof window === 'undefined') return null;
if (window.scrollY > 200) return 0.5; if (window.scrollY > 200) return 0.5;
const amountToDecrease = (window.scrollY / 200) * 0.5; const amountToDecrease = (window.scrollY / 200) * 0.5;
return 1 - amountToDecrease; return 1 - amountToDecrease;
}; };
const subscribe = (callback: () => void) => {
document.addEventListener('scroll', callback, true);
return () => document.removeEventListener('scroll', callback, true);
};
const getSnapshot = () => calculateBrightness();
const getServerSnapshot = () => 1;
export default function TopFade() { export default function TopFade() {
const [brightness, setBrightness] = useState<number | null>(null); const brightness = useSyncExternalStore(subscribe, getSnapshot, getServerSnapshot);
useEffect(() => { return <div className="top-fade pointer-events-none" style={{ filter: `brightness(${brightness})` }}></div>;
// Always set correct value when first render on client side
setBrightness(calculatedBrightnessValue());
const handleScroll = (event: Event) => {
if (window.scrollY > 200 && brightness === 0.5) return;
setBrightness(calculatedBrightnessValue());
};
document.addEventListener('scroll', handleScroll, true);
return () => {
document.removeEventListener('scroll', handleScroll, true);
};
}, [brightness]);
return (
<div
className="top-fade pointer-events-none"
style={
brightness
? {
filter: `brightness(${brightness})`,
}
: {}
}
></div>
);
} }

5
eslint.config.mjs Normal file
View File

@@ -0,0 +1,5 @@
import nextConfig from 'eslint-config-next/core-web-vitals';
const eslintConfig = [...nextConfig, { ignores: ['out'] }];
export default eslintConfig;

1
next-env.d.ts vendored
View File

@@ -1,5 +1,6 @@
/// <reference types="next" /> /// <reference types="next" />
/// <reference types="next/image-types/global" /> /// <reference types="next/image-types/global" />
import "./.next/dev/types/routes.d.ts";
// NOTE: This file should not be edited // NOTE: This file should not be edited
// see https://nextjs.org/docs/app/api-reference/config/typescript for more information. // see https://nextjs.org/docs/app/api-reference/config/typescript for more information.

View File

@@ -6,30 +6,30 @@
"dev": "next dev", "dev": "next dev",
"build": "next build", "build": "next build",
"start": "next start", "start": "next start",
"lint": "next lint", "lint": "eslint .",
"prod": "NODE_ENV=production next build", "prod": "NODE_ENV=production next build",
"prettify": "prettier --write ." "prettify": "prettier --write ."
}, },
"dependencies": { "dependencies": {
"lodash.shuffle": "4.2.0", "lodash.shuffle": "4.2.0",
"next": "15.2.3", "next": "16.0.6",
"react": "19.0.0", "react": "19.2.0",
"react-confetti": "6.4.0", "react-confetti": "6.4.0",
"react-dom": "19.0.0" "react-dom": "19.2.0"
}, },
"devDependencies": { "devDependencies": {
"@tailwindcss/postcss": "4.0.15", "@tailwindcss/postcss": "4.1.17",
"@types/lodash.shuffle": "4.2.9", "@types/lodash.shuffle": "4.2.9",
"@types/node": "22.13.12", "@types/node": "24.10.1",
"@types/react": "19.0.12", "@types/react": "19.2.7",
"@types/react-dom": "19.0.4", "@types/react-dom": "19.2.3",
"eslint": "9.23.0", "eslint": "9.39.1",
"eslint-config-next": "15.2.3", "eslint-config-next": "16.0.6",
"postcss": "8.5.3", "postcss": "8.5.6",
"prettier": "3.5.3", "prettier": "3.7.3",
"prettier-plugin-tailwindcss": "0.6.11", "prettier-plugin-tailwindcss": "0.7.2",
"tailwindcss": "4.0.15", "tailwindcss": "4.1.17",
"typescript": "5.8.2" "typescript": "5.9.3"
}, },
"prettier": { "prettier": {
"printWidth": 120, "printWidth": 120,

Binary file not shown.

Before

Width:  |  Height:  |  Size: 91 KiB

After

Width:  |  Height:  |  Size: 94 KiB

Binary file not shown.

Before

Width:  |  Height:  |  Size: 87 KiB

After

Width:  |  Height:  |  Size: 97 KiB

View File

@@ -10,7 +10,7 @@
"moduleResolution": "bundler", "moduleResolution": "bundler",
"resolveJsonModule": true, "resolveJsonModule": true,
"isolatedModules": true, "isolatedModules": true,
"jsx": "preserve", "jsx": "react-jsx",
"incremental": true, "incremental": true,
"plugins": [ "plugins": [
{ {
@@ -22,6 +22,13 @@
}, },
"target": "ES2017" "target": "ES2017"
}, },
"include": ["types/global.d.ts", "next-env.d.ts", "**/*.ts", "**/*.tsx", ".next/types/**/*.ts"], "include": [
"types/global.d.ts",
"next-env.d.ts",
"**/*.ts",
"**/*.tsx",
".next/types/**/*.ts",
".next/dev/types/**/*.ts"
],
"exclude": ["node_modules"] "exclude": ["node_modules"]
} }