diff --git a/packages/repack/src/loaders/assetsLoader/__tests__/assetsLoader.test.ts b/packages/repack/src/loaders/assetsLoader/__tests__/assetsLoader.test.ts deleted file mode 100644 index 07a27624a..000000000 --- a/packages/repack/src/loaders/assetsLoader/__tests__/assetsLoader.test.ts +++ /dev/null @@ -1,356 +0,0 @@ -import fs from 'node:fs'; -import path from 'node:path'; -import vm from 'node:vm'; -import { rspack } from '@rspack/core'; -import memfs from 'memfs'; -import { RspackVirtualModulePlugin } from 'rspack-plugin-virtual-module'; -import { - getAssetExtensionsRegExp, - getResolveOptions, -} from '../../../utils/index.js'; - -function loadFixtures(...filenames: string[]) { - return filenames - .map((filename: string) => { - const localPath = path.join(__dirname, '__fixtures__', filename); - const assetPath = `./__fixtures__/${filename}`; - const assetData = fs.readFileSync(localPath); - return [assetPath, assetData] as const; - }) - .reduce( - (acc, [assetPath, assetData]) => { - acc[assetPath] = assetData; - return acc; - }, - {} as Record - ); -} - -async function compileBundle( - platform: string, - virtualModules: Record, - inline?: boolean, - remote?: { - enabled: boolean; - assetPath?: (args: { - resourcePath: string; - resourceFilename: string; - resourceDirname: string; - resourceExtensionType: string; - }) => string; - publicPath: string; - } -) { - const compiler = rspack({ - context: __dirname, - mode: 'development', - devtool: false, - entry: './index.js', - resolve: getResolveOptions(platform), - output: { - path: '/out', - library: 'Export', - }, - module: { - rules: [ - { - test: getAssetExtensionsRegExp(), - use: { - loader: require.resolve('../assetsLoader'), - options: { - platform, - inline, - remote, - }, - }, - }, - ], - }, - plugins: [ - new RspackVirtualModulePlugin({ - 'package.json': '{ "type": "module" }', - 'node_modules/react-native/package.json': - '{ "name": "react-native", "main": "./index.js" }', - 'node_modules/react-native/index.js': - 'module.exports = { PixelRatio: { get: () => 1 } };', - 'node_modules/react-native/Libraries/Image/AssetRegistry.js': - 'module.exports = { registerAsset: (spec) => spec };', - 'node_modules/react-native/Libraries/Image/AssetSourceResolver.js': ` - module.exports = class AssetSourceResolver { - constructor(a, b, c) { - this.asset = c; - } - scaledAssetPath() { - var scale = require('react-native').PixelRatio.get(); - var scaleSuffix = scale === 1 ? '' : '@x' + scale; - return { - __packager_asset: true, - width: this.asset.width, - height: this.asset.height, - uri: this.asset.httpServerLocation + '/' + this.asset.name + scaleSuffix + '.' + this.asset.type, - scale: scale, - }; - } - static pickScale(scales, pixelRatio) { - return scales[pixelRatio - 1]; - } - };`, - ...virtualModules, - }), - ], - }); - - const volume = new memfs.Volume(); - const fileSystem = memfs.createFsFromVolume(volume); - // @ts-expect-error memfs is compatible enough - compiler.outputFileSystem = fileSystem; - - return await new Promise<{ - code: string; - fileSystem: typeof memfs.fs; - volume: typeof memfs.vol; - }>((resolve, reject) => - compiler.run((error) => { - if (error) { - reject(error); - } else { - resolve({ - code: fileSystem.readFileSync('/out/main.js', 'utf-8') as string, - fileSystem, - volume, - }); - } - }) - ); -} - -describe('assetLoader', () => { - const fixtures = loadFixtures( - 'logo.png', - 'star@1x.png', - 'star@2x.png', - 'star@3x.png' - ); - - describe.each(['ios', 'android'])('on %s', (platform) => { - it('should load and extract asset without scales', async () => { - const { code, volume } = await compileBundle(platform, { - ...fixtures, - './index.js': "export { default } from './__fixtures__/logo.png';", - }); - - const context: { Export?: { default: Record } } = {}; - vm.runInNewContext(code, context); - - expect(context.Export?.default).toMatchSnapshot(); - expect(volume.toTree()).toMatchSnapshot(); - }); - - it('should load and extract asset with scales', async () => { - const { code, volume } = await compileBundle(platform, { - ...fixtures, - './index.js': "export { default } from './__fixtures__/star.png';", - }); - - const context: { Export?: { default: Record } } = {}; - vm.runInNewContext(code, context); - - expect(context.Export?.default).toMatchSnapshot(); - expect(volume.toTree()).toMatchSnapshot(); - }); - - it('should prefer platform specific asset', async () => { - const platformFixtures = loadFixtures('logo.png', `logo.${platform}.png`); - const { code, volume } = await compileBundle(platform, { - ...platformFixtures, - './index.js': "export { default } from './__fixtures__/logo.png';", - }); - - const context: { Export?: { default: Record } } = {}; - vm.runInNewContext(code, context); - - expect(context.Export?.default).toMatchSnapshot(); - expect(volume.toTree()).toMatchSnapshot(); - }); - }); - - describe('should inline asset', () => { - it('without scales', async () => { - const { code, volume } = await compileBundle( - 'android', - { - ...fixtures, - './index.js': "export { default } from './__fixtures__/logo.png';", - }, - true - ); - - const context: { Export?: { default: Record } } = {}; - vm.runInNewContext(code, context); - - expect(context.Export?.default).toMatchSnapshot(); - expect(volume.toTree()).toMatchSnapshot(); - }); - - it.each([ - { - prefferedScale: 1, - }, - { - prefferedScale: 2, - }, - { - prefferedScale: 3, - }, - ])('with scales ($prefferedScale)', async ({ prefferedScale }) => { - const { code, volume } = await compileBundle( - 'android', - { - ...fixtures, - 'node_modules/react-native/index.js': `module.exports = { PixelRatio: { get: () => ${prefferedScale} } };`, - './index.js': "export { default } from './__fixtures__/star.png';", - }, - true - ); - - const context: { Export?: { default: Record } } = {}; - vm.runInNewContext(code, context); - - expect(context.Export?.default).toMatchSnapshot(); - expect(volume.toTree()).toMatchSnapshot(); - }); - }); - - describe('should convert to remote-asset', () => { - it('without scales', async () => { - const { code, volume } = await compileBundle( - 'ios', // platform doesn't matter for remote-assets - { - ...fixtures, - './index.js': "export { default } from './__fixtures__/logo.png';", - }, - false, - { - enabled: true, - publicPath: 'http://localhost:9999', - } - ); - - const context: { Export?: { default: Record } } = {}; - vm.runInNewContext(code, context); - - expect(context.Export?.default).toMatchSnapshot(); - expect(volume.toTree()).toMatchSnapshot(); - }); - - it.each([ - { prefferedScale: 1 }, - { prefferedScale: 2 }, - { prefferedScale: 3 }, - ])('with scales $prefferedScale', async ({ prefferedScale }) => { - const { code, volume } = await compileBundle( - 'ios', // platform doesn't matter for remote-assets - { - ...fixtures, - 'node_modules/react-native/index.js': `module.exports = { PixelRatio: { get: () => ${prefferedScale} } };`, - './index.js': "export { default } from './__fixtures__/star.png';", - }, - false, - { - enabled: true, - publicPath: 'http://localhost:9999', - } - ); - - const context: { Export?: { default: Record } } = {}; - vm.runInNewContext(code, context); - - expect(context.Export?.default).toMatchSnapshot(); - expect(volume.toTree()).toMatchSnapshot(); - }); - - it('with URL containing a path after basename', async () => { - const { code, volume } = await compileBundle( - 'ios', // platform doesn't matter for remote-assets - { - ...fixtures, - './index.js': "export { default } from './__fixtures__/logo.png';", - }, - false, - { - enabled: true, - publicPath: 'http://localhost:9999/remote-assets', - } - ); - - const context: { Export?: { default: Record } } = {}; - vm.runInNewContext(code, context); - - expect(context.Export?.default).toMatchSnapshot(); - expect(volume.toTree()).toMatchSnapshot(); - }); - - describe('with specified assetPath', () => { - it('without scales', async () => { - const { code, volume } = await compileBundle( - 'ios', // platform doesn't matter for remote-assets - { - ...fixtures, - './index.js': "export { default } from './__fixtures__/logo.png';", - }, - false, - { - enabled: true, - assetPath: ({ - resourceFilename, - resourceDirname, - resourceExtensionType, - }) => { - return `${resourceDirname}/nested-folder/${resourceFilename}-fake-hash.${resourceExtensionType}`; - }, - publicPath: 'http://localhost:9999/remote-assets', - } - ); - - const context: { Export?: { default: Record } } = {}; - vm.runInNewContext(code, context); - - expect(context.Export?.default).toMatchSnapshot(); - expect(volume.toTree()).toMatchSnapshot(); - }); - - it.each([ - { prefferedScale: 1 }, - { prefferedScale: 2 }, - { prefferedScale: 3 }, - ])('with scales $prefferedScale', async ({ prefferedScale }) => { - const { code, volume } = await compileBundle( - 'ios', // platform doesn't matter for remote-assets - { - ...fixtures, - 'node_modules/react-native/index.js': `module.exports = { PixelRatio: { get: () => ${prefferedScale} } };`, - './index.js': "export { default } from './__fixtures__/star.png';", - }, - false, - { - enabled: true, - assetPath: ({ - resourceFilename, - resourceDirname, - resourceExtensionType, - }) => { - return `${resourceDirname}/nested-folder/${resourceFilename}-fake-hash.${resourceExtensionType}`; - }, - publicPath: 'http://localhost:9999', - } - ); - - const context: { Export?: { default: Record } } = {}; - vm.runInNewContext(code, context); - - expect(context.Export?.default).toMatchSnapshot(); - expect(volume.toTree()).toMatchSnapshot(); - }); - }); - }); -}); diff --git a/packages/repack/src/types/runtime-globals.d.ts b/packages/repack/src/types/runtime-globals.d.ts index 611945be2..8b6c03c55 100644 --- a/packages/repack/src/types/runtime-globals.d.ts +++ b/packages/repack/src/types/runtime-globals.d.ts @@ -104,6 +104,8 @@ declare var __webpack_hash__: string; declare var __repack__: RepackRuntimeGlobals.RepackRuntimeObject; declare var __webpack_require__: RepackRuntimeGlobals.WebpackRequire; -declare interface NodeModule { - hot?: RepackRuntimeGlobals.HotApi; +declare namespace NodeJS { + interface Module { + hot?: RepackRuntimeGlobals.HotApi; + } } diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index 5fdb19b9b..8ac14166e 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -16,8 +16,8 @@ catalogs: specifier: ~0.5.17 version: 0.5.17 '@types/node': - specifier: ^20 - version: 20.14.11 + specifier: ^20.19.31 + version: 20.19.31 react: specifier: 19.1.0 version: 19.1.0 @@ -31,8 +31,8 @@ catalogs: specifier: ^5.8.3 version: 5.8.3 vitest: - specifier: ^2.0.5 - version: 2.0.5 + specifier: ^4.0.18 + version: 4.0.18 webpack: specifier: ^5.99.9 version: 5.100.2 @@ -234,7 +234,7 @@ importers: version: 5.8.3 vitest: specifier: 'catalog:' - version: 2.0.5(@types/node@20.14.11)(lightningcss@1.28.2)(terser@5.31.3) + version: 4.0.18(@types/node@20.19.31)(jiti@2.6.1)(lightningcss@1.28.2)(terser@5.31.3)(yaml@2.8.2) webpack: specifier: 'catalog:' version: 5.100.2(@swc/core@1.13.3(@swc/helpers@0.5.17)) @@ -438,7 +438,7 @@ importers: version: 7.0.6 '@types/node': specifier: 'catalog:' - version: 20.14.11 + version: 20.19.31 '@types/ws': specifier: ^8.18.0 version: 8.18.0 @@ -466,7 +466,7 @@ importers: version: 0.6.3(typescript@5.8.3) '@types/node': specifier: 'catalog:' - version: 20.14.11 + version: 20.19.31 '@types/semver': specifier: ^7.5.8 version: 7.5.8 @@ -511,7 +511,7 @@ importers: version: 1.6.0(@swc/helpers@0.5.18) '@types/node': specifier: 'catalog:' - version: 20.14.11 + version: 20.19.31 webpack: specifier: 'catalog:' version: 5.100.2(@swc/core@1.13.3) @@ -533,7 +533,7 @@ importers: version: 0.7.2 '@types/node': specifier: 'catalog:' - version: 20.14.11 + version: 20.19.31 nativewind: specifier: ^4.1.23 version: 4.1.23(react-native-reanimated@4.0.0(@babel/core@7.25.2)(react-native-worklets@0.4.0(@babel/core@7.25.2)(react-native@0.81.0(@babel/core@7.25.2)(@react-native-community/cli@20.0.0(typescript@5.8.3))(@types/react@19.1.8)(react@19.2.4))(react@19.2.4))(react-native@0.81.0(@babel/core@7.25.2)(@react-native-community/cli@20.0.0(typescript@5.8.3))(@types/react@19.1.8)(react@19.2.4))(react@19.2.4))(react-native@0.81.0(@babel/core@7.25.2)(@react-native-community/cli@20.0.0(typescript@5.8.3))(@types/react@19.1.8)(react@19.2.4))(react@19.2.4)(tailwindcss@3.4.17) @@ -561,7 +561,7 @@ importers: version: 7.20.5 '@types/node': specifier: 'catalog:' - version: 20.14.11 + version: 20.19.31 '@types/semver': specifier: ^7.7.0 version: 7.7.0 @@ -691,7 +691,7 @@ importers: version: 2.1.4 '@types/node': specifier: 'catalog:' - version: 20.14.11 + version: 20.19.31 '@types/react-dom': specifier: ^17.0.7 version: 17.0.25 @@ -709,7 +709,7 @@ importers: version: 1.8.0 jest: specifier: ^29.7.0 - version: 29.7.0(@types/node@20.14.11) + version: 29.7.0(@types/node@20.19.31) react: specifier: 'catalog:' version: 19.1.0 @@ -726,6 +726,33 @@ importers: specifier: 'catalog:' version: 5.100.2(@swc/core@1.13.3) + tests/integration: + devDependencies: + '@callstack/repack': + specifier: workspace:* + version: link:../../packages/repack + '@rspack/core': + specifier: 'catalog:' + version: 1.6.0(@swc/helpers@0.5.18) + '@types/node': + specifier: 'catalog:' + version: 20.19.31 + memfs: + specifier: ^4.11.1 + version: 4.17.0 + typescript: + specifier: 'catalog:' + version: 5.8.3 + vitest: + specifier: 'catalog:' + version: 4.0.18(@types/node@20.19.31)(jiti@2.6.1)(lightningcss@1.28.2)(terser@5.31.3)(yaml@2.8.2) + webpack: + specifier: 'catalog:' + version: 5.100.2(@swc/core@1.13.3) + webpack-virtual-modules: + specifier: ^0.6.2 + version: 0.6.2 + tests/metro-compat: devDependencies: '@callstack/repack': @@ -736,7 +763,7 @@ importers: version: 29.5.14 '@types/node': specifier: 'catalog:' - version: 20.14.11 + version: 20.19.31 babel-jest: specifier: ^29.7.0 version: 29.7.0(@babel/core@7.25.2) @@ -751,7 +778,7 @@ importers: version: 5.18.1 jest: specifier: ^29.7.0 - version: 29.7.0(@types/node@20.14.11) + version: 29.7.0(@types/node@20.19.31) memfs: specifier: ^4.11.1 version: 4.17.0 @@ -766,7 +793,7 @@ importers: version: link:../../packages/repack '@types/node': specifier: 'catalog:' - version: 20.14.11 + version: 20.19.31 enhanced-resolve: specifier: ^5.18.1 version: 5.18.1 @@ -778,7 +805,7 @@ importers: version: 5.8.3 vitest: specifier: 'catalog:' - version: 2.0.5(@types/node@20.14.11)(lightningcss@1.28.2)(terser@5.31.3) + version: 4.0.18(@types/node@20.19.31)(jiti@2.6.1)(lightningcss@1.28.2)(terser@5.31.3)(yaml@2.8.2) website: dependencies: @@ -794,7 +821,7 @@ importers: devDependencies: '@types/node': specifier: 'catalog:' - version: 20.14.11 + version: 20.19.31 '@types/react': specifier: ^18.2.64 version: 18.3.3 @@ -1711,9 +1738,9 @@ packages: '@emnapi/wasi-threads@1.1.0': resolution: {integrity: sha512-WI0DdZ8xFSbgMjR1sFsKABJ/C5OnRrjT06JXbZKexJGrDuPTzZdDYfFlsgcCXCyf+suG5QU2e/y1Wo2V/OapLQ==} - '@esbuild/aix-ppc64@0.21.5': - resolution: {integrity: sha512-1SDgH6ZSPTlggy1yI6+Dbkiz8xzpHJEVAlF/AM1tHPLsf5STom9rwtjE4hKAF20FfXXNTFqEYXyJNWh1GiZedQ==} - engines: {node: '>=12'} + '@esbuild/aix-ppc64@0.27.2': + resolution: {integrity: sha512-GZMB+a0mOMZs4MpDbj8RJp4cw+w1WV5NYD6xzgvzUJ5Ek2jerwfO2eADyI6ExDSUED+1X8aMbegahsJi+8mgpw==} + engines: {node: '>=18'} cpu: [ppc64] os: [aix] @@ -1723,9 +1750,9 @@ packages: cpu: [arm64] os: [android] - '@esbuild/android-arm64@0.21.5': - resolution: {integrity: sha512-c0uX9VAUBQ7dTDCjq+wdyGLowMdtR/GoC2U5IYk/7D1H1JYC0qseD7+11iMP2mRLN9RcCMRcjC4YMclCzGwS/A==} - engines: {node: '>=12'} + '@esbuild/android-arm64@0.27.2': + resolution: {integrity: sha512-pvz8ZZ7ot/RBphf8fv60ljmaoydPU12VuXHImtAs0XhLLw+EXBi2BLe3OYSBslR4rryHvweW5gmkKFwTiFy6KA==} + engines: {node: '>=18'} cpu: [arm64] os: [android] @@ -1735,9 +1762,9 @@ packages: cpu: [arm] os: [android] - '@esbuild/android-arm@0.21.5': - resolution: {integrity: sha512-vCPvzSjpPHEi1siZdlvAlsPxXl7WbOVUBBAowWug4rJHb68Ox8KualB+1ocNvT5fjv6wpkX6o/iEpbDrf68zcg==} - engines: {node: '>=12'} + '@esbuild/android-arm@0.27.2': + resolution: {integrity: sha512-DVNI8jlPa7Ujbr1yjU2PfUSRtAUZPG9I1RwW4F4xFB1Imiu2on0ADiI/c3td+KmDtVKNbi+nffGDQMfcIMkwIA==} + engines: {node: '>=18'} cpu: [arm] os: [android] @@ -1747,9 +1774,9 @@ packages: cpu: [x64] os: [android] - '@esbuild/android-x64@0.21.5': - resolution: {integrity: sha512-D7aPRUUNHRBwHxzxRvp856rjUHRFW1SdQATKXH2hqA0kAZb1hKmi02OpYRacl0TxIGz/ZmXWlbZgjwWYaCakTA==} - engines: {node: '>=12'} + '@esbuild/android-x64@0.27.2': + resolution: {integrity: sha512-z8Ank4Byh4TJJOh4wpz8g2vDy75zFL0TlZlkUkEwYXuPSgX8yzep596n6mT7905kA9uHZsf/o2OJZubl2l3M7A==} + engines: {node: '>=18'} cpu: [x64] os: [android] @@ -1759,9 +1786,9 @@ packages: cpu: [arm64] os: [darwin] - '@esbuild/darwin-arm64@0.21.5': - resolution: {integrity: sha512-DwqXqZyuk5AiWWf3UfLiRDJ5EDd49zg6O9wclZ7kUMv2WRFr4HKjXp/5t8JZ11QbQfUS6/cRCKGwYhtNAY88kQ==} - engines: {node: '>=12'} + '@esbuild/darwin-arm64@0.27.2': + resolution: {integrity: sha512-davCD2Zc80nzDVRwXTcQP/28fiJbcOwvdolL0sOiOsbwBa72kegmVU0Wrh1MYrbuCL98Omp5dVhQFWRKR2ZAlg==} + engines: {node: '>=18'} cpu: [arm64] os: [darwin] @@ -1771,9 +1798,9 @@ packages: cpu: [x64] os: [darwin] - '@esbuild/darwin-x64@0.21.5': - resolution: {integrity: sha512-se/JjF8NlmKVG4kNIuyWMV/22ZaerB+qaSi5MdrXtd6R08kvs2qCN4C09miupktDitvh8jRFflwGFBQcxZRjbw==} - engines: {node: '>=12'} + '@esbuild/darwin-x64@0.27.2': + resolution: {integrity: sha512-ZxtijOmlQCBWGwbVmwOF/UCzuGIbUkqB1faQRf5akQmxRJ1ujusWsb3CVfk/9iZKr2L5SMU5wPBi1UWbvL+VQA==} + engines: {node: '>=18'} cpu: [x64] os: [darwin] @@ -1783,9 +1810,9 @@ packages: cpu: [arm64] os: [freebsd] - '@esbuild/freebsd-arm64@0.21.5': - resolution: {integrity: sha512-5JcRxxRDUJLX8JXp/wcBCy3pENnCgBR9bN6JsY4OmhfUtIHe3ZW0mawA7+RDAcMLrMIZaf03NlQiX9DGyB8h4g==} - engines: {node: '>=12'} + '@esbuild/freebsd-arm64@0.27.2': + resolution: {integrity: sha512-lS/9CN+rgqQ9czogxlMcBMGd+l8Q3Nj1MFQwBZJyoEKI50XGxwuzznYdwcav6lpOGv5BqaZXqvBSiB/kJ5op+g==} + engines: {node: '>=18'} cpu: [arm64] os: [freebsd] @@ -1795,9 +1822,9 @@ packages: cpu: [x64] os: [freebsd] - '@esbuild/freebsd-x64@0.21.5': - resolution: {integrity: sha512-J95kNBj1zkbMXtHVH29bBriQygMXqoVQOQYA+ISs0/2l3T9/kj42ow2mpqerRBxDJnmkUDCaQT/dfNXWX/ZZCQ==} - engines: {node: '>=12'} + '@esbuild/freebsd-x64@0.27.2': + resolution: {integrity: sha512-tAfqtNYb4YgPnJlEFu4c212HYjQWSO/w/h/lQaBK7RbwGIkBOuNKQI9tqWzx7Wtp7bTPaGC6MJvWI608P3wXYA==} + engines: {node: '>=18'} cpu: [x64] os: [freebsd] @@ -1807,9 +1834,9 @@ packages: cpu: [arm64] os: [linux] - '@esbuild/linux-arm64@0.21.5': - resolution: {integrity: sha512-ibKvmyYzKsBeX8d8I7MH/TMfWDXBF3db4qM6sy+7re0YXya+K1cem3on9XgdT2EQGMu4hQyZhan7TeQ8XkGp4Q==} - engines: {node: '>=12'} + '@esbuild/linux-arm64@0.27.2': + resolution: {integrity: sha512-hYxN8pr66NsCCiRFkHUAsxylNOcAQaxSSkHMMjcpx0si13t1LHFphxJZUiGwojB1a/Hd5OiPIqDdXONia6bhTw==} + engines: {node: '>=18'} cpu: [arm64] os: [linux] @@ -1819,9 +1846,9 @@ packages: cpu: [arm] os: [linux] - '@esbuild/linux-arm@0.21.5': - resolution: {integrity: sha512-bPb5AHZtbeNGjCKVZ9UGqGwo8EUu4cLq68E95A53KlxAPRmUyYv2D6F0uUI65XisGOL1hBP5mTronbgo+0bFcA==} - engines: {node: '>=12'} + '@esbuild/linux-arm@0.27.2': + resolution: {integrity: sha512-vWfq4GaIMP9AIe4yj1ZUW18RDhx6EPQKjwe7n8BbIecFtCQG4CfHGaHuh7fdfq+y3LIA2vGS/o9ZBGVxIDi9hw==} + engines: {node: '>=18'} cpu: [arm] os: [linux] @@ -1831,9 +1858,9 @@ packages: cpu: [ia32] os: [linux] - '@esbuild/linux-ia32@0.21.5': - resolution: {integrity: sha512-YvjXDqLRqPDl2dvRODYmmhz4rPeVKYvppfGYKSNGdyZkA01046pLWyRKKI3ax8fbJoK5QbxblURkwK/MWY18Tg==} - engines: {node: '>=12'} + '@esbuild/linux-ia32@0.27.2': + resolution: {integrity: sha512-MJt5BRRSScPDwG2hLelYhAAKh9imjHK5+NE/tvnRLbIqUWa+0E9N4WNMjmp/kXXPHZGqPLxggwVhz7QP8CTR8w==} + engines: {node: '>=18'} cpu: [ia32] os: [linux] @@ -1843,9 +1870,9 @@ packages: cpu: [loong64] os: [linux] - '@esbuild/linux-loong64@0.21.5': - resolution: {integrity: sha512-uHf1BmMG8qEvzdrzAqg2SIG/02+4/DHB6a9Kbya0XDvwDEKCoC8ZRWI5JJvNdUjtciBGFQ5PuBlpEOXQj+JQSg==} - engines: {node: '>=12'} + '@esbuild/linux-loong64@0.27.2': + resolution: {integrity: sha512-lugyF1atnAT463aO6KPshVCJK5NgRnU4yb3FUumyVz+cGvZbontBgzeGFO1nF+dPueHD367a2ZXe1NtUkAjOtg==} + engines: {node: '>=18'} cpu: [loong64] os: [linux] @@ -1855,9 +1882,9 @@ packages: cpu: [mips64el] os: [linux] - '@esbuild/linux-mips64el@0.21.5': - resolution: {integrity: sha512-IajOmO+KJK23bj52dFSNCMsz1QP1DqM6cwLUv3W1QwyxkyIWecfafnI555fvSGqEKwjMXVLokcV5ygHW5b3Jbg==} - engines: {node: '>=12'} + '@esbuild/linux-mips64el@0.27.2': + resolution: {integrity: sha512-nlP2I6ArEBewvJ2gjrrkESEZkB5mIoaTswuqNFRv/WYd+ATtUpe9Y09RnJvgvdag7he0OWgEZWhviS1OTOKixw==} + engines: {node: '>=18'} cpu: [mips64el] os: [linux] @@ -1867,9 +1894,9 @@ packages: cpu: [ppc64] os: [linux] - '@esbuild/linux-ppc64@0.21.5': - resolution: {integrity: sha512-1hHV/Z4OEfMwpLO8rp7CvlhBDnjsC3CttJXIhBi+5Aj5r+MBvy4egg7wCbe//hSsT+RvDAG7s81tAvpL2XAE4w==} - engines: {node: '>=12'} + '@esbuild/linux-ppc64@0.27.2': + resolution: {integrity: sha512-C92gnpey7tUQONqg1n6dKVbx3vphKtTHJaNG2Ok9lGwbZil6DrfyecMsp9CrmXGQJmZ7iiVXvvZH6Ml5hL6XdQ==} + engines: {node: '>=18'} cpu: [ppc64] os: [linux] @@ -1879,9 +1906,9 @@ packages: cpu: [riscv64] os: [linux] - '@esbuild/linux-riscv64@0.21.5': - resolution: {integrity: sha512-2HdXDMd9GMgTGrPWnJzP2ALSokE/0O5HhTUvWIbD3YdjME8JwvSCnNGBnTThKGEB91OZhzrJ4qIIxk/SBmyDDA==} - engines: {node: '>=12'} + '@esbuild/linux-riscv64@0.27.2': + resolution: {integrity: sha512-B5BOmojNtUyN8AXlK0QJyvjEZkWwy/FKvakkTDCziX95AowLZKR6aCDhG7LeF7uMCXEJqwa8Bejz5LTPYm8AvA==} + engines: {node: '>=18'} cpu: [riscv64] os: [linux] @@ -1891,9 +1918,9 @@ packages: cpu: [s390x] os: [linux] - '@esbuild/linux-s390x@0.21.5': - resolution: {integrity: sha512-zus5sxzqBJD3eXxwvjN1yQkRepANgxE9lgOW2qLnmr8ikMTphkjgXu1HR01K4FJg8h1kEEDAqDcZQtbrRnB41A==} - engines: {node: '>=12'} + '@esbuild/linux-s390x@0.27.2': + resolution: {integrity: sha512-p4bm9+wsPwup5Z8f4EpfN63qNagQ47Ua2znaqGH6bqLlmJ4bx97Y9JdqxgGZ6Y8xVTixUnEkoKSHcpRlDnNr5w==} + engines: {node: '>=18'} cpu: [s390x] os: [linux] @@ -1903,45 +1930,63 @@ packages: cpu: [x64] os: [linux] - '@esbuild/linux-x64@0.21.5': - resolution: {integrity: sha512-1rYdTpyv03iycF1+BhzrzQJCdOuAOtaqHTWJZCWvijKD2N5Xu0TtVC8/+1faWqcP9iBCWOmjmhoH94dH82BxPQ==} - engines: {node: '>=12'} + '@esbuild/linux-x64@0.27.2': + resolution: {integrity: sha512-uwp2Tip5aPmH+NRUwTcfLb+W32WXjpFejTIOWZFw/v7/KnpCDKG66u4DLcurQpiYTiYwQ9B7KOeMJvLCu/OvbA==} + engines: {node: '>=18'} cpu: [x64] os: [linux] + '@esbuild/netbsd-arm64@0.27.2': + resolution: {integrity: sha512-Kj6DiBlwXrPsCRDeRvGAUb/LNrBASrfqAIok+xB0LxK8CHqxZ037viF13ugfsIpePH93mX7xfJp97cyDuTZ3cw==} + engines: {node: '>=18'} + cpu: [arm64] + os: [netbsd] + '@esbuild/netbsd-x64@0.17.19': resolution: {integrity: sha512-CwFq42rXCR8TYIjIfpXCbRX0rp1jo6cPIUPSaWwzbVI4aOfX96OXY8M6KNmtPcg7QjYeDmN+DD0Wp3LaBOLf4Q==} engines: {node: '>=12'} cpu: [x64] os: [netbsd] - '@esbuild/netbsd-x64@0.21.5': - resolution: {integrity: sha512-Woi2MXzXjMULccIwMnLciyZH4nCIMpWQAs049KEeMvOcNADVxo0UBIQPfSmxB3CWKedngg7sWZdLvLczpe0tLg==} - engines: {node: '>=12'} + '@esbuild/netbsd-x64@0.27.2': + resolution: {integrity: sha512-HwGDZ0VLVBY3Y+Nw0JexZy9o/nUAWq9MlV7cahpaXKW6TOzfVno3y3/M8Ga8u8Yr7GldLOov27xiCnqRZf0tCA==} + engines: {node: '>=18'} cpu: [x64] os: [netbsd] + '@esbuild/openbsd-arm64@0.27.2': + resolution: {integrity: sha512-DNIHH2BPQ5551A7oSHD0CKbwIA/Ox7+78/AWkbS5QoRzaqlev2uFayfSxq68EkonB+IKjiuxBFoV8ESJy8bOHA==} + engines: {node: '>=18'} + cpu: [arm64] + os: [openbsd] + '@esbuild/openbsd-x64@0.17.19': resolution: {integrity: sha512-cnq5brJYrSZ2CF6c35eCmviIN3k3RczmHz8eYaVlNasVqsNY+JKohZU5MKmaOI+KkllCdzOKKdPs762VCPC20g==} engines: {node: '>=12'} cpu: [x64] os: [openbsd] - '@esbuild/openbsd-x64@0.21.5': - resolution: {integrity: sha512-HLNNw99xsvx12lFBUwoT8EVCsSvRNDVxNpjZ7bPn947b8gJPzeHWyNVhFsaerc0n3TsbOINvRP2byTZ5LKezow==} - engines: {node: '>=12'} + '@esbuild/openbsd-x64@0.27.2': + resolution: {integrity: sha512-/it7w9Nb7+0KFIzjalNJVR5bOzA9Vay+yIPLVHfIQYG/j+j9VTH84aNB8ExGKPU4AzfaEvN9/V4HV+F+vo8OEg==} + engines: {node: '>=18'} cpu: [x64] os: [openbsd] + '@esbuild/openharmony-arm64@0.27.2': + resolution: {integrity: sha512-LRBbCmiU51IXfeXk59csuX/aSaToeG7w48nMwA6049Y4J4+VbWALAuXcs+qcD04rHDuSCSRKdmY63sruDS5qag==} + engines: {node: '>=18'} + cpu: [arm64] + os: [openharmony] + '@esbuild/sunos-x64@0.17.19': resolution: {integrity: sha512-vCRT7yP3zX+bKWFeP/zdS6SqdWB8OIpaRq/mbXQxTGHnIxspRtigpkUcDMlSCOejlHowLqII7K2JKevwyRP2rg==} engines: {node: '>=12'} cpu: [x64] os: [sunos] - '@esbuild/sunos-x64@0.21.5': - resolution: {integrity: sha512-6+gjmFpfy0BHU5Tpptkuh8+uw3mnrvgs+dSPQXQOv3ekbordwnzTVEb4qnIvQcYXq6gzkyTnoZ9dZG+D4garKg==} - engines: {node: '>=12'} + '@esbuild/sunos-x64@0.27.2': + resolution: {integrity: sha512-kMtx1yqJHTmqaqHPAzKCAkDaKsffmXkPHThSfRwZGyuqyIeBvf08KSsYXl+abf5HDAPMJIPnbBfXvP2ZC2TfHg==} + engines: {node: '>=18'} cpu: [x64] os: [sunos] @@ -1951,9 +1996,9 @@ packages: cpu: [arm64] os: [win32] - '@esbuild/win32-arm64@0.21.5': - resolution: {integrity: sha512-Z0gOTd75VvXqyq7nsl93zwahcTROgqvuAcYDUr+vOv8uHhNSKROyU961kgtCD1e95IqPKSQKH7tBTslnS3tA8A==} - engines: {node: '>=12'} + '@esbuild/win32-arm64@0.27.2': + resolution: {integrity: sha512-Yaf78O/B3Kkh+nKABUF++bvJv5Ijoy9AN1ww904rOXZFLWVc5OLOfL56W+C8F9xn5JQZa3UX6m+IktJnIb1Jjg==} + engines: {node: '>=18'} cpu: [arm64] os: [win32] @@ -1963,9 +2008,9 @@ packages: cpu: [ia32] os: [win32] - '@esbuild/win32-ia32@0.21.5': - resolution: {integrity: sha512-SWXFF1CL2RVNMaVs+BBClwtfZSvDgtL//G/smwAc5oVK/UPu2Gu9tIaRgFmYFFKrmg3SyAjSrElf0TiJ1v8fYA==} - engines: {node: '>=12'} + '@esbuild/win32-ia32@0.27.2': + resolution: {integrity: sha512-Iuws0kxo4yusk7sw70Xa2E2imZU5HoixzxfGCdxwBdhiDgt9vX9VUCBhqcwY7/uh//78A1hMkkROMJq9l27oLQ==} + engines: {node: '>=18'} cpu: [ia32] os: [win32] @@ -1975,9 +2020,9 @@ packages: cpu: [x64] os: [win32] - '@esbuild/win32-x64@0.21.5': - resolution: {integrity: sha512-tQd/1efJuzPC6rCFwEvLtci/xNFcTZknmXs98FYDfGE4wP9ClFV98nyKrzJKVPMhdDnjzLhdUyMX4PsQAPjwIw==} - engines: {node: '>=12'} + '@esbuild/win32-x64@0.27.2': + resolution: {integrity: sha512-sRdU18mcKf7F+YgheI/zGf5alZatMUTKj/jNS6l744f9u3WFu4v7twcUI9vu4mknF4Y9aDlblIie0IM+5xxaqQ==} + engines: {node: '>=18'} cpu: [x64] os: [win32] @@ -2137,6 +2182,9 @@ packages: '@jridgewell/sourcemap-codec@1.5.0': resolution: {integrity: sha512-gv3ZRaISU3fjPAgNsriBRqGWQL6quFx04YMPW/zD8XMLsU32mhCCbfbO6KZFLjvYpCZ8zyDEgqsgf+PwPaM7GQ==} + '@jridgewell/sourcemap-codec@1.5.5': + resolution: {integrity: sha512-cYQ9310grqxueWbl+WuIUIaiUaDcj7WOq5fVhEljNVgRfOUhY9fy2zTvfoqWsnebh8Sl70VScFbICvJnLKB0Og==} + '@jridgewell/trace-mapping@0.3.25': resolution: {integrity: sha512-vNk6aEwybGtawWmy/PzwnGDOjCkLWSD2wqvjGGAgOAwCGWySYXfYoxt00IJkTF+8Lb57DwOb3Aa0o9CApepiYQ==} @@ -2641,83 +2689,128 @@ packages: resolution: {integrity: sha512-F18Pn28Ligw3RyNKzXtSRZudWQ5R3JFywyWwqcUY+UFmjBjhekdIceHM/SXNZOJgkj21RRgXaIJy1gpaJtT0Jw==} engines: {node: '>=16.17'} - '@rollup/rollup-android-arm-eabi@4.21.2': - resolution: {integrity: sha512-fSuPrt0ZO8uXeS+xP3b+yYTCBUd05MoSp2N/MFOgjhhUhMmchXlpTQrTpI8T+YAwAQuK7MafsCOxW7VrPMrJcg==} + '@rollup/rollup-android-arm-eabi@4.57.1': + resolution: {integrity: sha512-A6ehUVSiSaaliTxai040ZpZ2zTevHYbvu/lDoeAteHI8QnaosIzm4qwtezfRg1jOYaUmnzLX1AOD6Z+UJjtifg==} cpu: [arm] os: [android] - '@rollup/rollup-android-arm64@4.21.2': - resolution: {integrity: sha512-xGU5ZQmPlsjQS6tzTTGwMsnKUtu0WVbl0hYpTPauvbRAnmIvpInhJtgjj3mcuJpEiuUw4v1s4BimkdfDWlh7gA==} + '@rollup/rollup-android-arm64@4.57.1': + resolution: {integrity: sha512-dQaAddCY9YgkFHZcFNS/606Exo8vcLHwArFZ7vxXq4rigo2bb494/xKMMwRRQW6ug7Js6yXmBZhSBRuBvCCQ3w==} cpu: [arm64] os: [android] - '@rollup/rollup-darwin-arm64@4.21.2': - resolution: {integrity: sha512-99AhQ3/ZMxU7jw34Sq8brzXqWH/bMnf7ZVhvLk9QU2cOepbQSVTns6qoErJmSiAvU3InRqC2RRZ5ovh1KN0d0Q==} + '@rollup/rollup-darwin-arm64@4.57.1': + resolution: {integrity: sha512-crNPrwJOrRxagUYeMn/DZwqN88SDmwaJ8Cvi/TN1HnWBU7GwknckyosC2gd0IqYRsHDEnXf328o9/HC6OkPgOg==} cpu: [arm64] os: [darwin] - '@rollup/rollup-darwin-x64@4.21.2': - resolution: {integrity: sha512-ZbRaUvw2iN/y37x6dY50D8m2BnDbBjlnMPotDi/qITMJ4sIxNY33HArjikDyakhSv0+ybdUxhWxE6kTI4oX26w==} + '@rollup/rollup-darwin-x64@4.57.1': + resolution: {integrity: sha512-Ji8g8ChVbKrhFtig5QBV7iMaJrGtpHelkB3lsaKzadFBe58gmjfGXAOfI5FV0lYMH8wiqsxKQ1C9B0YTRXVy4w==} cpu: [x64] os: [darwin] - '@rollup/rollup-linux-arm-gnueabihf@4.21.2': - resolution: {integrity: sha512-ztRJJMiE8nnU1YFcdbd9BcH6bGWG1z+jP+IPW2oDUAPxPjo9dverIOyXz76m6IPA6udEL12reYeLojzW2cYL7w==} + '@rollup/rollup-freebsd-arm64@4.57.1': + resolution: {integrity: sha512-R+/WwhsjmwodAcz65guCGFRkMb4gKWTcIeLy60JJQbXrJ97BOXHxnkPFrP+YwFlaS0m+uWJTstrUA9o+UchFug==} + cpu: [arm64] + os: [freebsd] + + '@rollup/rollup-freebsd-x64@4.57.1': + resolution: {integrity: sha512-IEQTCHeiTOnAUC3IDQdzRAGj3jOAYNr9kBguI7MQAAZK3caezRrg0GxAb6Hchg4lxdZEI5Oq3iov/w/hnFWY9Q==} + cpu: [x64] + os: [freebsd] + + '@rollup/rollup-linux-arm-gnueabihf@4.57.1': + resolution: {integrity: sha512-F8sWbhZ7tyuEfsmOxwc2giKDQzN3+kuBLPwwZGyVkLlKGdV1nvnNwYD0fKQ8+XS6hp9nY7B+ZeK01EBUE7aHaw==} cpu: [arm] os: [linux] - '@rollup/rollup-linux-arm-musleabihf@4.21.2': - resolution: {integrity: sha512-flOcGHDZajGKYpLV0JNc0VFH361M7rnV1ee+NTeC/BQQ1/0pllYcFmxpagltANYt8FYf9+kL6RSk80Ziwyhr7w==} + '@rollup/rollup-linux-arm-musleabihf@4.57.1': + resolution: {integrity: sha512-rGfNUfn0GIeXtBP1wL5MnzSj98+PZe/AXaGBCRmT0ts80lU5CATYGxXukeTX39XBKsxzFpEeK+Mrp9faXOlmrw==} cpu: [arm] os: [linux] - '@rollup/rollup-linux-arm64-gnu@4.21.2': - resolution: {integrity: sha512-69CF19Kp3TdMopyteO/LJbWufOzqqXzkrv4L2sP8kfMaAQ6iwky7NoXTp7bD6/irKgknDKM0P9E/1l5XxVQAhw==} + '@rollup/rollup-linux-arm64-gnu@4.57.1': + resolution: {integrity: sha512-MMtej3YHWeg/0klK2Qodf3yrNzz6CGjo2UntLvk2RSPlhzgLvYEB3frRvbEF2wRKh1Z2fDIg9KRPe1fawv7C+g==} cpu: [arm64] os: [linux] - '@rollup/rollup-linux-arm64-musl@4.21.2': - resolution: {integrity: sha512-48pD/fJkTiHAZTnZwR0VzHrao70/4MlzJrq0ZsILjLW/Ab/1XlVUStYyGt7tdyIiVSlGZbnliqmult/QGA2O2w==} + '@rollup/rollup-linux-arm64-musl@4.57.1': + resolution: {integrity: sha512-1a/qhaaOXhqXGpMFMET9VqwZakkljWHLmZOX48R0I/YLbhdxr1m4gtG1Hq7++VhVUmf+L3sTAf9op4JlhQ5u1Q==} cpu: [arm64] os: [linux] - '@rollup/rollup-linux-powerpc64le-gnu@4.21.2': - resolution: {integrity: sha512-cZdyuInj0ofc7mAQpKcPR2a2iu4YM4FQfuUzCVA2u4HI95lCwzjoPtdWjdpDKyHxI0UO82bLDoOaLfpZ/wviyQ==} + '@rollup/rollup-linux-loong64-gnu@4.57.1': + resolution: {integrity: sha512-QWO6RQTZ/cqYtJMtxhkRkidoNGXc7ERPbZN7dVW5SdURuLeVU7lwKMpo18XdcmpWYd0qsP1bwKPf7DNSUinhvA==} + cpu: [loong64] + os: [linux] + + '@rollup/rollup-linux-loong64-musl@4.57.1': + resolution: {integrity: sha512-xpObYIf+8gprgWaPP32xiN5RVTi/s5FCR+XMXSKmhfoJjrpRAjCuuqQXyxUa/eJTdAE6eJ+KDKaoEqjZQxh3Gw==} + cpu: [loong64] + os: [linux] + + '@rollup/rollup-linux-ppc64-gnu@4.57.1': + resolution: {integrity: sha512-4BrCgrpZo4hvzMDKRqEaW1zeecScDCR+2nZ86ATLhAoJ5FQ+lbHVD3ttKe74/c7tNT9c6F2viwB3ufwp01Oh2w==} cpu: [ppc64] os: [linux] - '@rollup/rollup-linux-riscv64-gnu@4.21.2': - resolution: {integrity: sha512-RL56JMT6NwQ0lXIQmMIWr1SW28z4E4pOhRRNqwWZeXpRlykRIlEpSWdsgNWJbYBEWD84eocjSGDu/XxbYeCmwg==} + '@rollup/rollup-linux-ppc64-musl@4.57.1': + resolution: {integrity: sha512-NOlUuzesGauESAyEYFSe3QTUguL+lvrN1HtwEEsU2rOwdUDeTMJdO5dUYl/2hKf9jWydJrO9OL/XSSf65R5+Xw==} + cpu: [ppc64] + os: [linux] + + '@rollup/rollup-linux-riscv64-gnu@4.57.1': + resolution: {integrity: sha512-ptA88htVp0AwUUqhVghwDIKlvJMD/fmL/wrQj99PRHFRAG6Z5nbWoWG4o81Nt9FT+IuqUQi+L31ZKAFeJ5Is+A==} + cpu: [riscv64] + os: [linux] + + '@rollup/rollup-linux-riscv64-musl@4.57.1': + resolution: {integrity: sha512-S51t7aMMTNdmAMPpBg7OOsTdn4tySRQvklmL3RpDRyknk87+Sp3xaumlatU+ppQ+5raY7sSTcC2beGgvhENfuw==} cpu: [riscv64] os: [linux] - '@rollup/rollup-linux-s390x-gnu@4.21.2': - resolution: {integrity: sha512-PMxkrWS9z38bCr3rWvDFVGD6sFeZJw4iQlhrup7ReGmfn7Oukrr/zweLhYX6v2/8J6Cep9IEA/SmjXjCmSbrMQ==} + '@rollup/rollup-linux-s390x-gnu@4.57.1': + resolution: {integrity: sha512-Bl00OFnVFkL82FHbEqy3k5CUCKH6OEJL54KCyx2oqsmZnFTR8IoNqBF+mjQVcRCT5sB6yOvK8A37LNm/kPJiZg==} cpu: [s390x] os: [linux] - '@rollup/rollup-linux-x64-gnu@4.21.2': - resolution: {integrity: sha512-B90tYAUoLhU22olrafY3JQCFLnT3NglazdwkHyxNDYF/zAxJt5fJUB/yBoWFoIQ7SQj+KLe3iL4BhOMa9fzgpw==} + '@rollup/rollup-linux-x64-gnu@4.57.1': + resolution: {integrity: sha512-ABca4ceT4N+Tv/GtotnWAeXZUZuM/9AQyCyKYyKnpk4yoA7QIAuBt6Hkgpw8kActYlew2mvckXkvx0FfoInnLg==} cpu: [x64] os: [linux] - '@rollup/rollup-linux-x64-musl@4.21.2': - resolution: {integrity: sha512-7twFizNXudESmC9oneLGIUmoHiiLppz/Xs5uJQ4ShvE6234K0VB1/aJYU3f/4g7PhssLGKBVCC37uRkkOi8wjg==} + '@rollup/rollup-linux-x64-musl@4.57.1': + resolution: {integrity: sha512-HFps0JeGtuOR2convgRRkHCekD7j+gdAuXM+/i6kGzQtFhlCtQkpwtNzkNj6QhCDp7DRJ7+qC/1Vg2jt5iSOFw==} cpu: [x64] os: [linux] - '@rollup/rollup-win32-arm64-msvc@4.21.2': - resolution: {integrity: sha512-9rRero0E7qTeYf6+rFh3AErTNU1VCQg2mn7CQcI44vNUWM9Ze7MSRS/9RFuSsox+vstRt97+x3sOhEey024FRQ==} + '@rollup/rollup-openbsd-x64@4.57.1': + resolution: {integrity: sha512-H+hXEv9gdVQuDTgnqD+SQffoWoc0Of59AStSzTEj/feWTBAnSfSD3+Dql1ZruJQxmykT/JVY0dE8Ka7z0DH1hw==} + cpu: [x64] + os: [openbsd] + + '@rollup/rollup-openharmony-arm64@4.57.1': + resolution: {integrity: sha512-4wYoDpNg6o/oPximyc/NG+mYUejZrCU2q+2w6YZqrAs2UcNUChIZXjtafAiiZSUc7On8v5NyNj34Kzj/Ltk6dQ==} + cpu: [arm64] + os: [openharmony] + + '@rollup/rollup-win32-arm64-msvc@4.57.1': + resolution: {integrity: sha512-O54mtsV/6LW3P8qdTcamQmuC990HDfR71lo44oZMZlXU4tzLrbvTii87Ni9opq60ds0YzuAlEr/GNwuNluZyMQ==} cpu: [arm64] os: [win32] - '@rollup/rollup-win32-ia32-msvc@4.21.2': - resolution: {integrity: sha512-5rA4vjlqgrpbFVVHX3qkrCo/fZTj1q0Xxpg+Z7yIo3J2AilW7t2+n6Q8Jrx+4MrYpAnjttTYF8rr7bP46BPzRw==} + '@rollup/rollup-win32-ia32-msvc@4.57.1': + resolution: {integrity: sha512-P3dLS+IerxCT/7D2q2FYcRdWRl22dNbrbBEtxdWhXrfIMPP9lQhb5h4Du04mdl5Woq05jVCDPCMF7Ub0NAjIew==} cpu: [ia32] os: [win32] - '@rollup/rollup-win32-x64-msvc@4.21.2': - resolution: {integrity: sha512-6UUxd0+SKomjdzuAcp+HAmxw1FlGBnl1v2yEPSabtx4lBfdXHDVsW7+lQkgz9cNFJGY3AWR7+V8P5BqkD9L9nA==} + '@rollup/rollup-win32-x64-gnu@4.57.1': + resolution: {integrity: sha512-VMBH2eOOaKGtIJYleXsi2B8CPVADrh+TyNxJ4mWPnKfLB/DBUmzW+5m1xUrcwWoMfSLagIRpjUFeW5CO5hyciQ==} + cpu: [x64] + os: [win32] + + '@rollup/rollup-win32-x64-msvc@4.57.1': + resolution: {integrity: sha512-mxRFDdHIWRxg3UfIIAwCm6NzvxG0jDX/wBN6KsQFTvKFqqg9vTrWUE68qEjHt19A5wwx5X5aUi2zuZT7YR0jrA==} cpu: [x64] os: [win32] @@ -3064,6 +3157,9 @@ packages: '@socket.io/component-emitter@3.1.2': resolution: {integrity: sha512-9BCxFwvbGg/RsZK9tjXd8s4UcwR0MWeFQ1XEKIQVVvAGJyINdrqKMcTRyLoK8Rse1GjzLV9cwjWV1olXRWEXVA==} + '@standard-schema/spec@1.1.0': + resolution: {integrity: sha512-l2aFy5jALhniG5HgqrD6jXLi/rUWrKvqN/qJx6yoJsgKhblVd+iqqU4RCXavm/jPityDo5TCvKMnpjKnOriy0w==} + '@svgr/babel-plugin-add-jsx-attribute@8.0.0': resolution: {integrity: sha512-b9MIk7yhdS1pMCZM8VeNfUlSKVRhsHZNMl5O9SfaX0l0t5wjdgu4IDzGB8bpnGBBOjGST3rRFVsaaEtI4W6f7g==} engines: {node: '>=14'} @@ -3251,6 +3347,9 @@ packages: '@types/babel__traverse@7.20.6': resolution: {integrity: sha512-r1bzfrm0tomOI8g1SzvCaQHo6Lcv6zu0EA+W2kHrt8dyrHQxGzBBL4kdkzIS+jBMV+EYcMAEAqXqYaLJq5rOZg==} + '@types/chai@5.2.3': + resolution: {integrity: sha512-Mw558oeA9fFbv65/y4mHtXDs9bPnFMZAL/jxdPFUpOHHIXX91mcgEHbS5Lahr+pwZFR8A7GQleRWeI6cGFC2UA==} + '@types/connect@3.4.38': resolution: {integrity: sha512-K6uROf1LD88uDQqJCktA4yzL1YYAK6NgfsI0v/mTgyPKWsX1CnJ0XPSDhViejru1GcRkLWb8RlzFYJRqGUbaug==} @@ -3266,6 +3365,9 @@ packages: '@types/dedent@0.7.2': resolution: {integrity: sha512-kRiitIeUg1mPV9yH4VUJ/1uk2XjyANfeL8/7rH1tsjvHeO9PJLBHJIYsFWmAvmGj5u8rj+1TZx7PZzW2qLw3Lw==} + '@types/deep-eql@4.0.2': + resolution: {integrity: sha512-c9h9dVVMigMPc4bwTvC5dxqtqJZwQPePsWjPlpSOnojbor6pGqdk541lfA7AqFQr5pB1BRdq0juY9db81BwyFw==} + '@types/eslint-scope@3.7.7': resolution: {integrity: sha512-MzMFlSLBqNF2gcHWO0G1vP/YQyfvrxZ0bF+u7mzUdZ1/xK4A4sru+nraZz5i3iEIk1l1uyicaDVTB4QbbEkAYg==} @@ -3338,6 +3440,9 @@ packages: '@types/node@20.14.11': resolution: {integrity: sha512-kprQpL8MMeszbz6ojB5/tU8PLN4kesnN8Gjzw349rDlNgsSzg90lAVj3llK99Dh7JON+t9AuscPPFW6mPbTnSA==} + '@types/node@20.19.31': + resolution: {integrity: sha512-5jsi0wpncvTD33Sh1UCgacK37FFwDn+EG7wCmEvs62fCvBL+n8/76cAYDok21NF6+jaVWIqKwCZyX7Vbu8eB3A==} + '@types/prop-types@15.7.12': resolution: {integrity: sha512-5zvhXYtRNRluoE/jAp4GVsSduVUzNWKkOZrCDBWYtE7biZywwdC2AcEzg+cSMLFRfVgeAFqpfNabiPjxFddV1Q==} @@ -3429,23 +3534,34 @@ packages: vue-router: optional: true - '@vitest/expect@2.0.5': - resolution: {integrity: sha512-yHZtwuP7JZivj65Gxoi8upUN2OzHTi3zVfjwdpu2WrvCZPLwsJ2Ey5ILIPccoW23dd/zQBlJ4/dhi7DWNyXCpA==} + '@vitest/expect@4.0.18': + resolution: {integrity: sha512-8sCWUyckXXYvx4opfzVY03EOiYVxyNrHS5QxX3DAIi5dpJAAkyJezHCP77VMX4HKA2LDT/Jpfo8i2r5BE3GnQQ==} - '@vitest/pretty-format@2.0.5': - resolution: {integrity: sha512-h8k+1oWHfwTkyTkb9egzwNMfJAEx4veaPSnMeKbVSjp4euqGSbQlm5+6VHwTr7u4FJslVVsUG5nopCaAYdOmSQ==} + '@vitest/mocker@4.0.18': + resolution: {integrity: sha512-HhVd0MDnzzsgevnOWCBj5Otnzobjy5wLBe4EdeeFGv8luMsGcYqDuFRMcttKWZA5vVO8RFjexVovXvAM4JoJDQ==} + peerDependencies: + msw: ^2.4.9 + vite: ^6.0.0 || ^7.0.0-0 + peerDependenciesMeta: + msw: + optional: true + vite: + optional: true - '@vitest/runner@2.0.5': - resolution: {integrity: sha512-TfRfZa6Bkk9ky4tW0z20WKXFEwwvWhRY+84CnSEtq4+3ZvDlJyY32oNTJtM7AW9ihW90tX/1Q78cb6FjoAs+ig==} + '@vitest/pretty-format@4.0.18': + resolution: {integrity: sha512-P24GK3GulZWC5tz87ux0m8OADrQIUVDPIjjj65vBXYG17ZeU3qD7r+MNZ1RNv4l8CGU2vtTRqixrOi9fYk/yKw==} - '@vitest/snapshot@2.0.5': - resolution: {integrity: sha512-SgCPUeDFLaM0mIUHfaArq8fD2WbaXG/zVXjRupthYfYGzc8ztbFbu6dUNOblBG7XLMR1kEhS/DNnfCZ2IhdDew==} + '@vitest/runner@4.0.18': + resolution: {integrity: sha512-rpk9y12PGa22Jg6g5M3UVVnTS7+zycIGk9ZNGN+m6tZHKQb7jrP7/77WfZy13Y/EUDd52NDsLRQhYKtv7XfPQw==} - '@vitest/spy@2.0.5': - resolution: {integrity: sha512-c/jdthAhvJdpfVuaexSrnawxZz6pywlTPe84LUB2m/4t3rl2fTo9NFGBG4oWgaD+FTgDDV8hJ/nibT7IfH3JfA==} + '@vitest/snapshot@4.0.18': + resolution: {integrity: sha512-PCiV0rcl7jKQjbgYqjtakly6T1uwv/5BQ9SwBLekVg/EaYeQFPiXcgrC2Y7vDMA8dM1SUEAEV82kgSQIlXNMvA==} - '@vitest/utils@2.0.5': - resolution: {integrity: sha512-d8HKbqIcya+GR67mkZbrzhS5kKhtp8dQLcmRZLGTscGVg7yImT82cIrhtn2L8+VujWcy6KZweApgNmPsTAO/UQ==} + '@vitest/spy@4.0.18': + resolution: {integrity: sha512-cbQt3PTSD7P2OARdVW3qWER5EGq7PHlvE+QfzSC0lbwO+xnt7+XH06ZzFjFRgzUX//JmpxrCu92VdwvEPlWSNw==} + + '@vitest/utils@4.0.18': + resolution: {integrity: sha512-msMRKLMVLWygpK3u2Hybgi4MNjcYJvwTb0Ru09+fOyCXIgT5raYP041DRRdiJiI3k/2U6SEbAETB3YtBrUkCFA==} '@vscode/sudo-prompt@9.3.1': resolution: {integrity: sha512-9ORTwwS74VaTn38tNbQhsA5U44zkJfcb0BdTSyyG6frP4e8KMtHuTXYmwefe5dpL8XB1aGSIVTaLjD3BbWb5iA==} @@ -3899,9 +4015,9 @@ packages: ccount@2.0.1: resolution: {integrity: sha512-eyrF0jiFpY+3drT6383f1qhkbGsLSifNAjA61IUjZjmLCWjItY6LB9ft9YhoDgwfmclB2zhu51Lc7+95b8NRAg==} - chai@5.1.1: - resolution: {integrity: sha512-pT1ZgP8rPNqUgieVaEY+ryQr6Q4HXNg8Ei9UnLUrjN4IA7dvQC5JB+/kxVcPNDHyBcc/26CXPkbNzq3qwrOEKA==} - engines: {node: '>=12'} + chai@6.2.2: + resolution: {integrity: sha512-NUPRluOfOiTKBKvWPtSD4PhFvWCqOi0BGStNWs57X9js7XGTprSmFoz5F0tWhR4WPjNeR9jXqdC7/UpSJTnlRg==} + engines: {node: '>=18'} chalk@2.4.2: resolution: {integrity: sha512-Mti+f9lpJNcwF4tWV8/OrTTtF1gZi+f8FqlyAdouralcFWFQWF2+NgCHShjkCb+IFBLq9buZwE1xckQU4peSuQ==} @@ -3938,10 +4054,6 @@ packages: chardet@0.7.0: resolution: {integrity: sha512-mT8iDcrh03qDGRRmoA2hmBJnxpllMR+0/0qlzjqZES6NdiWDcZkCNAk4rPFZ9Q85r27unkiNNg8ZOiwZXBHwcA==} - check-error@2.1.1: - resolution: {integrity: sha512-OAlb+T7V4Op9OwdkjmguYRqncdlx5JiofwOAUkmTF+jNdHwzTaTs4sRAGpzLF3oOz5xAyDGrPgeIDFQmDOTiJw==} - engines: {node: '>= 16'} - chokidar@3.6.0: resolution: {integrity: sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==} engines: {node: '>= 8.10.0'} @@ -4283,10 +4395,6 @@ packages: resolution: {integrity: sha512-SUwdGfqdKOwxCPeVYjwSyRpJ7Z+fhpwIAtmCUdZIWZ/YP5R9WAsyuSgpLVDi9bjWoN2LXHNss/dk3urXtdQxGg==} engines: {node: '>=6'} - deep-eql@5.0.2: - resolution: {integrity: sha512-h5k/5U50IJJFpzfL6nO9jaaumfjO/f2NjK/oYB2Djzm4p9L+3T9qWpZqZ2hAbLPuuYq9wrU08WQyBTL5GbPk5Q==} - engines: {node: '>=6'} - deep-equal@1.0.1: resolution: {integrity: sha512-bHtC0iYvWhyaTzvV3CZgPeZQqCOBGyGsVV7v4eevpdkLHfiSrXUdBG+qAuSz4RI70sszvjQ1QSZ98An1yNwpSw==} @@ -4504,6 +4612,9 @@ packages: es-module-lexer@1.5.4: resolution: {integrity: sha512-MVNK56NiMrOwitFB7cqDwq0CQutbw+0BvLshJSse0MUNU+y1FC3bUS/AQg7oUng+/wKrrki7JfmwtVHkVfPLlw==} + es-module-lexer@1.7.0: + resolution: {integrity: sha512-jEQoCwk8hyb2AZziIOLhDqpm5+2ww5uIE6lkO/6jcOCusfk6LhMHpXXfBLXTZ7Ydyt0j4VoUQv6uGNYbdW+kBA==} + es-object-atoms@1.1.1: resolution: {integrity: sha512-FGgH2h8zKNim9ljj7dankFPcICIK9Cp5bm+c2gQSYePhpaG5+esrLODihIorn+Pe6FGJzWhXQotPv73jTaldXA==} engines: {node: '>= 0.4'} @@ -4523,9 +4634,9 @@ packages: engines: {node: '>=12'} hasBin: true - esbuild@0.21.5: - resolution: {integrity: sha512-mg3OPMV4hXywwpoDxu3Qda5xCKQi+vCTZq8S9J/EpkhB2HzKXq4SNFZE3+NK93JYxc8VMSep+lOUSC/RVKaBqw==} - engines: {node: '>=12'} + esbuild@0.27.2: + resolution: {integrity: sha512-HyNQImnsOC7X9PMNaCIeAm4ISCQXs5a5YasTXVliKv4uuBo1dKrG0A+uQS8M5eXjVMnLg3WgXaKvprHlFJQffw==} + engines: {node: '>=18'} hasBin: true escalade@3.2.0: @@ -4619,10 +4730,6 @@ packages: resolution: {integrity: sha512-8uSpZZocAZRBAPIEINJj3Lo9HyGitllczc27Eh5YYojjMFMn8yHMDMaUHE2Jqfq05D/wucwI4JGURyXt1vchyg==} engines: {node: '>=10'} - execa@8.0.1: - resolution: {integrity: sha512-VyhnebXciFV2DESc+p6B+y0LjSm0krU4OgJN44qFAhBY0TJ+1V61tYD2+wHusZ6F9n5K+vl8k0sTy7PEfV4qpg==} - engines: {node: '>=16.17'} - execa@9.5.2: resolution: {integrity: sha512-EHlpxMCpHWSAh1dgS6bVeoLAXGnJNdR93aabr4QCGbzOM73o5XmRfM/e5FUqsw3aagP8S8XEWUWFAxnRBnAF0Q==} engines: {node: ^18.19.0 || >=20.5.0} @@ -4639,6 +4746,10 @@ packages: resolution: {integrity: sha512-A5EmesHW6rfnZ9ysHQjPdJRni0SRar0tjtG5MNtm9n5TUvsYU8oozprtRD4AqHxcZWWlVuAmQo2nWKfN9oyjTw==} engines: {node: '>=0.10.0'} + expect-type@1.3.0: + resolution: {integrity: sha512-knvyeauYhqjOYvQ66MznSMs83wmHrCycNEN6Ao+2AeYEfxUIkuiVxdEa1qlGEPK+We3n0THiDciYSsCcgW/DoA==} + engines: {node: '>=12.0.0'} + expect@29.7.0: resolution: {integrity: sha512-2Zks0hf1VLFYI1kbh0I5jP3KHHyCHpkfyHBzsSXRFgl/Bg9mWYfMW8oD+PdMPlEwy5HNsR9JutYy6pMeOh61nw==} engines: {node: ^14.15.0 || ^16.10.0 || >=18.0.0} @@ -4893,9 +5004,6 @@ packages: resolution: {integrity: sha512-DyFP3BM/3YHTQOCUL/w0OZHR0lpKeGrxotcHWcqNEdnltqFwXVfhEBQ94eIo34AfQpo0rGki4cyIiftY06h2Fg==} engines: {node: 6.* || 8.* || >= 10.*} - get-func-name@2.0.2: - resolution: {integrity: sha512-8vXOvuE167CtIc3OyItco7N/dpRtBbYOsPsXCz7X/PMnlGjYjSGuZJgM1Y7mmew7BKf9BqvLX2tnOVy1BBUsxQ==} - get-intrinsic@1.2.4: resolution: {integrity: sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==} engines: {node: '>= 0.4'} @@ -4924,10 +5032,6 @@ packages: resolution: {integrity: sha512-ts6Wi+2j3jQjqi70w5AlN8DFnkSwC+MqmxEzdEALB2qXZYV3X/b1CTfgPLGJNMeAWxdPfU8FO1ms3NUfaHCPYg==} engines: {node: '>=10'} - get-stream@8.0.1: - resolution: {integrity: sha512-VaUJspBffn/LMCJVoMvSAdmscJyS1auj5Zulnn5UoYcY531UWmdwhRWkcGKnGU93m5HSXP9LP2usOryrBtQowA==} - engines: {node: '>=16'} - get-stream@9.0.1: resolution: {integrity: sha512-kVCxPF3vQM/N0B1PmoqVUqgHP+EeVjmZSQn+1oCRPxd2P21P2F19lIgbR3HBosbB1PUhOAoctJnfEn2GbN2eZA==} engines: {node: '>=18'} @@ -5151,10 +5255,6 @@ packages: resolution: {integrity: sha512-B4FFZ6q/T2jhhksgkbEW3HBvWIfDW85snkQgawt07S7J5QXTk6BkNV+0yAeZrM5QpMAdYlocGoljn0sJ/WQkFw==} engines: {node: '>=10.17.0'} - human-signals@5.0.0: - resolution: {integrity: sha512-AXcZb6vzzrFAUE61HnN4mpLqd/cSIwNQjtNWR0euPm6y0iqx3G4gOXaIDdtdDwZmhwe82LA6+zinmW4UBWVePQ==} - engines: {node: '>=16.17.0'} - human-signals@8.0.0: resolution: {integrity: sha512-/1/GPCpDUCCYwlERiYjxoczfP0zfvZMU/OWgQPMya9AbAE24vseigFdhAMObpc8Q4lc/kjutPfUddDYyAmejnA==} engines: {node: '>=18.18.0'} @@ -5336,10 +5436,6 @@ packages: resolution: {integrity: sha512-hFoiJiTl63nn+kstHGBtewWSKnQLpyb155KHheA1l39uvtO9nWIop1p3udqPcUd/xbF1VLMO4n7OI6p7RbngDg==} engines: {node: '>=8'} - is-stream@3.0.0: - resolution: {integrity: sha512-LnQR4bZ9IADDRSkvpqMGvt/tEJWclzklNgSw48V5EAaAeDd6qGvN8ei6k5p0tvxSR171VmGyHuTiAOfxAbr8kA==} - engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - is-stream@4.0.1: resolution: {integrity: sha512-Dnz92NInDqYckGEUJv689RbRiTSEHCQ7wOVeALbkOz999YpqT46yMRIGtSNl2iCL1waAZSx40+h59NV/EwzV/A==} engines: {node: '>=18'} @@ -5840,9 +5936,6 @@ packages: resolution: {integrity: sha512-lyuxPGr/Wfhrlem2CL/UcnUc1zcqKAImBDzukY7Y5F/yQiNdko6+fRLevlw1HgMySw7f611UIY408EtxRSoK3Q==} hasBin: true - loupe@3.1.1: - resolution: {integrity: sha512-edNu/8D5MKVfGVFRhFf8aAxiTM6Wumfz5XsaatSxlD3w4R1d/WEKUTydCdPGbl9K7QG/Ca3GnDV2sIKIpXRQcw==} - lower-case@2.0.2: resolution: {integrity: sha512-7fm3l3NAF9WfN6W3JOmf5drwpVqX78JtoGJ3A6W0a6ZnldM41w2fV5D490psKFTpMds8TJse/eHLFFsNHHjHgg==} @@ -5859,6 +5952,9 @@ packages: magic-string@0.30.17: resolution: {integrity: sha512-sNPKHvyjVf7gyjwS4xGTaW/mCnF8wnjtifKBEhxfZ7E/S8tQ0rssrwGNn6q8JH/ohItJfSQp9mBtQYuTlH5QnA==} + magic-string@0.30.21: + resolution: {integrity: sha512-vd2F4YUyEXKGcLHoq+TEyCjxueSeHnFxyyjNp80yg0XV4vUhnDer/lvvlqM/arB5bXQN5K2/3oinyCRyx8T2CQ==} + make-dir@2.1.0: resolution: {integrity: sha512-LS9X+dc8KLxXCb8dni79fLIIUA5VyZoyjSMCwTluaXA0o27cCK0bhXkpgw+sTXVpPy/lSO57ilRixqk0vDmtRA==} engines: {node: '>=6'} @@ -6159,10 +6255,6 @@ packages: resolution: {integrity: sha512-OqbOk5oEQeAZ8WXWydlu9HJjz9WVdEIvamMCcXmuqUYjTknH/sqsWvhQ3vgwKFRR1HpjvNBKQ37nbJgYzGqGcg==} engines: {node: '>=6'} - mimic-fn@4.0.0: - resolution: {integrity: sha512-vqiC06CuhBTUdZH+RYl8sFrL096vA45Ok5ISO6sE/Mr1jRbGH4Csnhi8f3wKVl7x8mO4Au7Ir9D3Oyv1VYMFJw==} - engines: {node: '>=12'} - minimatch@10.1.1: resolution: {integrity: sha512-enIvLvRAFZYXJzkCYG5RKmPfrFArdLv+R+lbQ53BmIMLIry74bjKzX6iHAm8WYamJkhSSEabrWN5D97XnKObjQ==} engines: {node: 20 || >=22} @@ -6218,6 +6310,11 @@ packages: mz@2.7.0: resolution: {integrity: sha512-z81GNO7nnYMEhrGh9LeymoE4+Yr0Wn5McHIZMK5cfQCl+NDX08sCZgUc9/6MHni9IWuFLm1Z3HTCXu2z9fN62Q==} + nanoid@3.3.11: + resolution: {integrity: sha512-N8SpfPUnUp1bK+PMYW8qSWdl9U+wwNWI4QKxOYDy9JAro3WMX7p2OeVRF9v+347pnakNevPmiHhNmZ2HbFA76w==} + engines: {node: ^10 || ^12 || ^13.7 || ^14 || >=15.0.1} + hasBin: true + nanoid@3.3.8: resolution: {integrity: sha512-WNLf5Sd8oZxOm+TzppcYk8gVOgP+l58xNy58D0nbUnOxOWRWvlcCV4kUF7ltmI6PsrLl/BgKEyS4mqsGChFN0w==} engines: {node: ^10 || ^12 || ^13.7 || ^14 || >=15.0.1} @@ -6288,10 +6385,6 @@ packages: resolution: {integrity: sha512-S48WzZW777zhNIrn7gxOlISNAqi9ZC/uQFnRdbeIHhZhCA6UqpkOT8T1G7BvfdgP4Er8gF4sUbaS0i7QvIfCWw==} engines: {node: '>=8'} - npm-run-path@5.3.0: - resolution: {integrity: sha512-ppwTtiJZq0O/ai0z7yfudtBpWIoxM8yE6nHi1X47eFR2EWORqfbu6CnPlNsjeN683eT0qG6H/Pyf9fCcvjnnnQ==} - engines: {node: ^12.20.0 || ^14.13.1 || >=16.0.0} - npm-run-path@6.0.0: resolution: {integrity: sha512-9qny7Z9DsQU8Ou39ERsPU4OZQlSTP47ShQzuKZ6PRXpYLtIFgl/DEBYEXKlvcEa+9tHVcK8CF81Y2V72qaZhWA==} engines: {node: '>=18'} @@ -6333,6 +6426,9 @@ packages: resolution: {integrity: sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g==} engines: {node: '>= 0.4'} + obug@2.1.1: + resolution: {integrity: sha512-uTqF9MuPraAQ+IsnPf366RG4cP9RtUi7MLO1N3KEc+wb0a6yKpeL0lmk2IB1jY5KHPAlTc6T/JRdC/YqxHNwkQ==} + on-exit-leak-free@2.1.2: resolution: {integrity: sha512-0eJJY6hXLGf1udHwfNftBqH+g73EU4B504nZeKpz1sYRKafAghwxEJunB2O7rDZkL4PGfsMVnTXZ2EjibbqcsA==} engines: {node: '>=14.0.0'} @@ -6356,10 +6452,6 @@ packages: resolution: {integrity: sha512-kbpaSSGJTWdAY5KPVeMOKXSrPtr8C8C7wodJbcsd51jRnmD+GZu8Y0VoU6Dm5Z4vWr0Ig/1NKuWRKf7j5aaYSg==} engines: {node: '>=6'} - onetime@6.0.0: - resolution: {integrity: sha512-1FlR+gjXK7X+AsAHso35MnyN5KqGwJRi/31ft6x0M194ht7S+rWAvd7PHss9xSKMzE0asv1pyIHaJYq+BbacAQ==} - engines: {node: '>=12'} - oniguruma-parser@0.12.1: resolution: {integrity: sha512-8Unqkvk1RYc6yq2WBYRj4hdnsAxVze8i7iPfQr8e4uSP3tRv0rpZcbGUDvxfQQcdwHt/e9PrMvGCsa8OqG9X3w==} @@ -6521,12 +6613,8 @@ packages: resolution: {integrity: sha512-gDKb8aZMDeD/tZWs9P6+q0J9Mwkdl6xMV8TjnGP3qJVJ06bdMgkbBlLU8IdfOsIsFz2BW1rNVT3XuNEl8zPAvw==} engines: {node: '>=8'} - pathe@1.1.2: - resolution: {integrity: sha512-whLdWMYL2TwI08hn8/ZqAbrVemu0LNaNNJZX73O6qaIdCTfXutsLhMkjdENX0qhsQ9uIimo4/aQOmXkoon2nDQ==} - - pathval@2.0.0: - resolution: {integrity: sha512-vE7JKRyES09KiunauX7nd2Q9/L7lhok4smP9RZTDeD4MVs72Dp2qNFVz39Nz5a0FVEW0BJR6C0DYrq6unoziZA==} - engines: {node: '>= 14.16'} + pathe@2.0.3: + resolution: {integrity: sha512-WUjGcAqP1gQacoQe+OBJsFA7Ld4DyXuUIjZ5cc75cLHvJ7dtNsTugphxIADwspS+AraAUePCKrSVtPLFj/F88w==} picocolors@1.1.1: resolution: {integrity: sha512-xceH2snhtb5M9liqDsmEw56le376mTZkEX/jEb/RxNFyegNul7eNslCXP9FDj/Lcu0X8KEyMceP2ntpaHrDEVA==} @@ -6643,6 +6731,10 @@ packages: resolution: {integrity: sha512-6oz2beyjc5VMn/KV1pPw8fliQkhBXrVn1Z3TVyqZxU8kZpzEKhBdmCFqI6ZbmGtamQvQGuU1sgPTk8ZrXDD7jQ==} engines: {node: ^10 || ^12 || >=14} + postcss@8.5.6: + resolution: {integrity: sha512-3Ybi1tAuwAP9s0r1UQ2J4n5Y0G05bJkpUIO0/bI9MhwmD70S5aTWbXGBwxHrelT+XM1k6dM0pk+SwNkpTRN7Pg==} + engines: {node: ^10 || ^12 || >=14} + preferred-pm@4.1.1: resolution: {integrity: sha512-rU+ZAv1Ur9jAUZtGPebQVQPzdGhNzaEiQ7VL9+cjsAWPHFYOccNXPNiev1CCDSOg/2j7UujM7ojNhpkuILEVNQ==} engines: {node: '>=18.12'} @@ -7059,8 +7151,8 @@ packages: deprecated: Rimraf versions prior to v4 are no longer supported hasBin: true - rollup@4.21.2: - resolution: {integrity: sha512-e3TapAgYf9xjdLvKQCkQTnbTKd4a6jwlpQSJJFokHGaX2IVjoEqkIIhiQfqsi0cdwlOD+tQGuOd5AJkc5RngBw==} + rollup@4.57.1: + resolution: {integrity: sha512-oQL6lgK3e2QZeQ7gcgIkS2YZPg5slw37hYufJ3edKlfQSGGm8ICoxswK15ntSzF/a8+h7ekRy7k7oWc3BQ7y8A==} engines: {node: '>=18.0.0', npm: '>=8.0.0'} hasBin: true @@ -7330,8 +7422,8 @@ packages: resolution: {integrity: sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==} engines: {node: '>= 0.8'} - std-env@3.7.0: - resolution: {integrity: sha512-JPbdCEQLj1w5GilpiHAx3qJvFndqybBysA3qUOnznweH4QbNYUsW/ea8QzSrnh0vNsezMMw5bcVool8lM0gwzg==} + std-env@3.10.0: + resolution: {integrity: sha512-5GS12FdOZNliM5mAOxFRg7Ir0pWz8MdpYm6AY6VPkGpbA7ZzmbzNcBJQ0GPvvyWgcY7QAhCgf9Uy89I03faLkg==} stream-buffers@2.2.0: resolution: {integrity: sha512-uyQK/mx5QjHun80FLJTfaWE7JtwfRMKBLkMne6udYOmvH0CawotVa7TfgYHzAnpphn4+TweIx1QKMnRIbipmUg==} @@ -7391,10 +7483,6 @@ packages: resolution: {integrity: sha512-BrpvfNAE3dcvq7ll3xVumzjKjZQ5tI1sEUIKr3Uoks0XUl45St3FlatVqef9prk4jRDzhW6WZg+3bk93y6pLjA==} engines: {node: '>=6'} - strip-final-newline@3.0.0: - resolution: {integrity: sha512-dOESqjYr96iWYylGObzd39EuNTa5VJxyvVAEm5Jnh7KGo75V43Hk1odPQkNDyXNmUR6k+gEiDVXnjB8HJ3crXw==} - engines: {node: '>=12'} - strip-final-newline@4.0.0: resolution: {integrity: sha512-aulFJcD6YK8V1G7iRB5tigAP4TsHBZZrOV8pjV++zdUwmeV8uzbY7yn6h9MswN62adStNZFuCIx4haBnRuMDaw==} engines: {node: '>=18'} @@ -7521,6 +7609,10 @@ packages: tinycolor2@1.6.0: resolution: {integrity: sha512-XPaBkWQJdsf3pLKJV9p4qN/S+fm2Oj8AIPo1BTUhg5oxkvm9+SVEGFdhyOz7tTdUTfvxMiAs4sp6/eZO2Ew+pw==} + tinyexec@1.0.2: + resolution: {integrity: sha512-W/KYk+NFhkmsYpuHq5JykngiOCnxeVL8v8dFnqxSD8qEEdRfXk1SDM6JzNqcERbcGYj9tMrDQBYV9cjgnunFIg==} + engines: {node: '>=18'} + tinyglobby@0.2.14: resolution: {integrity: sha512-tX5e7OM1HnYr2+a2C/4V0htOcSQcoSTH9KgJnVvNm5zm/cyEWKJ7j7YutsH9CxMdtOkkLFy2AHrMci9IM8IPZQ==} engines: {node: '>=12.0.0'} @@ -7532,20 +7624,12 @@ packages: tinygradient@1.1.5: resolution: {integrity: sha512-8nIfc2vgQ4TeLnk2lFj4tRLvvJwEfQuabdsmvDdQPT0xlk9TaNtpGd6nNRxXoK6vQhN6RSzj+Cnp5tTQmpxmbw==} - tinypool@1.0.1: - resolution: {integrity: sha512-URZYihUbRPcGv95En+sz6MfghfIc2OJ1sv/RmhWZLouPY0/8Vo80viwPvg3dlaS9fuq7fQMEfgRRK7BBZThBEA==} - engines: {node: ^18.0.0 || >=20.0.0} - tinypool@1.1.1: resolution: {integrity: sha512-Zba82s87IFq9A9XmjiX5uZA/ARWDrB03OHlq+Vw1fSdt0I+4/Kutwy8BP4Y/y/aORMo61FQ0vIb5j44vSo5Pkg==} engines: {node: ^18.0.0 || >=20.0.0} - tinyrainbow@1.2.0: - resolution: {integrity: sha512-weEDEq7Z5eTHPDh4xjX789+fHfF+P8boiFB+0vbWzpbnbsEr/GRaohi/uMKxg8RZMXnl1ItAi/IUHWMsjDV7kQ==} - engines: {node: '>=14.0.0'} - - tinyspy@3.0.0: - resolution: {integrity: sha512-q5nmENpTHgiPVd1cJDDc9cVoYN5x4vCvwT3FMilvKPKneCBZAxn2YWQjDF0UMcE9k0Cay1gBiDfTMU0g+mPMQA==} + tinyrainbow@3.0.3: + resolution: {integrity: sha512-PSkbLUoxOFRzJYjjxHJt9xro7D+iilgMX/C9lawzVuYiIdcihh9DXmVibBe8lmcFrRi/VzlPjBxbN7rH24q8/Q==} engines: {node: '>=14.0.0'} tmp@0.0.33: @@ -7643,6 +7727,9 @@ packages: undici-types@5.26.5: resolution: {integrity: sha512-JlCMO+ehdEIKqlFxk6IfVoAUVmgz7cU7zD/h9XZ0qzeosSHmUJVOzSQvvYSYWXkFXC+IfLKSIffhv0sVZup6pA==} + undici-types@6.21.0: + resolution: {integrity: sha512-iwDZqg0QAGrg9Rav5H4n0M64c3mkR59cJ6wQp+7C4nI0gsmExaedaYLNO44eT4AtBBwjbTiGPMlt2Md0T9H9JQ==} + unhead@2.1.2: resolution: {integrity: sha512-vSihrxyb+zsEUfEbraZBCjdE0p/WSoc2NGDrpwwSNAwuPxhYK1nH3eegf02IENLpn1sUhL8IoO84JWmRQ6tILA==} @@ -7765,27 +7852,27 @@ packages: vfile@6.0.2: resolution: {integrity: sha512-zND7NlS8rJYb/sPqkb13ZvbbUoExdbi4w3SfRrMq6R3FvnLQmmfpajJNITuuYm6AZ5uao9vy4BAos3EXBPf2rg==} - vite-node@2.0.5: - resolution: {integrity: sha512-LdsW4pxj0Ot69FAoXZ1yTnA9bjGohr2yNBU7QKRxpz8ITSkhuDl6h3zS/tvgz4qrNjeRnvrWeXQ8ZF7Um4W00Q==} - engines: {node: ^18.0.0 || >=20.0.0} - hasBin: true - - vite@5.4.3: - resolution: {integrity: sha512-IH+nl64eq9lJjFqU+/yrRnrHPVTlgy42/+IzbOdaFDVlyLgI/wDlf+FCobXLX1cT0X5+7LMyH1mIy2xJdLfo8Q==} - engines: {node: ^18.0.0 || >=20.0.0} + vite@7.3.1: + resolution: {integrity: sha512-w+N7Hifpc3gRjZ63vYBXA56dvvRlNWRczTdmCBBa+CotUzAPf5b7YMdMR/8CQoeYE5LX3W4wj6RYTgonm1b9DA==} + engines: {node: ^20.19.0 || >=22.12.0} hasBin: true peerDependencies: - '@types/node': ^18.0.0 || >=20.0.0 - less: '*' + '@types/node': ^20.19.0 || >=22.12.0 + jiti: '>=1.21.0' + less: ^4.0.0 lightningcss: ^1.21.0 - sass: '*' - sass-embedded: '*' - stylus: '*' - sugarss: '*' - terser: ^5.4.0 + sass: ^1.70.0 + sass-embedded: ^1.70.0 + stylus: '>=0.54.8' + sugarss: ^5.0.0 + terser: ^5.16.0 + tsx: ^4.8.1 + yaml: ^2.4.2 peerDependenciesMeta: '@types/node': optional: true + jiti: + optional: true less: optional: true lightningcss: @@ -7800,24 +7887,37 @@ packages: optional: true terser: optional: true + tsx: + optional: true + yaml: + optional: true - vitest@2.0.5: - resolution: {integrity: sha512-8GUxONfauuIdeSl5f9GTgVEpg5BTOlplET4WEDaeY2QBiN8wSm68vxN/tb5z405OwppfoCavnwXafiaYBC/xOA==} - engines: {node: ^18.0.0 || >=20.0.0} + vitest@4.0.18: + resolution: {integrity: sha512-hOQuK7h0FGKgBAas7v0mSAsnvrIgAvWmRFjmzpJ7SwFHH3g1k2u37JtYwOwmEKhK6ZO3v9ggDBBm0La1LCK4uQ==} + engines: {node: ^20.0.0 || ^22.0.0 || >=24.0.0} hasBin: true peerDependencies: '@edge-runtime/vm': '*' - '@types/node': ^18.0.0 || >=20.0.0 - '@vitest/browser': 2.0.5 - '@vitest/ui': 2.0.5 + '@opentelemetry/api': ^1.9.0 + '@types/node': ^20.0.0 || ^22.0.0 || >=24.0.0 + '@vitest/browser-playwright': 4.0.18 + '@vitest/browser-preview': 4.0.18 + '@vitest/browser-webdriverio': 4.0.18 + '@vitest/ui': 4.0.18 happy-dom: '*' jsdom: '*' peerDependenciesMeta: '@edge-runtime/vm': optional: true + '@opentelemetry/api': + optional: true '@types/node': optional: true - '@vitest/browser': + '@vitest/browser-playwright': + optional: true + '@vitest/browser-preview': + optional: true + '@vitest/browser-webdriverio': optional: true '@vitest/ui': optional: true @@ -7864,6 +7964,9 @@ packages: resolution: {integrity: sha512-yd1RBzSGanHkitROoPFd6qsrxt+oFhg/129YzheDGqeustzX0vTZJZsSsQjVQC4yzBQ56K55XU8gaNCtIzOnTg==} engines: {node: '>=10.13.0'} + webpack-virtual-modules@0.6.2: + resolution: {integrity: sha512-66/V2i5hQanC51vBQKPH4aI8NMAcBW59FVBs+rC7eGHupMyfn34q7rZIE+ETlJ+XTevqfUhVVBgSUNSW2flEUQ==} + webpack@5.100.2: resolution: {integrity: sha512-QaNKAvGCDRh3wW1dsDjeMdDXwZm2vqq3zn6Pvq4rHOEOGSaUMgOOjG2Y9ZbIGzpfkJk9ZYTHpDqgDfeBDcnLaw==} engines: {node: '>=10.13.0'} @@ -9259,139 +9362,148 @@ snapshots: dependencies: tslib: 2.8.1 - '@esbuild/aix-ppc64@0.21.5': + '@esbuild/aix-ppc64@0.27.2': optional: true '@esbuild/android-arm64@0.17.19': optional: true - '@esbuild/android-arm64@0.21.5': + '@esbuild/android-arm64@0.27.2': optional: true '@esbuild/android-arm@0.17.19': optional: true - '@esbuild/android-arm@0.21.5': + '@esbuild/android-arm@0.27.2': optional: true '@esbuild/android-x64@0.17.19': optional: true - '@esbuild/android-x64@0.21.5': + '@esbuild/android-x64@0.27.2': optional: true '@esbuild/darwin-arm64@0.17.19': optional: true - '@esbuild/darwin-arm64@0.21.5': + '@esbuild/darwin-arm64@0.27.2': optional: true '@esbuild/darwin-x64@0.17.19': optional: true - '@esbuild/darwin-x64@0.21.5': + '@esbuild/darwin-x64@0.27.2': optional: true '@esbuild/freebsd-arm64@0.17.19': optional: true - '@esbuild/freebsd-arm64@0.21.5': + '@esbuild/freebsd-arm64@0.27.2': optional: true '@esbuild/freebsd-x64@0.17.19': optional: true - '@esbuild/freebsd-x64@0.21.5': + '@esbuild/freebsd-x64@0.27.2': optional: true '@esbuild/linux-arm64@0.17.19': optional: true - '@esbuild/linux-arm64@0.21.5': + '@esbuild/linux-arm64@0.27.2': optional: true '@esbuild/linux-arm@0.17.19': optional: true - '@esbuild/linux-arm@0.21.5': + '@esbuild/linux-arm@0.27.2': optional: true '@esbuild/linux-ia32@0.17.19': optional: true - '@esbuild/linux-ia32@0.21.5': + '@esbuild/linux-ia32@0.27.2': optional: true '@esbuild/linux-loong64@0.17.19': optional: true - '@esbuild/linux-loong64@0.21.5': + '@esbuild/linux-loong64@0.27.2': optional: true '@esbuild/linux-mips64el@0.17.19': optional: true - '@esbuild/linux-mips64el@0.21.5': + '@esbuild/linux-mips64el@0.27.2': optional: true '@esbuild/linux-ppc64@0.17.19': optional: true - '@esbuild/linux-ppc64@0.21.5': + '@esbuild/linux-ppc64@0.27.2': optional: true '@esbuild/linux-riscv64@0.17.19': optional: true - '@esbuild/linux-riscv64@0.21.5': + '@esbuild/linux-riscv64@0.27.2': optional: true '@esbuild/linux-s390x@0.17.19': optional: true - '@esbuild/linux-s390x@0.21.5': + '@esbuild/linux-s390x@0.27.2': optional: true '@esbuild/linux-x64@0.17.19': optional: true - '@esbuild/linux-x64@0.21.5': + '@esbuild/linux-x64@0.27.2': + optional: true + + '@esbuild/netbsd-arm64@0.27.2': optional: true '@esbuild/netbsd-x64@0.17.19': optional: true - '@esbuild/netbsd-x64@0.21.5': + '@esbuild/netbsd-x64@0.27.2': + optional: true + + '@esbuild/openbsd-arm64@0.27.2': optional: true '@esbuild/openbsd-x64@0.17.19': optional: true - '@esbuild/openbsd-x64@0.21.5': + '@esbuild/openbsd-x64@0.27.2': + optional: true + + '@esbuild/openharmony-arm64@0.27.2': optional: true '@esbuild/sunos-x64@0.17.19': optional: true - '@esbuild/sunos-x64@0.21.5': + '@esbuild/sunos-x64@0.27.2': optional: true '@esbuild/win32-arm64@0.17.19': optional: true - '@esbuild/win32-arm64@0.21.5': + '@esbuild/win32-arm64@0.27.2': optional: true '@esbuild/win32-ia32@0.17.19': optional: true - '@esbuild/win32-ia32@0.21.5': + '@esbuild/win32-ia32@0.27.2': optional: true '@esbuild/win32-x64@0.17.19': optional: true - '@esbuild/win32-x64@0.21.5': + '@esbuild/win32-x64@0.27.2': optional: true '@fastify/ajv-compiler@3.6.0': @@ -9463,7 +9575,7 @@ snapshots: '@jest/console@29.7.0': dependencies: '@jest/types': 29.6.3 - '@types/node': 20.14.11 + '@types/node': 20.19.31 chalk: 4.1.2 jest-message-util: 29.7.0 jest-util: 29.7.0 @@ -9476,14 +9588,14 @@ snapshots: '@jest/test-result': 29.7.0 '@jest/transform': 29.7.0 '@jest/types': 29.6.3 - '@types/node': 20.14.11 + '@types/node': 20.19.31 ansi-escapes: 4.3.2 chalk: 4.1.2 ci-info: 3.9.0 exit: 0.1.2 graceful-fs: 4.2.11 jest-changed-files: 29.7.0 - jest-config: 29.7.0(@types/node@20.14.11) + jest-config: 29.7.0(@types/node@20.19.31) jest-haste-map: 29.7.0 jest-message-util: 29.7.0 jest-regex-util: 29.6.3 @@ -9556,7 +9668,7 @@ snapshots: '@jest/transform': 29.7.0 '@jest/types': 29.6.3 '@jridgewell/trace-mapping': 0.3.25 - '@types/node': 20.14.11 + '@types/node': 20.19.31 chalk: 4.1.2 collect-v8-coverage: 1.0.2 exit: 0.1.2 @@ -9633,7 +9745,7 @@ snapshots: dependencies: '@types/istanbul-lib-coverage': 2.0.6 '@types/istanbul-reports': 3.0.4 - '@types/node': 20.14.11 + '@types/node': 20.19.31 '@types/yargs': 15.0.19 chalk: 4.1.2 @@ -9642,7 +9754,7 @@ snapshots: '@jest/schemas': 29.6.3 '@types/istanbul-lib-coverage': 2.0.6 '@types/istanbul-reports': 3.0.4 - '@types/node': 20.14.11 + '@types/node': 20.19.31 '@types/yargs': 17.0.33 chalk: 4.1.2 @@ -9663,6 +9775,8 @@ snapshots: '@jridgewell/sourcemap-codec@1.5.0': {} + '@jridgewell/sourcemap-codec@1.5.5': {} + '@jridgewell/trace-mapping@0.3.25': dependencies: '@jridgewell/resolve-uri': 3.1.2 @@ -10501,52 +10615,79 @@ snapshots: dependencies: '@rnx-kit/tools-node': 3.0.0 - '@rollup/rollup-android-arm-eabi@4.21.2': + '@rollup/rollup-android-arm-eabi@4.57.1': + optional: true + + '@rollup/rollup-android-arm64@4.57.1': optional: true - '@rollup/rollup-android-arm64@4.21.2': + '@rollup/rollup-darwin-arm64@4.57.1': optional: true - '@rollup/rollup-darwin-arm64@4.21.2': + '@rollup/rollup-darwin-x64@4.57.1': optional: true - '@rollup/rollup-darwin-x64@4.21.2': + '@rollup/rollup-freebsd-arm64@4.57.1': optional: true - '@rollup/rollup-linux-arm-gnueabihf@4.21.2': + '@rollup/rollup-freebsd-x64@4.57.1': optional: true - '@rollup/rollup-linux-arm-musleabihf@4.21.2': + '@rollup/rollup-linux-arm-gnueabihf@4.57.1': optional: true - '@rollup/rollup-linux-arm64-gnu@4.21.2': + '@rollup/rollup-linux-arm-musleabihf@4.57.1': optional: true - '@rollup/rollup-linux-arm64-musl@4.21.2': + '@rollup/rollup-linux-arm64-gnu@4.57.1': optional: true - '@rollup/rollup-linux-powerpc64le-gnu@4.21.2': + '@rollup/rollup-linux-arm64-musl@4.57.1': optional: true - '@rollup/rollup-linux-riscv64-gnu@4.21.2': + '@rollup/rollup-linux-loong64-gnu@4.57.1': optional: true - '@rollup/rollup-linux-s390x-gnu@4.21.2': + '@rollup/rollup-linux-loong64-musl@4.57.1': optional: true - '@rollup/rollup-linux-x64-gnu@4.21.2': + '@rollup/rollup-linux-ppc64-gnu@4.57.1': optional: true - '@rollup/rollup-linux-x64-musl@4.21.2': + '@rollup/rollup-linux-ppc64-musl@4.57.1': optional: true - '@rollup/rollup-win32-arm64-msvc@4.21.2': + '@rollup/rollup-linux-riscv64-gnu@4.57.1': optional: true - '@rollup/rollup-win32-ia32-msvc@4.21.2': + '@rollup/rollup-linux-riscv64-musl@4.57.1': optional: true - '@rollup/rollup-win32-x64-msvc@4.21.2': + '@rollup/rollup-linux-s390x-gnu@4.57.1': + optional: true + + '@rollup/rollup-linux-x64-gnu@4.57.1': + optional: true + + '@rollup/rollup-linux-x64-musl@4.57.1': + optional: true + + '@rollup/rollup-openbsd-x64@4.57.1': + optional: true + + '@rollup/rollup-openharmony-arm64@4.57.1': + optional: true + + '@rollup/rollup-win32-arm64-msvc@4.57.1': + optional: true + + '@rollup/rollup-win32-ia32-msvc@4.57.1': + optional: true + + '@rollup/rollup-win32-x64-gnu@4.57.1': + optional: true + + '@rollup/rollup-win32-x64-msvc@4.57.1': optional: true '@rsbuild/core@1.3.5': @@ -11130,6 +11271,8 @@ snapshots: '@socket.io/component-emitter@3.1.2': {} + '@standard-schema/spec@1.1.0': {} + '@svgr/babel-plugin-add-jsx-attribute@8.0.0(@babel/core@7.25.2)': dependencies: '@babel/core': 7.25.2 @@ -11322,6 +11465,11 @@ snapshots: dependencies: '@babel/types': 7.25.6 + '@types/chai@5.2.3': + dependencies: + '@types/deep-eql': 4.0.2 + assertion-error: 2.0.1 + '@types/connect@3.4.38': dependencies: '@types/node': 20.14.11 @@ -11338,6 +11486,8 @@ snapshots: '@types/dedent@0.7.2': {} + '@types/deep-eql@4.0.2': {} + '@types/eslint-scope@3.7.7': dependencies: '@types/eslint': 9.6.1 @@ -11365,7 +11515,7 @@ snapshots: '@types/graceful-fs@4.1.9': dependencies: - '@types/node': 20.14.11 + '@types/node': 20.19.31 '@types/gradient-string@1.1.6': dependencies: @@ -11377,7 +11527,7 @@ snapshots: '@types/http-proxy@1.17.16': dependencies: - '@types/node': 20.14.11 + '@types/node': 20.19.31 '@types/istanbul-lib-coverage@2.0.6': {} @@ -11402,7 +11552,7 @@ snapshots: '@types/jsonwebtoken@9.0.6': dependencies: - '@types/node': 20.14.11 + '@types/node': 20.19.31 '@types/mdast@4.0.4': dependencies: @@ -11420,6 +11570,10 @@ snapshots: dependencies: undici-types: 5.26.5 + '@types/node@20.19.31': + dependencies: + undici-types: 6.21.0 + '@types/prop-types@15.7.12': {} '@types/react-dom@17.0.25': @@ -11465,7 +11619,7 @@ snapshots: '@types/ws@8.18.0': dependencies: - '@types/node': 20.14.11 + '@types/node': 20.19.31 '@types/yargs-parser@21.0.3': {} @@ -11488,38 +11642,44 @@ snapshots: optionalDependencies: react: 19.2.4 - '@vitest/expect@2.0.5': + '@vitest/expect@4.0.18': dependencies: - '@vitest/spy': 2.0.5 - '@vitest/utils': 2.0.5 - chai: 5.1.1 - tinyrainbow: 1.2.0 + '@standard-schema/spec': 1.1.0 + '@types/chai': 5.2.3 + '@vitest/spy': 4.0.18 + '@vitest/utils': 4.0.18 + chai: 6.2.2 + tinyrainbow: 3.0.3 - '@vitest/pretty-format@2.0.5': + '@vitest/mocker@4.0.18(vite@7.3.1(@types/node@20.19.31)(jiti@2.6.1)(lightningcss@1.28.2)(terser@5.31.3)(yaml@2.8.2))': dependencies: - tinyrainbow: 1.2.0 + '@vitest/spy': 4.0.18 + estree-walker: 3.0.3 + magic-string: 0.30.21 + optionalDependencies: + vite: 7.3.1(@types/node@20.19.31)(jiti@2.6.1)(lightningcss@1.28.2)(terser@5.31.3)(yaml@2.8.2) - '@vitest/runner@2.0.5': + '@vitest/pretty-format@4.0.18': dependencies: - '@vitest/utils': 2.0.5 - pathe: 1.1.2 + tinyrainbow: 3.0.3 - '@vitest/snapshot@2.0.5': + '@vitest/runner@4.0.18': dependencies: - '@vitest/pretty-format': 2.0.5 - magic-string: 0.30.17 - pathe: 1.1.2 + '@vitest/utils': 4.0.18 + pathe: 2.0.3 - '@vitest/spy@2.0.5': + '@vitest/snapshot@4.0.18': dependencies: - tinyspy: 3.0.0 + '@vitest/pretty-format': 4.0.18 + magic-string: 0.30.21 + pathe: 2.0.3 - '@vitest/utils@2.0.5': + '@vitest/spy@4.0.18': {} + + '@vitest/utils@4.0.18': dependencies: - '@vitest/pretty-format': 2.0.5 - estree-walker: 3.0.3 - loupe: 3.1.1 - tinyrainbow: 1.2.0 + '@vitest/pretty-format': 4.0.18 + tinyrainbow: 3.0.3 '@vscode/sudo-prompt@9.3.1': {} @@ -12025,13 +12185,7 @@ snapshots: ccount@2.0.1: {} - chai@5.1.1: - dependencies: - assertion-error: 2.0.1 - check-error: 2.1.1 - deep-eql: 5.0.2 - loupe: 3.1.1 - pathval: 2.0.0 + chai@6.2.2: {} chalk@2.4.2: dependencies: @@ -12063,8 +12217,6 @@ snapshots: chardet@0.7.0: {} - check-error@2.1.1: {} - chokidar@3.6.0: dependencies: anymatch: 3.1.3 @@ -12079,7 +12231,7 @@ snapshots: chrome-launcher@0.15.2: dependencies: - '@types/node': 20.14.11 + '@types/node': 20.19.31 escape-string-regexp: 4.0.0 is-wsl: 2.2.0 lighthouse-logger: 1.4.2 @@ -12090,7 +12242,7 @@ snapshots: chromium-edge-launcher@0.2.0: dependencies: - '@types/node': 20.14.11 + '@types/node': 20.19.31 escape-string-regexp: 4.0.0 is-wsl: 2.2.0 lighthouse-logger: 1.4.2 @@ -12291,13 +12443,13 @@ snapshots: optionalDependencies: typescript: 5.8.3 - create-jest@29.7.0(@types/node@20.14.11): + create-jest@29.7.0(@types/node@20.19.31): dependencies: '@jest/types': 29.6.3 chalk: 4.1.2 exit: 0.1.2 graceful-fs: 4.2.11 - jest-config: 29.7.0(@types/node@20.14.11) + jest-config: 29.7.0(@types/node@20.19.31) jest-util: 29.7.0 prompts: 2.4.2 transitivePeerDependencies: @@ -12389,8 +12541,6 @@ snapshots: dependencies: type-detect: 4.0.8 - deep-eql@5.0.2: {} - deep-equal@1.0.1: {} deepmerge@4.3.1: {} @@ -12583,6 +12733,8 @@ snapshots: es-module-lexer@1.5.4: {} + es-module-lexer@1.7.0: {} + es-object-atoms@1.1.1: dependencies: es-errors: 1.3.0 @@ -12633,31 +12785,34 @@ snapshots: '@esbuild/win32-ia32': 0.17.19 '@esbuild/win32-x64': 0.17.19 - esbuild@0.21.5: + esbuild@0.27.2: optionalDependencies: - '@esbuild/aix-ppc64': 0.21.5 - '@esbuild/android-arm': 0.21.5 - '@esbuild/android-arm64': 0.21.5 - '@esbuild/android-x64': 0.21.5 - '@esbuild/darwin-arm64': 0.21.5 - '@esbuild/darwin-x64': 0.21.5 - '@esbuild/freebsd-arm64': 0.21.5 - '@esbuild/freebsd-x64': 0.21.5 - '@esbuild/linux-arm': 0.21.5 - '@esbuild/linux-arm64': 0.21.5 - '@esbuild/linux-ia32': 0.21.5 - '@esbuild/linux-loong64': 0.21.5 - '@esbuild/linux-mips64el': 0.21.5 - '@esbuild/linux-ppc64': 0.21.5 - '@esbuild/linux-riscv64': 0.21.5 - '@esbuild/linux-s390x': 0.21.5 - '@esbuild/linux-x64': 0.21.5 - '@esbuild/netbsd-x64': 0.21.5 - '@esbuild/openbsd-x64': 0.21.5 - '@esbuild/sunos-x64': 0.21.5 - '@esbuild/win32-arm64': 0.21.5 - '@esbuild/win32-ia32': 0.21.5 - '@esbuild/win32-x64': 0.21.5 + '@esbuild/aix-ppc64': 0.27.2 + '@esbuild/android-arm': 0.27.2 + '@esbuild/android-arm64': 0.27.2 + '@esbuild/android-x64': 0.27.2 + '@esbuild/darwin-arm64': 0.27.2 + '@esbuild/darwin-x64': 0.27.2 + '@esbuild/freebsd-arm64': 0.27.2 + '@esbuild/freebsd-x64': 0.27.2 + '@esbuild/linux-arm': 0.27.2 + '@esbuild/linux-arm64': 0.27.2 + '@esbuild/linux-ia32': 0.27.2 + '@esbuild/linux-loong64': 0.27.2 + '@esbuild/linux-mips64el': 0.27.2 + '@esbuild/linux-ppc64': 0.27.2 + '@esbuild/linux-riscv64': 0.27.2 + '@esbuild/linux-s390x': 0.27.2 + '@esbuild/linux-x64': 0.27.2 + '@esbuild/netbsd-arm64': 0.27.2 + '@esbuild/netbsd-x64': 0.27.2 + '@esbuild/openbsd-arm64': 0.27.2 + '@esbuild/openbsd-x64': 0.27.2 + '@esbuild/openharmony-arm64': 0.27.2 + '@esbuild/sunos-x64': 0.27.2 + '@esbuild/win32-arm64': 0.27.2 + '@esbuild/win32-ia32': 0.27.2 + '@esbuild/win32-x64': 0.27.2 escalade@3.2.0: {} @@ -12743,18 +12898,6 @@ snapshots: signal-exit: 3.0.7 strip-final-newline: 2.0.0 - execa@8.0.1: - dependencies: - cross-spawn: 7.0.6 - get-stream: 8.0.1 - human-signals: 5.0.0 - is-stream: 3.0.0 - merge-stream: 2.0.0 - npm-run-path: 5.3.0 - onetime: 6.0.0 - signal-exit: 4.1.0 - strip-final-newline: 3.0.0 - execa@9.5.2: dependencies: '@sindresorhus/merge-streams': 4.0.0 @@ -12778,6 +12921,8 @@ snapshots: dependencies: homedir-polyfill: 1.0.3 + expect-type@1.3.0: {} + expect@29.7.0: dependencies: '@jest/expect-utils': 29.7.0 @@ -13054,8 +13199,6 @@ snapshots: get-caller-file@2.0.5: {} - get-func-name@2.0.2: {} - get-intrinsic@1.2.4: dependencies: es-errors: 1.3.0 @@ -13090,8 +13233,6 @@ snapshots: get-stream@6.0.1: {} - get-stream@8.0.1: {} - get-stream@9.0.1: dependencies: '@sec-ant/readable-stream': 0.4.1 @@ -13442,8 +13583,6 @@ snapshots: human-signals@2.1.0: {} - human-signals@5.0.0: {} - human-signals@8.0.0: {} husky@9.1.6: {} @@ -13571,8 +13710,6 @@ snapshots: is-stream@2.0.1: {} - is-stream@3.0.0: {} - is-stream@4.0.1: {} is-subdir@1.2.0: @@ -13664,7 +13801,7 @@ snapshots: '@jest/expect': 29.7.0 '@jest/test-result': 29.7.0 '@jest/types': 29.6.3 - '@types/node': 20.14.11 + '@types/node': 20.19.31 chalk: 4.1.2 co: 4.6.0 dedent: 1.5.3 @@ -13684,16 +13821,16 @@ snapshots: - babel-plugin-macros - supports-color - jest-cli@29.7.0(@types/node@20.14.11): + jest-cli@29.7.0(@types/node@20.19.31): dependencies: '@jest/core': 29.7.0 '@jest/test-result': 29.7.0 '@jest/types': 29.6.3 chalk: 4.1.2 - create-jest: 29.7.0(@types/node@20.14.11) + create-jest: 29.7.0(@types/node@20.19.31) exit: 0.1.2 import-local: 3.1.0 - jest-config: 29.7.0(@types/node@20.14.11) + jest-config: 29.7.0(@types/node@20.19.31) jest-util: 29.7.0 jest-validate: 29.7.0 yargs: 17.7.2 @@ -13703,7 +13840,7 @@ snapshots: - supports-color - ts-node - jest-config@29.7.0(@types/node@20.14.11): + jest-config@29.7.0(@types/node@20.19.31): dependencies: '@babel/core': 7.25.2 '@jest/test-sequencer': 29.7.0 @@ -13728,7 +13865,7 @@ snapshots: slash: 3.0.0 strip-json-comments: 3.1.1 optionalDependencies: - '@types/node': 20.14.11 + '@types/node': 20.19.31 transitivePeerDependencies: - babel-plugin-macros - supports-color @@ -13774,7 +13911,7 @@ snapshots: dependencies: '@jest/types': 29.6.3 '@types/graceful-fs': 4.1.9 - '@types/node': 20.14.11 + '@types/node': 20.19.31 anymatch: 3.1.3 fb-watchman: 2.0.2 graceful-fs: 4.2.11 @@ -13848,7 +13985,7 @@ snapshots: '@jest/test-result': 29.7.0 '@jest/transform': 29.7.0 '@jest/types': 29.6.3 - '@types/node': 20.14.11 + '@types/node': 20.19.31 chalk: 4.1.2 emittery: 0.13.1 graceful-fs: 4.2.11 @@ -13876,7 +14013,7 @@ snapshots: '@jest/test-result': 29.7.0 '@jest/transform': 29.7.0 '@jest/types': 29.6.3 - '@types/node': 20.14.11 + '@types/node': 20.19.31 chalk: 4.1.2 cjs-module-lexer: 1.3.1 collect-v8-coverage: 1.0.2 @@ -13941,7 +14078,7 @@ snapshots: dependencies: '@jest/test-result': 29.7.0 '@jest/types': 29.6.3 - '@types/node': 20.14.11 + '@types/node': 20.19.31 ansi-escapes: 4.3.2 chalk: 4.1.2 emittery: 0.13.1 @@ -13961,12 +14098,12 @@ snapshots: merge-stream: 2.0.0 supports-color: 8.1.1 - jest@29.7.0(@types/node@20.14.11): + jest@29.7.0(@types/node@20.19.31): dependencies: '@jest/core': 29.7.0 '@jest/types': 29.6.3 import-local: 3.1.0 - jest-cli: 29.7.0(@types/node@20.14.11) + jest-cli: 29.7.0(@types/node@20.19.31) transitivePeerDependencies: - '@types/node' - babel-plugin-macros @@ -14283,10 +14420,6 @@ snapshots: dependencies: js-tokens: 4.0.0 - loupe@3.1.1: - dependencies: - get-func-name: 2.0.2 - lower-case@2.0.2: dependencies: tslib: 2.8.1 @@ -14303,6 +14436,10 @@ snapshots: dependencies: '@jridgewell/sourcemap-codec': 1.5.0 + magic-string@0.30.21: + dependencies: + '@jridgewell/sourcemap-codec': 1.5.5 + make-dir@2.1.0: dependencies: pify: 4.0.1 @@ -14972,8 +15109,6 @@ snapshots: mimic-fn@2.1.0: {} - mimic-fn@4.0.0: {} - minimatch@10.1.1: dependencies: '@isaacs/brace-expansion': 5.0.0 @@ -15018,6 +15153,8 @@ snapshots: object-assign: 4.1.1 thenify-all: 1.6.0 + nanoid@3.3.11: {} + nanoid@3.3.8: {} nativewind@4.1.23(react-native-reanimated@4.0.0(@babel/core@7.25.2)(react-native-worklets@0.4.0(@babel/core@7.25.2)(react-native@0.81.0(@babel/core@7.25.2)(@react-native-community/cli@20.0.0(typescript@5.8.3))(@types/react@19.1.8)(react@19.1.0))(react@19.1.0))(react-native@0.81.0(@babel/core@7.25.2)(@react-native-community/cli@20.0.0(typescript@5.8.3))(@types/react@19.1.8)(react@19.1.0))(react@19.1.0))(react-native-safe-area-context@5.5.0(react-native@0.81.0(@babel/core@7.25.2)(@react-native-community/cli@20.0.0(typescript@5.8.3))(@types/react@19.1.8)(react@19.1.0))(react@19.1.0))(react-native-svg@15.12.0(react-native@0.81.0(@babel/core@7.25.2)(@react-native-community/cli@20.0.0(typescript@5.8.3))(@types/react@19.1.8)(react@19.1.0))(react@19.1.0))(react-native@0.81.0(@babel/core@7.25.2)(@react-native-community/cli@20.0.0(typescript@5.8.3))(@types/react@19.1.8)(react@19.1.0))(react@19.1.0)(tailwindcss@3.4.17): @@ -15089,10 +15226,6 @@ snapshots: dependencies: path-key: 3.1.1 - npm-run-path@5.3.0: - dependencies: - path-key: 4.0.0 - npm-run-path@6.0.0: dependencies: path-key: 4.0.0 @@ -15168,6 +15301,8 @@ snapshots: object-inspect@1.13.2: {} + obug@2.1.1: {} + on-exit-leak-free@2.1.2: {} on-finished@2.3.0: @@ -15188,10 +15323,6 @@ snapshots: dependencies: mimic-fn: 2.1.0 - onetime@6.0.0: - dependencies: - mimic-fn: 4.0.0 - oniguruma-parser@0.12.1: {} oniguruma-to-es@4.3.4: @@ -15357,9 +15488,7 @@ snapshots: path-type@4.0.0: {} - pathe@1.1.2: {} - - pathval@2.0.0: {} + pathe@2.0.3: {} picocolors@1.1.1: {} @@ -15475,6 +15604,12 @@ snapshots: picocolors: 1.1.1 source-map-js: 1.2.1 + postcss@8.5.6: + dependencies: + nanoid: 3.3.11 + picocolors: 1.1.1 + source-map-js: 1.2.1 + preferred-pm@4.1.1: dependencies: find-up-simple: 1.0.0 @@ -16076,26 +16211,35 @@ snapshots: dependencies: glob: 7.2.3 - rollup@4.21.2: + rollup@4.57.1: dependencies: - '@types/estree': 1.0.5 + '@types/estree': 1.0.8 optionalDependencies: - '@rollup/rollup-android-arm-eabi': 4.21.2 - '@rollup/rollup-android-arm64': 4.21.2 - '@rollup/rollup-darwin-arm64': 4.21.2 - '@rollup/rollup-darwin-x64': 4.21.2 - '@rollup/rollup-linux-arm-gnueabihf': 4.21.2 - '@rollup/rollup-linux-arm-musleabihf': 4.21.2 - '@rollup/rollup-linux-arm64-gnu': 4.21.2 - '@rollup/rollup-linux-arm64-musl': 4.21.2 - '@rollup/rollup-linux-powerpc64le-gnu': 4.21.2 - '@rollup/rollup-linux-riscv64-gnu': 4.21.2 - '@rollup/rollup-linux-s390x-gnu': 4.21.2 - '@rollup/rollup-linux-x64-gnu': 4.21.2 - '@rollup/rollup-linux-x64-musl': 4.21.2 - '@rollup/rollup-win32-arm64-msvc': 4.21.2 - '@rollup/rollup-win32-ia32-msvc': 4.21.2 - '@rollup/rollup-win32-x64-msvc': 4.21.2 + '@rollup/rollup-android-arm-eabi': 4.57.1 + '@rollup/rollup-android-arm64': 4.57.1 + '@rollup/rollup-darwin-arm64': 4.57.1 + '@rollup/rollup-darwin-x64': 4.57.1 + '@rollup/rollup-freebsd-arm64': 4.57.1 + '@rollup/rollup-freebsd-x64': 4.57.1 + '@rollup/rollup-linux-arm-gnueabihf': 4.57.1 + '@rollup/rollup-linux-arm-musleabihf': 4.57.1 + '@rollup/rollup-linux-arm64-gnu': 4.57.1 + '@rollup/rollup-linux-arm64-musl': 4.57.1 + '@rollup/rollup-linux-loong64-gnu': 4.57.1 + '@rollup/rollup-linux-loong64-musl': 4.57.1 + '@rollup/rollup-linux-ppc64-gnu': 4.57.1 + '@rollup/rollup-linux-ppc64-musl': 4.57.1 + '@rollup/rollup-linux-riscv64-gnu': 4.57.1 + '@rollup/rollup-linux-riscv64-musl': 4.57.1 + '@rollup/rollup-linux-s390x-gnu': 4.57.1 + '@rollup/rollup-linux-x64-gnu': 4.57.1 + '@rollup/rollup-linux-x64-musl': 4.57.1 + '@rollup/rollup-openbsd-x64': 4.57.1 + '@rollup/rollup-openharmony-arm64': 4.57.1 + '@rollup/rollup-win32-arm64-msvc': 4.57.1 + '@rollup/rollup-win32-ia32-msvc': 4.57.1 + '@rollup/rollup-win32-x64-gnu': 4.57.1 + '@rollup/rollup-win32-x64-msvc': 4.57.1 fsevents: 2.3.3 rsbuild-plugin-dts@0.6.3(@rsbuild/core@1.3.5)(typescript@5.8.3): @@ -16376,7 +16520,7 @@ snapshots: statuses@2.0.1: {} - std-env@3.7.0: {} + std-env@3.10.0: {} stream-buffers@2.2.0: {} @@ -16436,8 +16580,6 @@ snapshots: strip-final-newline@2.0.0: {} - strip-final-newline@3.0.0: {} - strip-final-newline@4.0.0: {} strip-json-comments@3.1.1: {} @@ -16596,6 +16738,8 @@ snapshots: tinycolor2@1.6.0: {} + tinyexec@1.0.2: {} + tinyglobby@0.2.14: dependencies: fdir: 6.4.4(picomatch@4.0.2) @@ -16611,13 +16755,9 @@ snapshots: '@types/tinycolor2': 1.4.6 tinycolor2: 1.6.0 - tinypool@1.0.1: {} - tinypool@1.1.1: {} - tinyrainbow@1.2.0: {} - - tinyspy@3.0.0: {} + tinyrainbow@3.0.3: {} tmp@0.0.33: dependencies: @@ -16682,6 +16822,8 @@ snapshots: undici-types@5.26.5: {} + undici-types@6.21.0: {} + unhead@2.1.2: dependencies: hookable: 6.0.1 @@ -16813,67 +16955,58 @@ snapshots: unist-util-stringify-position: 4.0.0 vfile-message: 4.0.2 - vite-node@2.0.5(@types/node@20.14.11)(lightningcss@1.28.2)(terser@5.31.3): - dependencies: - cac: 6.7.14 - debug: 4.4.0 - pathe: 1.1.2 - tinyrainbow: 1.2.0 - vite: 5.4.3(@types/node@20.14.11)(lightningcss@1.28.2)(terser@5.31.3) - transitivePeerDependencies: - - '@types/node' - - less - - lightningcss - - sass - - sass-embedded - - stylus - - sugarss - - supports-color - - terser - - vite@5.4.3(@types/node@20.14.11)(lightningcss@1.28.2)(terser@5.31.3): + vite@7.3.1(@types/node@20.19.31)(jiti@2.6.1)(lightningcss@1.28.2)(terser@5.31.3)(yaml@2.8.2): dependencies: - esbuild: 0.21.5 - postcss: 8.5.1 - rollup: 4.21.2 + esbuild: 0.27.2 + fdir: 6.5.0(picomatch@4.0.3) + picomatch: 4.0.3 + postcss: 8.5.6 + rollup: 4.57.1 + tinyglobby: 0.2.15 optionalDependencies: - '@types/node': 20.14.11 + '@types/node': 20.19.31 fsevents: 2.3.3 + jiti: 2.6.1 lightningcss: 1.28.2 terser: 5.31.3 + yaml: 2.8.2 - vitest@2.0.5(@types/node@20.14.11)(lightningcss@1.28.2)(terser@5.31.3): - dependencies: - '@ampproject/remapping': 2.3.0 - '@vitest/expect': 2.0.5 - '@vitest/pretty-format': 2.0.5 - '@vitest/runner': 2.0.5 - '@vitest/snapshot': 2.0.5 - '@vitest/spy': 2.0.5 - '@vitest/utils': 2.0.5 - chai: 5.1.1 - debug: 4.4.0 - execa: 8.0.1 - magic-string: 0.30.17 - pathe: 1.1.2 - std-env: 3.7.0 + vitest@4.0.18(@types/node@20.19.31)(jiti@2.6.1)(lightningcss@1.28.2)(terser@5.31.3)(yaml@2.8.2): + dependencies: + '@vitest/expect': 4.0.18 + '@vitest/mocker': 4.0.18(vite@7.3.1(@types/node@20.19.31)(jiti@2.6.1)(lightningcss@1.28.2)(terser@5.31.3)(yaml@2.8.2)) + '@vitest/pretty-format': 4.0.18 + '@vitest/runner': 4.0.18 + '@vitest/snapshot': 4.0.18 + '@vitest/spy': 4.0.18 + '@vitest/utils': 4.0.18 + es-module-lexer: 1.7.0 + expect-type: 1.3.0 + magic-string: 0.30.21 + obug: 2.1.1 + pathe: 2.0.3 + picomatch: 4.0.3 + std-env: 3.10.0 tinybench: 2.9.0 - tinypool: 1.0.1 - tinyrainbow: 1.2.0 - vite: 5.4.3(@types/node@20.14.11)(lightningcss@1.28.2)(terser@5.31.3) - vite-node: 2.0.5(@types/node@20.14.11)(lightningcss@1.28.2)(terser@5.31.3) + tinyexec: 1.0.2 + tinyglobby: 0.2.15 + tinyrainbow: 3.0.3 + vite: 7.3.1(@types/node@20.19.31)(jiti@2.6.1)(lightningcss@1.28.2)(terser@5.31.3)(yaml@2.8.2) why-is-node-running: 2.3.0 optionalDependencies: - '@types/node': 20.14.11 + '@types/node': 20.19.31 transitivePeerDependencies: + - jiti - less - lightningcss + - msw - sass - sass-embedded - stylus - sugarss - - supports-color - terser + - tsx + - yaml vlq@0.2.3: {} @@ -16924,6 +17057,8 @@ snapshots: webpack-sources@3.3.3: {} + webpack-virtual-modules@0.6.2: {} + webpack@5.100.2(@swc/core@1.13.3(@swc/helpers@0.5.17)): dependencies: '@types/eslint-scope': 3.7.7 diff --git a/pnpm-workspace.yaml b/pnpm-workspace.yaml index 2ee44fd3d..9bdc932a0 100644 --- a/pnpm-workspace.yaml +++ b/pnpm-workspace.yaml @@ -8,13 +8,13 @@ catalog: "@rspack/core": ^1.6.0 "@rslib/core": ^0.6.3 "@swc/helpers": ~0.5.17 - "@types/node": ^20 + "@types/node": ^20.19.31 "terser-webpack-plugin": ^5.3.14 "typescript": ^5.8.3 "webpack": ^5.99.9 "react": "19.1.0" "react-native": "0.81.0" - "vitest": ^2.0.5 + "vitest": ^4.0.18 catalogs: testers: diff --git a/tests/integration/package.json b/tests/integration/package.json new file mode 100644 index 000000000..1821ba903 --- /dev/null +++ b/tests/integration/package.json @@ -0,0 +1,24 @@ +{ + "name": "integration-test", + "version": "0.0.1", + "description": "Integration tests for @callstack/repack", + "private": true, + "type": "module", + "engines": { + "node": ">=22" + }, + "scripts": { + "test": "vitest run", + "test:watch": "vitest" + }, + "devDependencies": { + "@callstack/repack": "workspace:*", + "@rspack/core": "catalog:", + "@types/node": "catalog:", + "memfs": "^4.11.1", + "typescript": "catalog:", + "vitest": "catalog:", + "webpack": "catalog:", + "webpack-virtual-modules": "^0.6.2" + } +} diff --git a/tests/integration/src/helpers.ts b/tests/integration/src/helpers.ts new file mode 100644 index 000000000..4ceea48f7 --- /dev/null +++ b/tests/integration/src/helpers.ts @@ -0,0 +1,114 @@ +import type { + Compiler as RspackCompiler, + Configuration as RspackConfiguration, +} from '@rspack/core'; +import { Volume, createFsFromVolume } from 'memfs'; +import { inject } from 'vitest'; +import type { + Compiler as WebpackCompiler, + Configuration as WebpackConfiguration, +} from 'webpack'; + +export type BundlerType = 'rspack' | 'webpack'; + +type Compiler = RspackCompiler | WebpackCompiler; +type Configuration = RspackConfiguration | WebpackConfiguration; + +function getBundlerType(): BundlerType { + return inject('bundlerType'); +} + +/** + * Create a compiler instance for the current bundler + */ +export async function createCompiler(config: Configuration): Promise { + const type = getBundlerType(); + if (type === 'rspack') { + const { rspack } = await import('@rspack/core'); + return rspack(config as RspackConfiguration); + } + const { webpack } = await import('webpack'); + return webpack(config as WebpackConfiguration); +} + +/** + * Create a virtual module plugin for the current bundler + */ +export async function createVirtualModulePlugin( + modules: Record +): Promise<{ apply(compiler: Compiler): void }> { + const type = getBundlerType(); + if (type === 'rspack') { + const { rspack } = await import('@rspack/core'); + return new rspack.experiments.VirtualModulesPlugin(modules); + } + const VirtualModulesPlugin = (await import('webpack-virtual-modules')) + .default; + return new VirtualModulesPlugin(modules); +} + +/** + * Run compilation and return the result + */ +export function compile(compiler: Compiler) { + const volume = new Volume(); + const fileSystem = createFsFromVolume(volume); + + // @ts-expect-error memfs is compatible enough with webpack's output filesystem + compiler.outputFileSystem = fileSystem; + + return new Promise<{ code: string; volume: InstanceType }>( + (resolve, reject) => { + compiler.run((error, stats) => { + if (error) { + reject(error); + return; + } + + if (stats?.hasErrors()) { + reject(new Error(stats.toString({ errors: true }))); + return; + } + + const code = fileSystem.readFileSync('/out/main.js', 'utf-8') as string; + resolve({ code, volume }); + }); + } + ); +} + +/** + * Virtual modules for mocking React Native in tests + */ +export function getReactNativeVirtualModules( + pixelRatio = 1 +): Record { + return { + 'package.json': '{ "type": "module" }', + 'node_modules/react-native/package.json': + '{ "name": "react-native", "main": "./index.js" }', + 'node_modules/react-native/index.js': `module.exports = { PixelRatio: { get: () => ${pixelRatio} } };`, + 'node_modules/react-native/Libraries/Image/AssetRegistry.js': + 'module.exports = { registerAsset: (spec) => spec };', + 'node_modules/react-native/Libraries/Image/AssetSourceResolver.js': ` + module.exports = class AssetSourceResolver { + constructor(a, b, c) { + this.asset = c; + } + scaledAssetPath() { + var scale = require('react-native').PixelRatio.get(); + var scaleSuffix = scale === 1 ? '' : '@x' + scale; + return { + __packager_asset: true, + width: this.asset.width, + height: this.asset.height, + uri: this.asset.httpServerLocation + '/' + this.asset.name + scaleSuffix + '.' + this.asset.type, + scale: scale, + }; + } + static pickScale(scales, pixelRatio) { + return scales[pixelRatio - 1]; + } + };`, + }; +} diff --git a/packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/logo.android.png b/tests/integration/src/loaders/__fixtures__/assets/logo.android.png similarity index 100% rename from packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/logo.android.png rename to tests/integration/src/loaders/__fixtures__/assets/logo.android.png diff --git a/packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/logo.ios.png b/tests/integration/src/loaders/__fixtures__/assets/logo.ios.png similarity index 100% rename from packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/logo.ios.png rename to tests/integration/src/loaders/__fixtures__/assets/logo.ios.png diff --git a/packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/logo.png b/tests/integration/src/loaders/__fixtures__/assets/logo.png similarity index 100% rename from packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/logo.png rename to tests/integration/src/loaders/__fixtures__/assets/logo.png diff --git a/packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/star@1x.png b/tests/integration/src/loaders/__fixtures__/assets/star@1x.png similarity index 100% rename from packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/star@1x.png rename to tests/integration/src/loaders/__fixtures__/assets/star@1x.png diff --git a/packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/star@2x.png b/tests/integration/src/loaders/__fixtures__/assets/star@2x.png similarity index 100% rename from packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/star@2x.png rename to tests/integration/src/loaders/__fixtures__/assets/star@2x.png diff --git a/packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/star@3x.png b/tests/integration/src/loaders/__fixtures__/assets/star@3x.png similarity index 100% rename from packages/repack/src/loaders/assetsLoader/__tests__/__fixtures__/star@3x.png rename to tests/integration/src/loaders/__fixtures__/assets/star@3x.png diff --git a/packages/repack/src/loaders/assetsLoader/__tests__/__snapshots__/assetsLoader.test.ts.snap b/tests/integration/src/loaders/__snapshots__/rspack/assets-loader.test.ts.snap similarity index 85% rename from packages/repack/src/loaders/assetsLoader/__tests__/__snapshots__/assetsLoader.test.ts.snap rename to tests/integration/src/loaders/__snapshots__/rspack/assets-loader.test.ts.snap index 9e8c3068f..7a4a7b268 100644 --- a/packages/repack/src/loaders/assetsLoader/__tests__/__snapshots__/assetsLoader.test.ts.snap +++ b/tests/integration/src/loaders/__snapshots__/rspack/assets-loader.test.ts.snap @@ -1,11 +1,11 @@ -// Jest Snapshot v1, https://goo.gl/fbAQLP +// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html -exports[`assetLoader on android should load and extract asset with scales 1`] = ` +exports[`assetLoader > on android > should load and extract asset with scales 1`] = ` { "__packager_asset": true, "hash": "86abef08a42e972a96c958d6fa9d43da,02ad731a8881911e488b51c48a4cc6c1,d9f7c31eebb3a41cc180431867b04f38", "height": 272, - "httpServerLocation": "assets/node_modules/rspack-virtual-module-2f60a7fc/__fixtures__", + "httpServerLocation": "assets/__fixtures__/assets", "name": "star", "scales": [ 1, @@ -17,24 +17,24 @@ exports[`assetLoader on android should load and extract asset with scales 1`] = } `; -exports[`assetLoader on android should load and extract asset with scales 2`] = ` +exports[`assetLoader > on android > should load and extract asset with scales 2`] = ` "/ └─ out/ ├─ drawable-mdpi/ - │ └─ node_modules_rspackvirtualmodule2f60a7fc___fixtures___star.png + │ └─ __fixtures___assets_star.png ├─ drawable-xhdpi/ - │ └─ node_modules_rspackvirtualmodule2f60a7fc___fixtures___star.png + │ └─ __fixtures___assets_star.png ├─ drawable-xxhdpi/ - │ └─ node_modules_rspackvirtualmodule2f60a7fc___fixtures___star.png + │ └─ __fixtures___assets_star.png └─ main.js" `; -exports[`assetLoader on android should load and extract asset without scales 1`] = ` +exports[`assetLoader > on android > should load and extract asset without scales 1`] = ` { "__packager_asset": true, - "hash": "30be0ddcd5932e77845666e7b6f6a863", + "hash": "373411381c08b2c5034c814c24c26b19", "height": 51, - "httpServerLocation": "assets/node_modules/rspack-virtual-module-dede2d21/__fixtures__", + "httpServerLocation": "assets/__fixtures__/assets", "name": "logo", "scales": [ 1, @@ -44,20 +44,20 @@ exports[`assetLoader on android should load and extract asset without scales 1`] } `; -exports[`assetLoader on android should load and extract asset without scales 2`] = ` +exports[`assetLoader > on android > should load and extract asset without scales 2`] = ` "/ └─ out/ ├─ drawable-mdpi/ - │ └─ node_modules_rspackvirtualmoduledede2d21___fixtures___logo.png + │ └─ __fixtures___assets_logo.png └─ main.js" `; -exports[`assetLoader on android should prefer platform specific asset 1`] = ` +exports[`assetLoader > on android > should prefer platform specific asset 1`] = ` { "__packager_asset": true, "hash": "373411381c08b2c5034c814c24c26b19", "height": 51, - "httpServerLocation": "assets/node_modules/rspack-virtual-module-acc39058/__fixtures__", + "httpServerLocation": "assets/__fixtures__/assets", "name": "logo", "scales": [ 1, @@ -67,20 +67,20 @@ exports[`assetLoader on android should prefer platform specific asset 1`] = ` } `; -exports[`assetLoader on android should prefer platform specific asset 2`] = ` +exports[`assetLoader > on android > should prefer platform specific asset 2`] = ` "/ └─ out/ ├─ drawable-mdpi/ - │ └─ node_modules_rspackvirtualmoduleacc39058___fixtures___logo.png + │ └─ __fixtures___assets_logo.png └─ main.js" `; -exports[`assetLoader on ios should load and extract asset with scales 1`] = ` +exports[`assetLoader > on ios > should load and extract asset with scales 1`] = ` { "__packager_asset": true, "hash": "86abef08a42e972a96c958d6fa9d43da,02ad731a8881911e488b51c48a4cc6c1,d9f7c31eebb3a41cc180431867b04f38", "height": 272, - "httpServerLocation": "assets/node_modules/rspack-virtual-module-2f60a7fc/__fixtures__", + "httpServerLocation": "assets/__fixtures__/assets", "name": "star", "scales": [ 1, @@ -92,25 +92,24 @@ exports[`assetLoader on ios should load and extract asset with scales 1`] = ` } `; -exports[`assetLoader on ios should load and extract asset with scales 2`] = ` +exports[`assetLoader > on ios > should load and extract asset with scales 2`] = ` "/ └─ out/ ├─ assets/ - │ └─ node_modules/ - │ └─ rspack-virtual-module-2f60a7fc/ - │ └─ __fixtures__/ - │ ├─ star.png - │ ├─ star@2x.png - │ └─ star@3x.png + │ └─ __fixtures__/ + │ └─ assets/ + │ ├─ star.png + │ ├─ star@2x.png + │ └─ star@3x.png └─ main.js" `; -exports[`assetLoader on ios should load and extract asset without scales 1`] = ` +exports[`assetLoader > on ios > should load and extract asset without scales 1`] = ` { "__packager_asset": true, - "hash": "30be0ddcd5932e77845666e7b6f6a863", + "hash": "6839dbc2a8dafd50c1d82b7db5fe274a", "height": 51, - "httpServerLocation": "assets/node_modules/rspack-virtual-module-dede2d21/__fixtures__", + "httpServerLocation": "assets/__fixtures__/assets", "name": "logo", "scales": [ 1, @@ -120,23 +119,22 @@ exports[`assetLoader on ios should load and extract asset without scales 1`] = ` } `; -exports[`assetLoader on ios should load and extract asset without scales 2`] = ` +exports[`assetLoader > on ios > should load and extract asset without scales 2`] = ` "/ └─ out/ ├─ assets/ - │ └─ node_modules/ - │ └─ rspack-virtual-module-dede2d21/ - │ └─ __fixtures__/ - │ └─ logo.png + │ └─ __fixtures__/ + │ └─ assets/ + │ └─ logo.png └─ main.js" `; -exports[`assetLoader on ios should prefer platform specific asset 1`] = ` +exports[`assetLoader > on ios > should prefer platform specific asset 1`] = ` { "__packager_asset": true, "hash": "6839dbc2a8dafd50c1d82b7db5fe274a", "height": 51, - "httpServerLocation": "assets/node_modules/rspack-virtual-module-1d9593d4/__fixtures__", + "httpServerLocation": "assets/__fixtures__/assets", "name": "logo", "scales": [ 1, @@ -146,232 +144,222 @@ exports[`assetLoader on ios should prefer platform specific asset 1`] = ` } `; -exports[`assetLoader on ios should prefer platform specific asset 2`] = ` +exports[`assetLoader > on ios > should prefer platform specific asset 2`] = ` "/ └─ out/ ├─ assets/ - │ └─ node_modules/ - │ └─ rspack-virtual-module-1d9593d4/ - │ └─ __fixtures__/ - │ └─ logo.png + │ └─ __fixtures__/ + │ └─ assets/ + │ └─ logo.png └─ main.js" `; -exports[`assetLoader should convert to remote-asset with URL containing a path after basename 1`] = ` +exports[`assetLoader > should convert to remote-asset > with URL containing a path after basename 1`] = ` { "__packager_asset": true, "height": 51, "scale": 1, - "uri": "http://localhost:9999/remote-assets/assets/node_modules/rspack-virtual-module-dede2d21/__fixtures__/logo.png", + "uri": "http://localhost:9999/remote-assets/assets/__fixtures__/assets/logo.png", "width": 297, } `; -exports[`assetLoader should convert to remote-asset with URL containing a path after basename 2`] = ` +exports[`assetLoader > should convert to remote-asset > with URL containing a path after basename 2`] = ` "/ └─ out/ ├─ main.js └─ remote-assets/ └─ assets/ - └─ node_modules/ - └─ rspack-virtual-module-dede2d21/ - └─ __fixtures__/ - └─ logo.png" + └─ __fixtures__/ + └─ assets/ + └─ logo.png" `; -exports[`assetLoader should convert to remote-asset with scales 1 1`] = ` +exports[`assetLoader > should convert to remote-asset > with scales 1 1`] = ` { "__packager_asset": true, "height": 272, "scale": 1, - "uri": "http://localhost:9999/assets/node_modules/rspack-virtual-module-2f60a7fc/__fixtures__/star.png", + "uri": "http://localhost:9999/assets/__fixtures__/assets/star.png", "width": 286, } `; -exports[`assetLoader should convert to remote-asset with scales 1 2`] = ` +exports[`assetLoader > should convert to remote-asset > with scales 1 2`] = ` "/ └─ out/ ├─ main.js └─ remote-assets/ └─ assets/ - └─ node_modules/ - └─ rspack-virtual-module-2f60a7fc/ - └─ __fixtures__/ - ├─ star.png - ├─ star@2x.png - └─ star@3x.png" + └─ __fixtures__/ + └─ assets/ + ├─ star.png + ├─ star@2x.png + └─ star@3x.png" `; -exports[`assetLoader should convert to remote-asset with scales 2 1`] = ` +exports[`assetLoader > should convert to remote-asset > with scales 2 1`] = ` { "__packager_asset": true, "height": 272, "scale": 2, - "uri": "http://localhost:9999/assets/node_modules/rspack-virtual-module-4e63ce4e/__fixtures__/star@x2.png", + "uri": "http://localhost:9999/assets/__fixtures__/assets/star@x2.png", "width": 286, } `; -exports[`assetLoader should convert to remote-asset with scales 2 2`] = ` +exports[`assetLoader > should convert to remote-asset > with scales 2 2`] = ` "/ └─ out/ ├─ main.js └─ remote-assets/ └─ assets/ - └─ node_modules/ - └─ rspack-virtual-module-4e63ce4e/ - └─ __fixtures__/ - ├─ star.png - ├─ star@2x.png - └─ star@3x.png" + └─ __fixtures__/ + └─ assets/ + ├─ star.png + ├─ star@2x.png + └─ star@3x.png" `; -exports[`assetLoader should convert to remote-asset with scales 3 1`] = ` +exports[`assetLoader > should convert to remote-asset > with scales 3 1`] = ` { "__packager_asset": true, "height": 272, "scale": 3, - "uri": "http://localhost:9999/assets/node_modules/rspack-virtual-module-1f80d675/__fixtures__/star@x3.png", + "uri": "http://localhost:9999/assets/__fixtures__/assets/star@x3.png", "width": 286, } `; -exports[`assetLoader should convert to remote-asset with scales 3 2`] = ` +exports[`assetLoader > should convert to remote-asset > with scales 3 2`] = ` "/ └─ out/ ├─ main.js └─ remote-assets/ └─ assets/ - └─ node_modules/ - └─ rspack-virtual-module-1f80d675/ - └─ __fixtures__/ - ├─ star.png - ├─ star@2x.png - └─ star@3x.png" + └─ __fixtures__/ + └─ assets/ + ├─ star.png + ├─ star@2x.png + └─ star@3x.png" `; -exports[`assetLoader should convert to remote-asset with specified assetPath with scales 1 1`] = ` +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 1 1`] = ` { "__packager_asset": true, "height": 272, "scale": 1, - "uri": "http://localhost:9999/assets/node_modules/rspack-virtual-module-2f60a7fc/__fixtures__/nested-folder/star-fake-hash.png", + "uri": "http://localhost:9999/assets/__fixtures__/assets/nested-folder/star-fake-hash.png", "width": 286, } `; -exports[`assetLoader should convert to remote-asset with specified assetPath with scales 1 2`] = ` +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 1 2`] = ` "/ └─ out/ ├─ main.js └─ remote-assets/ └─ assets/ - └─ node_modules/ - └─ rspack-virtual-module-2f60a7fc/ - └─ __fixtures__/ - └─ nested-folder/ - ├─ star-fake-hash.png - ├─ star-fake-hash@2x.png - └─ star-fake-hash@3x.png" + └─ __fixtures__/ + └─ assets/ + └─ nested-folder/ + ├─ star-fake-hash.png + ├─ star-fake-hash@2x.png + └─ star-fake-hash@3x.png" `; -exports[`assetLoader should convert to remote-asset with specified assetPath with scales 2 1`] = ` +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 2 1`] = ` { "__packager_asset": true, "height": 272, "scale": 2, - "uri": "http://localhost:9999/assets/node_modules/rspack-virtual-module-4e63ce4e/__fixtures__/nested-folder/star-fake-hash@x2.png", + "uri": "http://localhost:9999/assets/__fixtures__/assets/nested-folder/star-fake-hash@x2.png", "width": 286, } `; -exports[`assetLoader should convert to remote-asset with specified assetPath with scales 2 2`] = ` +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 2 2`] = ` "/ └─ out/ ├─ main.js └─ remote-assets/ └─ assets/ - └─ node_modules/ - └─ rspack-virtual-module-4e63ce4e/ - └─ __fixtures__/ - └─ nested-folder/ - ├─ star-fake-hash.png - ├─ star-fake-hash@2x.png - └─ star-fake-hash@3x.png" + └─ __fixtures__/ + └─ assets/ + └─ nested-folder/ + ├─ star-fake-hash.png + ├─ star-fake-hash@2x.png + └─ star-fake-hash@3x.png" `; -exports[`assetLoader should convert to remote-asset with specified assetPath with scales 3 1`] = ` +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 3 1`] = ` { "__packager_asset": true, "height": 272, "scale": 3, - "uri": "http://localhost:9999/assets/node_modules/rspack-virtual-module-1f80d675/__fixtures__/nested-folder/star-fake-hash@x3.png", + "uri": "http://localhost:9999/assets/__fixtures__/assets/nested-folder/star-fake-hash@x3.png", "width": 286, } `; -exports[`assetLoader should convert to remote-asset with specified assetPath with scales 3 2`] = ` +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 3 2`] = ` "/ └─ out/ ├─ main.js └─ remote-assets/ └─ assets/ - └─ node_modules/ - └─ rspack-virtual-module-1f80d675/ - └─ __fixtures__/ - └─ nested-folder/ - ├─ star-fake-hash.png - ├─ star-fake-hash@2x.png - └─ star-fake-hash@3x.png" + └─ __fixtures__/ + └─ assets/ + └─ nested-folder/ + ├─ star-fake-hash.png + ├─ star-fake-hash@2x.png + └─ star-fake-hash@3x.png" `; -exports[`assetLoader should convert to remote-asset with specified assetPath without scales 1`] = ` +exports[`assetLoader > should convert to remote-asset > with specified assetPath > without scales 1`] = ` { "__packager_asset": true, "height": 51, "scale": 1, - "uri": "http://localhost:9999/remote-assets/assets/node_modules/rspack-virtual-module-dede2d21/__fixtures__/nested-folder/logo-fake-hash.png", + "uri": "http://localhost:9999/remote-assets/assets/__fixtures__/assets/nested-folder/logo-fake-hash.png", "width": 297, } `; -exports[`assetLoader should convert to remote-asset with specified assetPath without scales 2`] = ` +exports[`assetLoader > should convert to remote-asset > with specified assetPath > without scales 2`] = ` "/ └─ out/ ├─ main.js └─ remote-assets/ └─ assets/ - └─ node_modules/ - └─ rspack-virtual-module-dede2d21/ - └─ __fixtures__/ - └─ nested-folder/ - └─ logo-fake-hash.png" + └─ __fixtures__/ + └─ assets/ + └─ nested-folder/ + └─ logo-fake-hash.png" `; -exports[`assetLoader should convert to remote-asset without scales 1`] = ` +exports[`assetLoader > should convert to remote-asset > without scales 1`] = ` { "__packager_asset": true, "height": 51, "scale": 1, - "uri": "http://localhost:9999/assets/node_modules/rspack-virtual-module-dede2d21/__fixtures__/logo.png", + "uri": "http://localhost:9999/assets/__fixtures__/assets/logo.png", "width": 297, } `; -exports[`assetLoader should convert to remote-asset without scales 2`] = ` +exports[`assetLoader > should convert to remote-asset > without scales 2`] = ` "/ └─ out/ ├─ main.js └─ remote-assets/ └─ assets/ - └─ node_modules/ - └─ rspack-virtual-module-dede2d21/ - └─ __fixtures__/ - └─ logo.png" + └─ __fixtures__/ + └─ assets/ + └─ logo.png" `; -exports[`assetLoader should inline asset with scales (1) 1`] = ` +exports[`assetLoader > should inline asset > with scales (1) 1`] = ` { "height": 272, "scale": 1, @@ -380,13 +368,13 @@ exports[`assetLoader should inline asset with scales (1) 1`] = ` } `; -exports[`assetLoader should inline asset with scales (1) 2`] = ` +exports[`assetLoader > should inline asset > with scales (1) 2`] = ` "/ └─ out/ └─ main.js" `; -exports[`assetLoader should inline asset with scales (2) 1`] = ` +exports[`assetLoader > should inline asset > with scales (2) 1`] = ` { "height": 407.5, "scale": 2, @@ -395,13 +383,13 @@ exports[`assetLoader should inline asset with scales (2) 1`] = ` } `; -exports[`assetLoader should inline asset with scales (2) 2`] = ` +exports[`assetLoader > should inline asset > with scales (2) 2`] = ` "/ └─ out/ └─ main.js" `; -exports[`assetLoader should inline asset with scales (3) 1`] = ` +exports[`assetLoader > should inline asset > with scales (3) 1`] = ` { "height": 362, "scale": 3, @@ -410,22 +398,22 @@ exports[`assetLoader should inline asset with scales (3) 1`] = ` } `; -exports[`assetLoader should inline asset with scales (3) 2`] = ` +exports[`assetLoader > should inline asset > with scales (3) 2`] = ` "/ └─ out/ └─ main.js" `; -exports[`assetLoader should inline asset without scales 1`] = ` +exports[`assetLoader > should inline asset > without scales 1`] = ` { "height": 51, "scale": 1, - "uri": "", + "uri": "", "width": 297, } `; -exports[`assetLoader should inline asset without scales 2`] = ` +exports[`assetLoader > should inline asset > without scales 2`] = ` "/ └─ out/ └─ main.js" diff --git a/tests/integration/src/loaders/__snapshots__/webpack/assets-loader.test.ts.snap b/tests/integration/src/loaders/__snapshots__/webpack/assets-loader.test.ts.snap new file mode 100644 index 000000000..7a4a7b268 --- /dev/null +++ b/tests/integration/src/loaders/__snapshots__/webpack/assets-loader.test.ts.snap @@ -0,0 +1,420 @@ +// Vitest Snapshot v1, https://vitest.dev/guide/snapshot.html + +exports[`assetLoader > on android > should load and extract asset with scales 1`] = ` +{ + "__packager_asset": true, + "hash": "86abef08a42e972a96c958d6fa9d43da,02ad731a8881911e488b51c48a4cc6c1,d9f7c31eebb3a41cc180431867b04f38", + "height": 272, + "httpServerLocation": "assets/__fixtures__/assets", + "name": "star", + "scales": [ + 1, + 2, + 3, + ], + "type": "png", + "width": 286, +} +`; + +exports[`assetLoader > on android > should load and extract asset with scales 2`] = ` +"/ +└─ out/ + ├─ drawable-mdpi/ + │ └─ __fixtures___assets_star.png + ├─ drawable-xhdpi/ + │ └─ __fixtures___assets_star.png + ├─ drawable-xxhdpi/ + │ └─ __fixtures___assets_star.png + └─ main.js" +`; + +exports[`assetLoader > on android > should load and extract asset without scales 1`] = ` +{ + "__packager_asset": true, + "hash": "373411381c08b2c5034c814c24c26b19", + "height": 51, + "httpServerLocation": "assets/__fixtures__/assets", + "name": "logo", + "scales": [ + 1, + ], + "type": "png", + "width": 297, +} +`; + +exports[`assetLoader > on android > should load and extract asset without scales 2`] = ` +"/ +└─ out/ + ├─ drawable-mdpi/ + │ └─ __fixtures___assets_logo.png + └─ main.js" +`; + +exports[`assetLoader > on android > should prefer platform specific asset 1`] = ` +{ + "__packager_asset": true, + "hash": "373411381c08b2c5034c814c24c26b19", + "height": 51, + "httpServerLocation": "assets/__fixtures__/assets", + "name": "logo", + "scales": [ + 1, + ], + "type": "png", + "width": 297, +} +`; + +exports[`assetLoader > on android > should prefer platform specific asset 2`] = ` +"/ +└─ out/ + ├─ drawable-mdpi/ + │ └─ __fixtures___assets_logo.png + └─ main.js" +`; + +exports[`assetLoader > on ios > should load and extract asset with scales 1`] = ` +{ + "__packager_asset": true, + "hash": "86abef08a42e972a96c958d6fa9d43da,02ad731a8881911e488b51c48a4cc6c1,d9f7c31eebb3a41cc180431867b04f38", + "height": 272, + "httpServerLocation": "assets/__fixtures__/assets", + "name": "star", + "scales": [ + 1, + 2, + 3, + ], + "type": "png", + "width": 286, +} +`; + +exports[`assetLoader > on ios > should load and extract asset with scales 2`] = ` +"/ +└─ out/ + ├─ assets/ + │ └─ __fixtures__/ + │ └─ assets/ + │ ├─ star.png + │ ├─ star@2x.png + │ └─ star@3x.png + └─ main.js" +`; + +exports[`assetLoader > on ios > should load and extract asset without scales 1`] = ` +{ + "__packager_asset": true, + "hash": "6839dbc2a8dafd50c1d82b7db5fe274a", + "height": 51, + "httpServerLocation": "assets/__fixtures__/assets", + "name": "logo", + "scales": [ + 1, + ], + "type": "png", + "width": 297, +} +`; + +exports[`assetLoader > on ios > should load and extract asset without scales 2`] = ` +"/ +└─ out/ + ├─ assets/ + │ └─ __fixtures__/ + │ └─ assets/ + │ └─ logo.png + └─ main.js" +`; + +exports[`assetLoader > on ios > should prefer platform specific asset 1`] = ` +{ + "__packager_asset": true, + "hash": "6839dbc2a8dafd50c1d82b7db5fe274a", + "height": 51, + "httpServerLocation": "assets/__fixtures__/assets", + "name": "logo", + "scales": [ + 1, + ], + "type": "png", + "width": 297, +} +`; + +exports[`assetLoader > on ios > should prefer platform specific asset 2`] = ` +"/ +└─ out/ + ├─ assets/ + │ └─ __fixtures__/ + │ └─ assets/ + │ └─ logo.png + └─ main.js" +`; + +exports[`assetLoader > should convert to remote-asset > with URL containing a path after basename 1`] = ` +{ + "__packager_asset": true, + "height": 51, + "scale": 1, + "uri": "http://localhost:9999/remote-assets/assets/__fixtures__/assets/logo.png", + "width": 297, +} +`; + +exports[`assetLoader > should convert to remote-asset > with URL containing a path after basename 2`] = ` +"/ +└─ out/ + ├─ main.js + └─ remote-assets/ + └─ assets/ + └─ __fixtures__/ + └─ assets/ + └─ logo.png" +`; + +exports[`assetLoader > should convert to remote-asset > with scales 1 1`] = ` +{ + "__packager_asset": true, + "height": 272, + "scale": 1, + "uri": "http://localhost:9999/assets/__fixtures__/assets/star.png", + "width": 286, +} +`; + +exports[`assetLoader > should convert to remote-asset > with scales 1 2`] = ` +"/ +└─ out/ + ├─ main.js + └─ remote-assets/ + └─ assets/ + └─ __fixtures__/ + └─ assets/ + ├─ star.png + ├─ star@2x.png + └─ star@3x.png" +`; + +exports[`assetLoader > should convert to remote-asset > with scales 2 1`] = ` +{ + "__packager_asset": true, + "height": 272, + "scale": 2, + "uri": "http://localhost:9999/assets/__fixtures__/assets/star@x2.png", + "width": 286, +} +`; + +exports[`assetLoader > should convert to remote-asset > with scales 2 2`] = ` +"/ +└─ out/ + ├─ main.js + └─ remote-assets/ + └─ assets/ + └─ __fixtures__/ + └─ assets/ + ├─ star.png + ├─ star@2x.png + └─ star@3x.png" +`; + +exports[`assetLoader > should convert to remote-asset > with scales 3 1`] = ` +{ + "__packager_asset": true, + "height": 272, + "scale": 3, + "uri": "http://localhost:9999/assets/__fixtures__/assets/star@x3.png", + "width": 286, +} +`; + +exports[`assetLoader > should convert to remote-asset > with scales 3 2`] = ` +"/ +└─ out/ + ├─ main.js + └─ remote-assets/ + └─ assets/ + └─ __fixtures__/ + └─ assets/ + ├─ star.png + ├─ star@2x.png + └─ star@3x.png" +`; + +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 1 1`] = ` +{ + "__packager_asset": true, + "height": 272, + "scale": 1, + "uri": "http://localhost:9999/assets/__fixtures__/assets/nested-folder/star-fake-hash.png", + "width": 286, +} +`; + +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 1 2`] = ` +"/ +└─ out/ + ├─ main.js + └─ remote-assets/ + └─ assets/ + └─ __fixtures__/ + └─ assets/ + └─ nested-folder/ + ├─ star-fake-hash.png + ├─ star-fake-hash@2x.png + └─ star-fake-hash@3x.png" +`; + +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 2 1`] = ` +{ + "__packager_asset": true, + "height": 272, + "scale": 2, + "uri": "http://localhost:9999/assets/__fixtures__/assets/nested-folder/star-fake-hash@x2.png", + "width": 286, +} +`; + +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 2 2`] = ` +"/ +└─ out/ + ├─ main.js + └─ remote-assets/ + └─ assets/ + └─ __fixtures__/ + └─ assets/ + └─ nested-folder/ + ├─ star-fake-hash.png + ├─ star-fake-hash@2x.png + └─ star-fake-hash@3x.png" +`; + +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 3 1`] = ` +{ + "__packager_asset": true, + "height": 272, + "scale": 3, + "uri": "http://localhost:9999/assets/__fixtures__/assets/nested-folder/star-fake-hash@x3.png", + "width": 286, +} +`; + +exports[`assetLoader > should convert to remote-asset > with specified assetPath > with scales 3 2`] = ` +"/ +└─ out/ + ├─ main.js + └─ remote-assets/ + └─ assets/ + └─ __fixtures__/ + └─ assets/ + └─ nested-folder/ + ├─ star-fake-hash.png + ├─ star-fake-hash@2x.png + └─ star-fake-hash@3x.png" +`; + +exports[`assetLoader > should convert to remote-asset > with specified assetPath > without scales 1`] = ` +{ + "__packager_asset": true, + "height": 51, + "scale": 1, + "uri": "http://localhost:9999/remote-assets/assets/__fixtures__/assets/nested-folder/logo-fake-hash.png", + "width": 297, +} +`; + +exports[`assetLoader > should convert to remote-asset > with specified assetPath > without scales 2`] = ` +"/ +└─ out/ + ├─ main.js + └─ remote-assets/ + └─ assets/ + └─ __fixtures__/ + └─ assets/ + └─ nested-folder/ + └─ logo-fake-hash.png" +`; + +exports[`assetLoader > should convert to remote-asset > without scales 1`] = ` +{ + "__packager_asset": true, + "height": 51, + "scale": 1, + "uri": "http://localhost:9999/assets/__fixtures__/assets/logo.png", + "width": 297, +} +`; + +exports[`assetLoader > should convert to remote-asset > without scales 2`] = ` +"/ +└─ out/ + ├─ main.js + └─ remote-assets/ + └─ assets/ + └─ __fixtures__/ + └─ assets/ + └─ logo.png" +`; + +exports[`assetLoader > should inline asset > with scales (1) 1`] = ` +{ + "height": 272, + "scale": 1, + "uri": "", + "width": 286, +} +`; + +exports[`assetLoader > should inline asset > with scales (1) 2`] = ` +"/ +└─ out/ + └─ main.js" +`; + +exports[`assetLoader > should inline asset > with scales (2) 1`] = ` +{ + "height": 407.5, + "scale": 2, + "uri": "", + "width": 428, +} +`; + +exports[`assetLoader > should inline asset > with scales (2) 2`] = ` +"/ +└─ out/ + └─ main.js" +`; + +exports[`assetLoader > should inline asset > with scales (3) 1`] = ` +{ + "height": 362, + "scale": 3, + "uri": "", + "width": 380.6666666666667, +} +`; + +exports[`assetLoader > should inline asset > with scales (3) 2`] = ` +"/ +└─ out/ + └─ main.js" +`; + +exports[`assetLoader > should inline asset > without scales 1`] = ` +{ + "height": 51, + "scale": 1, + "uri": "", + "width": 297, +} +`; + +exports[`assetLoader > should inline asset > without scales 2`] = ` +"/ +└─ out/ + └─ main.js" +`; diff --git a/tests/integration/src/loaders/assets-loader.test.ts b/tests/integration/src/loaders/assets-loader.test.ts new file mode 100644 index 000000000..e6995732a --- /dev/null +++ b/tests/integration/src/loaders/assets-loader.test.ts @@ -0,0 +1,285 @@ +import path from 'node:path'; +import { fileURLToPath } from 'node:url'; +import vm from 'node:vm'; +import { getAssetExtensionsRegExp, getResolveOptions } from '@callstack/repack'; +import { describe, expect, it } from 'vitest'; +import { + compile, + createCompiler, + createVirtualModulePlugin, + getReactNativeVirtualModules, +} from '../helpers.js'; + +const __dirname = path.dirname(fileURLToPath(import.meta.url)); + +async function compileBundle( + platform: string, + virtualModules: Record, + inline?: boolean, + remote?: { + enabled: boolean; + assetPath?: (args: { + resourcePath: string; + resourceFilename: string; + resourceDirname: string; + resourceExtensionType: string; + }) => string; + publicPath: string; + } +) { + const virtualPlugin = await createVirtualModulePlugin(virtualModules); + + const compiler = await createCompiler({ + context: __dirname, + mode: 'development', + devtool: false, + entry: './index.js', + resolve: getResolveOptions(platform), + output: { + path: '/out', + library: 'Export', + }, + module: { + rules: [ + { + test: getAssetExtensionsRegExp(), + use: { + loader: require.resolve('@callstack/repack/assets-loader'), + options: { + platform, + inline, + remote, + }, + }, + }, + ], + }, + plugins: [virtualPlugin], + }); + + return compile(compiler); +} + +describe('assetLoader', () => { + describe.each(['ios', 'android'])('on %s', (platform) => { + it('should load and extract asset without scales', async () => { + const { code, volume } = await compileBundle(platform, { + ...getReactNativeVirtualModules(), + './index.js': + "export { default } from './__fixtures__/assets/logo.png';", + }); + + const context: { Export?: { default: Record } } = {}; + vm.runInNewContext(code, context); + + expect(context.Export?.default).toMatchSnapshot(); + expect(volume.toTree()).toMatchSnapshot(); + }); + + it('should load and extract asset with scales', async () => { + const { code, volume } = await compileBundle(platform, { + ...getReactNativeVirtualModules(), + './index.js': + "export { default } from './__fixtures__/assets/star.png';", + }); + + const context: { Export?: { default: Record } } = {}; + vm.runInNewContext(code, context); + + expect(context.Export?.default).toMatchSnapshot(); + expect(volume.toTree()).toMatchSnapshot(); + }); + + it('should prefer platform specific asset', async () => { + const { code, volume } = await compileBundle(platform, { + ...getReactNativeVirtualModules(), + './index.js': + "export { default } from './__fixtures__/assets/logo.png';", + }); + + const context: { Export?: { default: Record } } = {}; + vm.runInNewContext(code, context); + + expect(context.Export?.default).toMatchSnapshot(); + expect(volume.toTree()).toMatchSnapshot(); + }); + }); + + describe('should inline asset', () => { + it('without scales', async () => { + const { code, volume } = await compileBundle( + 'android', + { + ...getReactNativeVirtualModules(), + './index.js': + "export { default } from './__fixtures__/assets/logo.png';", + }, + true + ); + + const context: { Export?: { default: Record } } = {}; + vm.runInNewContext(code, context); + + expect(context.Export?.default).toMatchSnapshot(); + expect(volume.toTree()).toMatchSnapshot(); + }); + + it.each([ + { preferredScale: 1 }, + { preferredScale: 2 }, + { preferredScale: 3 }, + ])('with scales ($preferredScale)', async ({ preferredScale }) => { + const { code, volume } = await compileBundle( + 'android', + { + ...getReactNativeVirtualModules(preferredScale), + './index.js': + "export { default } from './__fixtures__/assets/star.png';", + }, + true + ); + + const context: { Export?: { default: Record } } = {}; + vm.runInNewContext(code, context); + + expect(context.Export?.default).toMatchSnapshot(); + expect(volume.toTree()).toMatchSnapshot(); + }); + }); + + describe('should convert to remote-asset', () => { + it('without scales', async () => { + const { code, volume } = await compileBundle( + 'ios', // platform doesn't matter for remote-assets + { + ...getReactNativeVirtualModules(), + './index.js': + "export { default } from './__fixtures__/assets/logo.png';", + }, + false, + { + enabled: true, + publicPath: 'http://localhost:9999', + } + ); + + const context: { Export?: { default: Record } } = {}; + vm.runInNewContext(code, context); + + expect(context.Export?.default).toMatchSnapshot(); + expect(volume.toTree()).toMatchSnapshot(); + }); + + it.each([ + { preferredScale: 1 }, + { preferredScale: 2 }, + { preferredScale: 3 }, + ])('with scales $preferredScale', async ({ preferredScale }) => { + const { code, volume } = await compileBundle( + 'ios', // platform doesn't matter for remote-assets + { + ...getReactNativeVirtualModules(preferredScale), + './index.js': + "export { default } from './__fixtures__/assets/star.png';", + }, + false, + { + enabled: true, + publicPath: 'http://localhost:9999', + } + ); + + const context: { Export?: { default: Record } } = {}; + vm.runInNewContext(code, context); + + expect(context.Export?.default).toMatchSnapshot(); + expect(volume.toTree()).toMatchSnapshot(); + }); + + it('with URL containing a path after basename', async () => { + const { code, volume } = await compileBundle( + 'ios', // platform doesn't matter for remote-assets + { + ...getReactNativeVirtualModules(), + './index.js': + "export { default } from './__fixtures__/assets/logo.png';", + }, + false, + { + enabled: true, + publicPath: 'http://localhost:9999/remote-assets', + } + ); + + const context: { Export?: { default: Record } } = {}; + vm.runInNewContext(code, context); + + expect(context.Export?.default).toMatchSnapshot(); + expect(volume.toTree()).toMatchSnapshot(); + }); + + describe('with specified assetPath', () => { + it('without scales', async () => { + const { code, volume } = await compileBundle( + 'ios', // platform doesn't matter for remote-assets + { + ...getReactNativeVirtualModules(), + './index.js': + "export { default } from './__fixtures__/assets/logo.png';", + }, + false, + { + enabled: true, + assetPath: ({ + resourceFilename, + resourceDirname, + resourceExtensionType, + }) => { + return `${resourceDirname}/nested-folder/${resourceFilename}-fake-hash.${resourceExtensionType}`; + }, + publicPath: 'http://localhost:9999/remote-assets', + } + ); + + const context: { Export?: { default: Record } } = {}; + vm.runInNewContext(code, context); + + expect(context.Export?.default).toMatchSnapshot(); + expect(volume.toTree()).toMatchSnapshot(); + }); + + it.each([ + { preferredScale: 1 }, + { preferredScale: 2 }, + { preferredScale: 3 }, + ])('with scales $preferredScale', async ({ preferredScale }) => { + const { code, volume } = await compileBundle( + 'ios', // platform doesn't matter for remote-assets + { + ...getReactNativeVirtualModules(preferredScale), + './index.js': + "export { default } from './__fixtures__/assets/star.png';", + }, + false, + { + enabled: true, + assetPath: ({ + resourceFilename, + resourceDirname, + resourceExtensionType, + }) => { + return `${resourceDirname}/nested-folder/${resourceFilename}-fake-hash.${resourceExtensionType}`; + }, + publicPath: 'http://localhost:9999', + } + ); + + const context: { Export?: { default: Record } } = {}; + vm.runInNewContext(code, context); + + expect(context.Export?.default).toMatchSnapshot(); + expect(volume.toTree()).toMatchSnapshot(); + }); + }); + }); +}); diff --git a/tests/integration/src/vitest.d.ts b/tests/integration/src/vitest.d.ts new file mode 100644 index 000000000..f74518776 --- /dev/null +++ b/tests/integration/src/vitest.d.ts @@ -0,0 +1,7 @@ +import 'vitest'; + +declare module 'vitest' { + export interface ProvidedContext { + bundlerType: 'rspack' | 'webpack'; + } +} diff --git a/tests/integration/tsconfig.json b/tests/integration/tsconfig.json new file mode 100644 index 000000000..bec28a273 --- /dev/null +++ b/tests/integration/tsconfig.json @@ -0,0 +1,12 @@ +{ + "extends": "../../tsconfig.base.json", + "compilerOptions": { + "target": "ESNext", + "module": "ESNext", + "moduleResolution": "bundler", + "strict": true, + "noEmit": true, + "types": ["node", "vitest/globals"] + }, + "include": ["src", "vitest.config.ts"] +} diff --git a/tests/integration/vitest.config.ts b/tests/integration/vitest.config.ts new file mode 100644 index 000000000..6e2d2b80f --- /dev/null +++ b/tests/integration/vitest.config.ts @@ -0,0 +1,43 @@ +import { basename, dirname, join } from 'node:path'; +import { defineConfig } from 'vitest/config'; +import type { BundlerType } from './src/helpers.js'; + +export default defineConfig({ + test: { + // Store snapshots in separate directories per bundler for easier review + // e.g. __snapshots__/rspack/test.ts.snap, __snapshots__/webpack/test.ts.snap + resolveSnapshotPath(testPath, snapExtension, context) { + const projectName = context.config.name ?? 'default'; + return join( + dirname(testPath), + '__snapshots__', + projectName, + basename(testPath) + snapExtension + ); + }, + projects: [ + { + test: { + name: 'rspack', + include: ['src/**/*.test.ts'], + environment: 'node', + testTimeout: 30_000, + provide: { + bundlerType: 'rspack' satisfies BundlerType, + }, + }, + }, + { + test: { + name: 'webpack', + include: ['src/**/*.test.ts'], + environment: 'node', + testTimeout: 30_000, + provide: { + bundlerType: 'webpack' satisfies BundlerType, + }, + }, + }, + ], + }, +});