one 1.2.53 → 1.2.55
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/cli/build.cjs +11 -5
- package/dist/cjs/cli/build.js +11 -4
- package/dist/cjs/cli/build.js.map +1 -1
- package/dist/cjs/cli/build.native.js +9 -2
- package/dist/cjs/cli/build.native.js.map +1 -1
- package/dist/cjs/cli/generateSitemap.test.js.map +1 -1
- package/dist/cjs/cli/generateSitemap.test.native.js.map +1 -1
- package/dist/cjs/createApp.cjs +11 -11
- package/dist/cjs/createApp.js +5 -4
- package/dist/cjs/createApp.js.map +1 -1
- package/dist/cjs/getDevServer.native.js.map +1 -1
- package/dist/cjs/image/getImageData.cjs +91 -0
- package/dist/cjs/image/getImageData.js +64 -0
- package/dist/cjs/image/getImageData.js.map +6 -0
- package/dist/cjs/image/getImageData.native.js +95 -0
- package/dist/cjs/image/getImageData.native.js.map +1 -0
- package/dist/cjs/image.cjs +26 -0
- package/dist/cjs/image.js +21 -0
- package/dist/cjs/image.js.map +6 -0
- package/dist/cjs/image.native.js +29 -0
- package/dist/cjs/image.native.js.map +1 -0
- package/dist/cjs/index.cjs +3 -0
- package/dist/cjs/index.js +3 -1
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/index.native.js +3 -0
- package/dist/cjs/index.native.js.map +1 -1
- package/dist/cjs/metro-config/getViteMetroPluginOptions.cjs +2 -2
- package/dist/cjs/metro-config/getViteMetroPluginOptions.js +1 -1
- package/dist/cjs/metro-config/getViteMetroPluginOptions.js.map +1 -1
- package/dist/cjs/metro-config/getViteMetroPluginOptions.native.js +2 -2
- package/dist/cjs/metro-config/getViteMetroPluginOptions.native.js.map +1 -1
- package/dist/cjs/router/Route.js.map +1 -1
- package/dist/cjs/router/Route.native.js.map +1 -1
- package/dist/cjs/router/getRoutes.cjs +2 -2
- package/dist/cjs/router/getRoutes.js +1 -2
- package/dist/cjs/router/getRoutes.js.map +1 -1
- package/dist/cjs/router/getRoutes.native.js.map +1 -1
- package/dist/cjs/router/matchers.test.js +7 -1
- package/dist/cjs/router/matchers.test.js.map +1 -1
- package/dist/cjs/router/matchers.test.native.js.map +1 -1
- package/dist/cjs/router/useScreens.js +25 -5
- package/dist/cjs/router/useScreens.js.map +1 -1
- package/dist/cjs/router/useScreens.native.js.map +1 -1
- package/dist/cjs/router/useViteRoutes.cjs +1 -1
- package/dist/cjs/router/useViteRoutes.js +1 -1
- package/dist/cjs/router/useViteRoutes.js.map +1 -1
- package/dist/cjs/router/useViteRoutes.native.js.map +1 -1
- package/dist/cjs/server/getServerManifest.js +3 -1
- package/dist/cjs/server/getServerManifest.js.map +1 -1
- package/dist/cjs/server/getServerManifest.native.js.map +1 -1
- package/dist/cjs/server/oneServe.js +7 -2
- package/dist/cjs/server/oneServe.js.map +1 -1
- package/dist/cjs/server/oneServe.native.js.map +1 -1
- package/dist/cjs/typed-routes/generateRouteTypes.cjs +2 -2
- package/dist/cjs/typed-routes/generateRouteTypes.js +1 -1
- package/dist/cjs/typed-routes/generateRouteTypes.js.map +1 -1
- package/dist/cjs/typed-routes/generateRouteTypes.native.js +2 -2
- package/dist/cjs/typed-routes/generateRouteTypes.native.js.map +1 -1
- package/dist/cjs/typed-routes/injectRouteHelpers.cjs +2 -2
- package/dist/cjs/typed-routes/injectRouteHelpers.js +1 -1
- package/dist/cjs/typed-routes/injectRouteHelpers.js.map +1 -1
- package/dist/cjs/typed-routes/injectRouteHelpers.native.js +2 -2
- package/dist/cjs/typed-routes/injectRouteHelpers.native.js.map +1 -1
- package/dist/cjs/ui/TabSlot.cjs +1 -1
- package/dist/cjs/ui/TabSlot.js +1 -1
- package/dist/cjs/ui/TabSlot.js.map +1 -1
- package/dist/cjs/ui/TabSlot.native.js +2 -2
- package/dist/cjs/ui/TabSlot.native.js.map +1 -1
- package/dist/cjs/ui/TabTrigger.cjs +1 -1
- package/dist/cjs/ui/TabTrigger.js +1 -1
- package/dist/cjs/ui/TabTrigger.js.map +1 -1
- package/dist/cjs/ui/TabTrigger.native.js +1 -1
- package/dist/cjs/ui/TabTrigger.native.js.map +1 -1
- package/dist/cjs/ui/Tabs.cjs +7 -7
- package/dist/cjs/ui/Tabs.js +5 -2
- package/dist/cjs/ui/Tabs.js.map +1 -1
- package/dist/cjs/ui/Tabs.native.js +7 -7
- package/dist/cjs/ui/Tabs.native.js.map +1 -1
- package/dist/cjs/ui/common.cjs +1 -1
- package/dist/cjs/ui/common.js +1 -1
- package/dist/cjs/ui/common.js.map +1 -1
- package/dist/cjs/ui/common.native.js +1 -1
- package/dist/cjs/ui/common.native.js.map +1 -1
- package/dist/cjs/useLoader.cjs +1 -0
- package/dist/cjs/useLoader.js +1 -0
- package/dist/cjs/useLoader.js.map +1 -1
- package/dist/cjs/useLoader.native.js +1 -0
- package/dist/cjs/useLoader.native.js.map +1 -1
- package/dist/cjs/utils/promiseWithResolvers.cjs +4 -5
- package/dist/cjs/utils/promiseWithResolvers.js +2 -1
- package/dist/cjs/utils/promiseWithResolvers.js.map +1 -1
- package/dist/cjs/utils/promiseWithResolvers.native.js.map +1 -1
- package/dist/cjs/utils/trackLoaderDependencies.cjs +51 -0
- package/dist/cjs/utils/trackLoaderDependencies.js +40 -0
- package/dist/cjs/utils/trackLoaderDependencies.js.map +6 -0
- package/dist/cjs/utils/trackLoaderDependencies.native.js +57 -0
- package/dist/cjs/utils/trackLoaderDependencies.native.js.map +1 -0
- package/dist/cjs/utils/watchFile.cjs +35 -0
- package/dist/cjs/utils/watchFile.js +30 -0
- package/dist/cjs/utils/watchFile.js.map +6 -0
- package/dist/cjs/utils/watchFile.native.js +39 -0
- package/dist/cjs/utils/watchFile.native.js.map +1 -0
- package/dist/cjs/vercel/build/buildVercelOutputDirectory.js.map +1 -1
- package/dist/cjs/vercel/build/buildVercelOutputDirectory.native.js.map +1 -1
- package/dist/cjs/vercel/build/config/vc-build-output-config-base.cjs +2 -4
- package/dist/cjs/vercel/build/config/vc-build-output-config-base.js +2 -4
- package/dist/cjs/vercel/build/config/vc-build-output-config-base.js.map +1 -1
- package/dist/cjs/vercel/build/config/vc-build-output-config-base.native.js +2 -4
- package/dist/cjs/vercel/build/config/vc-build-output-config-base.native.js.map +1 -1
- package/dist/cjs/vite/DevHead.cjs +22 -0
- package/dist/cjs/vite/DevHead.js +26 -0
- package/dist/cjs/vite/DevHead.js.map +1 -1
- package/dist/cjs/vite/one.cjs +5 -4
- package/dist/cjs/vite/one.js +2 -1
- package/dist/cjs/vite/one.js.map +1 -1
- package/dist/cjs/vite/one.native.js +5 -4
- package/dist/cjs/vite/one.native.js.map +1 -1
- package/dist/cjs/vite/plugins/SSRCSSPlugin.cjs +7 -7
- package/dist/cjs/vite/plugins/SSRCSSPlugin.js +2 -3
- package/dist/cjs/vite/plugins/SSRCSSPlugin.js.map +1 -1
- package/dist/cjs/vite/plugins/SSRCSSPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/clientTreeShakePlugin.js +4 -1
- package/dist/cjs/vite/plugins/clientTreeShakePlugin.js.map +1 -1
- package/dist/cjs/vite/plugins/clientTreeShakePlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/fileSystemRouterPlugin.cjs +34 -7
- package/dist/cjs/vite/plugins/fileSystemRouterPlugin.js +43 -7
- package/dist/cjs/vite/plugins/fileSystemRouterPlugin.js.map +2 -2
- package/dist/cjs/vite/plugins/fileSystemRouterPlugin.native.js +82 -21
- package/dist/cjs/vite/plugins/fileSystemRouterPlugin.native.js.map +1 -1
- package/dist/cjs/vite/plugins/imageDataPlugin.cjs +70 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.js +55 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.js.map +6 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.native.js +77 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.native.js.map +1 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.test.cjs +214 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.test.js +184 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.test.js.map +6 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.test.native.js +228 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.test.native.js.map +1 -0
- package/dist/cjs/zero/useQuery.cjs +2 -2
- package/dist/cjs/zero/useQuery.js +1 -2
- package/dist/cjs/zero/useQuery.js.map +1 -1
- package/dist/cjs/zero/useQuery.native.js.map +1 -1
- package/dist/esm/cli/build.js +11 -4
- package/dist/esm/cli/build.js.map +1 -1
- package/dist/esm/cli/build.mjs +10 -4
- package/dist/esm/cli/build.mjs.map +1 -1
- package/dist/esm/cli/build.native.js +8 -1
- package/dist/esm/cli/build.native.js.map +1 -1
- package/dist/esm/cli/buildPage.js +1 -1
- package/dist/esm/cli/buildPage.js.map +1 -1
- package/dist/esm/cli/buildPage.mjs +1 -1
- package/dist/esm/cli/buildPage.mjs.map +1 -1
- package/dist/esm/cli/buildPage.native.js +1 -1
- package/dist/esm/cli/buildPage.native.js.map +1 -1
- package/dist/esm/cli/generateSitemap.test.js +1 -1
- package/dist/esm/cli/generateSitemap.test.js.map +1 -1
- package/dist/esm/cli/generateSitemap.test.mjs +1 -1
- package/dist/esm/cli/generateSitemap.test.mjs.map +1 -1
- package/dist/esm/cli/generateSitemap.test.native.js +1 -1
- package/dist/esm/cli/generateSitemap.test.native.js.map +1 -1
- package/dist/esm/createApp.js +5 -4
- package/dist/esm/createApp.js.map +1 -1
- package/dist/esm/createApp.mjs +11 -11
- package/dist/esm/createApp.mjs.map +1 -1
- package/dist/esm/getDevServer.native.js.map +1 -1
- package/dist/esm/image/getImageData.js +41 -0
- package/dist/esm/image/getImageData.js.map +6 -0
- package/dist/esm/image/getImageData.mjs +55 -0
- package/dist/esm/image/getImageData.mjs.map +1 -0
- package/dist/esm/image/getImageData.native.js +56 -0
- package/dist/esm/image/getImageData.native.js.map +1 -0
- package/dist/esm/image.js +5 -0
- package/dist/esm/image.js.map +6 -0
- package/dist/esm/image.mjs +3 -0
- package/dist/esm/image.mjs.map +1 -0
- package/dist/esm/image.native.js +3 -0
- package/dist/esm/image.native.js.map +1 -0
- package/dist/esm/index.js +4 -1
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/index.mjs +3 -2
- package/dist/esm/index.mjs.map +1 -1
- package/dist/esm/index.native.js +3 -2
- package/dist/esm/index.native.js.map +1 -1
- package/dist/esm/metro-config/getViteMetroPluginOptions.js +1 -1
- package/dist/esm/metro-config/getViteMetroPluginOptions.js.map +1 -1
- package/dist/esm/metro-config/getViteMetroPluginOptions.mjs +1 -1
- package/dist/esm/metro-config/getViteMetroPluginOptions.mjs.map +1 -1
- package/dist/esm/metro-config/getViteMetroPluginOptions.native.js +1 -1
- package/dist/esm/metro-config/getViteMetroPluginOptions.native.js.map +1 -1
- package/dist/esm/router/Route.js.map +1 -1
- package/dist/esm/router/Route.mjs.map +1 -1
- package/dist/esm/router/Route.native.js.map +1 -1
- package/dist/esm/router/getRoutes.js +1 -2
- package/dist/esm/router/getRoutes.js.map +1 -1
- package/dist/esm/router/getRoutes.mjs +2 -2
- package/dist/esm/router/getRoutes.mjs.map +1 -1
- package/dist/esm/router/getRoutes.native.js.map +1 -1
- package/dist/esm/router/matchers.test.js +7 -1
- package/dist/esm/router/matchers.test.js.map +1 -1
- package/dist/esm/router/matchers.test.mjs.map +1 -1
- package/dist/esm/router/matchers.test.native.js.map +1 -1
- package/dist/esm/router/router.js +1 -1
- package/dist/esm/router/router.js.map +1 -1
- package/dist/esm/router/router.mjs +1 -1
- package/dist/esm/router/router.mjs.map +1 -1
- package/dist/esm/router/router.native.js +1 -1
- package/dist/esm/router/router.native.js.map +1 -1
- package/dist/esm/router/useScreens.js +25 -5
- package/dist/esm/router/useScreens.js.map +1 -1
- package/dist/esm/router/useScreens.mjs.map +1 -1
- package/dist/esm/router/useScreens.native.js.map +1 -1
- package/dist/esm/router/useViteRoutes.js +1 -1
- package/dist/esm/router/useViteRoutes.js.map +1 -1
- package/dist/esm/router/useViteRoutes.mjs +1 -1
- package/dist/esm/router/useViteRoutes.mjs.map +1 -1
- package/dist/esm/router/useViteRoutes.native.js.map +1 -1
- package/dist/esm/serve-worker.js +1 -1
- package/dist/esm/serve-worker.mjs +1 -1
- package/dist/esm/serve-worker.mjs.map +1 -1
- package/dist/esm/serve-worker.native.js +1 -1
- package/dist/esm/serve-worker.native.js.map +1 -1
- package/dist/esm/server/getServerManifest.js +3 -1
- package/dist/esm/server/getServerManifest.js.map +1 -1
- package/dist/esm/server/getServerManifest.mjs.map +1 -1
- package/dist/esm/server/getServerManifest.native.js.map +1 -1
- package/dist/esm/server/oneServe.js +7 -2
- package/dist/esm/server/oneServe.js.map +1 -1
- package/dist/esm/server/oneServe.mjs.map +1 -1
- package/dist/esm/server/oneServe.native.js.map +1 -1
- package/dist/esm/typed-routes/generateRouteTypes.js +1 -1
- package/dist/esm/typed-routes/generateRouteTypes.js.map +1 -1
- package/dist/esm/typed-routes/generateRouteTypes.mjs +1 -1
- package/dist/esm/typed-routes/generateRouteTypes.mjs.map +1 -1
- package/dist/esm/typed-routes/generateRouteTypes.native.js +1 -1
- package/dist/esm/typed-routes/generateRouteTypes.native.js.map +1 -1
- package/dist/esm/typed-routes/injectRouteHelpers.js +1 -1
- package/dist/esm/typed-routes/injectRouteHelpers.js.map +1 -1
- package/dist/esm/typed-routes/injectRouteHelpers.mjs +1 -1
- package/dist/esm/typed-routes/injectRouteHelpers.mjs.map +1 -1
- package/dist/esm/typed-routes/injectRouteHelpers.native.js +1 -1
- package/dist/esm/typed-routes/injectRouteHelpers.native.js.map +1 -1
- package/dist/esm/ui/Slot.js.map +1 -1
- package/dist/esm/ui/Slot.mjs.map +1 -1
- package/dist/esm/ui/Slot.native.js.map +1 -1
- package/dist/esm/ui/TabList.js +1 -1
- package/dist/esm/ui/TabList.js.map +1 -1
- package/dist/esm/ui/TabList.mjs +1 -1
- package/dist/esm/ui/TabList.mjs.map +1 -1
- package/dist/esm/ui/TabList.native.js +1 -1
- package/dist/esm/ui/TabList.native.js.map +1 -1
- package/dist/esm/ui/TabRouter.js.map +1 -1
- package/dist/esm/ui/TabRouter.mjs.map +1 -1
- package/dist/esm/ui/TabRouter.native.js.map +1 -1
- package/dist/esm/ui/TabSlot.js +2 -2
- package/dist/esm/ui/TabSlot.js.map +1 -1
- package/dist/esm/ui/TabSlot.mjs +2 -2
- package/dist/esm/ui/TabSlot.mjs.map +1 -1
- package/dist/esm/ui/TabSlot.native.js +2 -2
- package/dist/esm/ui/TabSlot.native.js.map +1 -1
- package/dist/esm/ui/TabTrigger.js +3 -3
- package/dist/esm/ui/TabTrigger.js.map +1 -1
- package/dist/esm/ui/TabTrigger.mjs +2 -2
- package/dist/esm/ui/TabTrigger.mjs.map +1 -1
- package/dist/esm/ui/TabTrigger.native.js +2 -2
- package/dist/esm/ui/TabTrigger.native.js.map +1 -1
- package/dist/esm/ui/Tabs.js +10 -7
- package/dist/esm/ui/Tabs.js.map +1 -1
- package/dist/esm/ui/Tabs.mjs +6 -6
- package/dist/esm/ui/Tabs.mjs.map +1 -1
- package/dist/esm/ui/Tabs.native.js +6 -6
- package/dist/esm/ui/Tabs.native.js.map +1 -1
- package/dist/esm/ui/common.js +3 -3
- package/dist/esm/ui/common.js.map +1 -1
- package/dist/esm/ui/common.mjs +1 -1
- package/dist/esm/ui/common.mjs.map +1 -1
- package/dist/esm/ui/common.native.js +1 -1
- package/dist/esm/ui/common.native.js.map +1 -1
- package/dist/esm/ui/useComponent.js +1 -1
- package/dist/esm/ui/useComponent.js.map +1 -1
- package/dist/esm/ui/useComponent.mjs +1 -1
- package/dist/esm/ui/useComponent.mjs.map +1 -1
- package/dist/esm/ui/useComponent.native.js +1 -1
- package/dist/esm/ui/useComponent.native.js.map +1 -1
- package/dist/esm/useLoader.js +1 -0
- package/dist/esm/useLoader.js.map +1 -1
- package/dist/esm/useLoader.mjs +1 -0
- package/dist/esm/useLoader.mjs.map +1 -1
- package/dist/esm/useLoader.native.js +1 -0
- package/dist/esm/useLoader.native.js.map +1 -1
- package/dist/esm/utils/cleanUrl.js +1 -1
- package/dist/esm/utils/cleanUrl.mjs +1 -1
- package/dist/esm/utils/cleanUrl.mjs.map +1 -1
- package/dist/esm/utils/cleanUrl.native.js +1 -1
- package/dist/esm/utils/cleanUrl.native.js.map +1 -1
- package/dist/esm/utils/promiseWithResolvers.js +2 -1
- package/dist/esm/utils/promiseWithResolvers.js.map +1 -1
- package/dist/esm/utils/promiseWithResolvers.mjs +4 -5
- package/dist/esm/utils/promiseWithResolvers.mjs.map +1 -1
- package/dist/esm/utils/promiseWithResolvers.native.js.map +1 -1
- package/dist/esm/utils/trackLoaderDependencies.js +25 -0
- package/dist/esm/utils/trackLoaderDependencies.js.map +6 -0
- package/dist/esm/utils/trackLoaderDependencies.mjs +28 -0
- package/dist/esm/utils/trackLoaderDependencies.mjs.map +1 -0
- package/dist/esm/utils/trackLoaderDependencies.native.js +31 -0
- package/dist/esm/utils/trackLoaderDependencies.native.js.map +1 -0
- package/dist/esm/utils/watchFile.js +14 -0
- package/dist/esm/utils/watchFile.js.map +6 -0
- package/dist/esm/utils/watchFile.mjs +11 -0
- package/dist/esm/utils/watchFile.mjs.map +1 -0
- package/dist/esm/utils/watchFile.native.js +12 -0
- package/dist/esm/utils/watchFile.native.js.map +1 -0
- package/dist/esm/vercel/build/buildVercelOutputDirectory.js.map +1 -1
- package/dist/esm/vercel/build/buildVercelOutputDirectory.mjs.map +1 -1
- package/dist/esm/vercel/build/buildVercelOutputDirectory.native.js.map +1 -1
- package/dist/esm/vercel/build/config/vc-build-output-config-base.js +2 -4
- package/dist/esm/vercel/build/config/vc-build-output-config-base.js.map +1 -1
- package/dist/esm/vercel/build/config/vc-build-output-config-base.mjs +2 -4
- package/dist/esm/vercel/build/config/vc-build-output-config-base.mjs.map +1 -1
- package/dist/esm/vercel/build/config/vc-build-output-config-base.native.js +2 -4
- package/dist/esm/vercel/build/config/vc-build-output-config-base.native.js.map +1 -1
- package/dist/esm/vite/DevHead.js +26 -0
- package/dist/esm/vite/DevHead.js.map +1 -1
- package/dist/esm/vite/DevHead.mjs +22 -0
- package/dist/esm/vite/DevHead.mjs.map +1 -1
- package/dist/esm/vite/one.js +4 -2
- package/dist/esm/vite/one.js.map +1 -1
- package/dist/esm/vite/one.mjs +4 -3
- package/dist/esm/vite/one.mjs.map +1 -1
- package/dist/esm/vite/one.native.js +4 -3
- package/dist/esm/vite/one.native.js.map +1 -1
- package/dist/esm/vite/plugins/SSRCSSPlugin.js +2 -3
- package/dist/esm/vite/plugins/SSRCSSPlugin.js.map +1 -1
- package/dist/esm/vite/plugins/SSRCSSPlugin.mjs +7 -7
- package/dist/esm/vite/plugins/SSRCSSPlugin.mjs.map +1 -1
- package/dist/esm/vite/plugins/SSRCSSPlugin.native.js.map +1 -1
- package/dist/esm/vite/plugins/clientTreeShakePlugin.js +4 -1
- package/dist/esm/vite/plugins/clientTreeShakePlugin.js.map +1 -1
- package/dist/esm/vite/plugins/clientTreeShakePlugin.mjs.map +1 -1
- package/dist/esm/vite/plugins/clientTreeShakePlugin.native.js.map +1 -1
- package/dist/esm/vite/plugins/fileSystemRouterPlugin.js +43 -6
- package/dist/esm/vite/plugins/fileSystemRouterPlugin.js.map +2 -2
- package/dist/esm/vite/plugins/fileSystemRouterPlugin.mjs +34 -7
- package/dist/esm/vite/plugins/fileSystemRouterPlugin.mjs.map +1 -1
- package/dist/esm/vite/plugins/fileSystemRouterPlugin.native.js +82 -21
- package/dist/esm/vite/plugins/fileSystemRouterPlugin.native.js.map +1 -1
- package/dist/esm/vite/plugins/imageDataPlugin.js +41 -0
- package/dist/esm/vite/plugins/imageDataPlugin.js.map +6 -0
- package/dist/esm/vite/plugins/imageDataPlugin.mjs +47 -0
- package/dist/esm/vite/plugins/imageDataPlugin.mjs.map +1 -0
- package/dist/esm/vite/plugins/imageDataPlugin.native.js +51 -0
- package/dist/esm/vite/plugins/imageDataPlugin.native.js.map +1 -0
- package/dist/esm/vite/plugins/imageDataPlugin.test.js +165 -0
- package/dist/esm/vite/plugins/imageDataPlugin.test.js.map +6 -0
- package/dist/esm/vite/plugins/imageDataPlugin.test.mjs +193 -0
- package/dist/esm/vite/plugins/imageDataPlugin.test.mjs.map +1 -0
- package/dist/esm/vite/plugins/imageDataPlugin.test.native.js +204 -0
- package/dist/esm/vite/plugins/imageDataPlugin.test.native.js.map +1 -0
- package/dist/esm/zero/useQuery.js +1 -2
- package/dist/esm/zero/useQuery.js.map +1 -1
- package/dist/esm/zero/useQuery.mjs +2 -2
- package/dist/esm/zero/useQuery.mjs.map +1 -1
- package/dist/esm/zero/useQuery.native.js.map +1 -1
- package/package.json +19 -10
- package/src/cli/build.ts +18 -3
- package/src/cli/buildPage.ts +1 -1
- package/src/cli/generateSitemap.test.ts +2 -2
- package/src/createApp.native.tsx +1 -1
- package/src/createApp.tsx +5 -3
- package/src/createMiddleware.ts +1 -1
- package/src/getDevServer.native.ts +0 -2
- package/src/image/getImageData.ts +104 -0
- package/src/image.ts +1 -0
- package/src/index.ts +20 -1
- package/src/interfaces/router.ts +6 -2
- package/src/metro-config/getViteMetroPluginOptions.ts +2 -2
- package/src/router/Route.tsx +5 -1
- package/src/router/getRoutes.ts +1 -1
- package/src/router/matchers.test.ts +8 -2
- package/src/router/router.ts +1 -1
- package/src/router/useScreens.tsx +19 -3
- package/src/router/useViteRoutes.tsx +1 -1
- package/src/serve-worker.ts +1 -1
- package/src/server/getServerManifest.ts +3 -1
- package/src/server/oneServe.ts +9 -4
- package/src/typed-routes/generateRouteTypes.ts +2 -2
- package/src/typed-routes/injectRouteHelpers.ts +1 -1
- package/src/ui/Slot.tsx +3 -3
- package/src/ui/TabList.tsx +2 -2
- package/src/ui/TabRouter.tsx +2 -2
- package/src/ui/TabSlot.tsx +2 -3
- package/src/ui/TabTrigger.tsx +8 -9
- package/src/ui/Tabs.tsx +15 -13
- package/src/ui/common.tsx +5 -6
- package/src/ui/useComponent.tsx +1 -1
- package/src/useLoader.ts +4 -0
- package/src/utils/cleanUrl.ts +1 -1
- package/src/utils/promiseWithResolvers.ts +1 -1
- package/src/utils/trackLoaderDependencies.ts +53 -0
- package/src/utils/watchFile.ts +19 -0
- package/src/vercel/build/buildVercelOutputDirectory.ts +1 -1
- package/src/vercel/build/config/vc-build-output-config-base.ts +2 -4
- package/src/vite/DevHead.tsx +23 -0
- package/src/vite/one.ts +5 -2
- package/src/vite/plugins/SSRCSSPlugin.ts +2 -2
- package/src/vite/plugins/clientTreeShakePlugin.ts +4 -1
- package/src/vite/plugins/fileSystemRouterPlugin.tsx +76 -3
- package/src/vite/plugins/imageDataPlugin.test.ts +316 -0
- package/src/vite/plugins/imageDataPlugin.ts +89 -0
- package/src/vite/types.ts +1 -1
- package/src/zero/useQuery.ts +1 -1
- package/types/cli/build.d.ts.map +1 -1
- package/types/createApp.d.ts.map +1 -1
- package/types/createMiddleware.d.ts +1 -2
- package/types/createMiddleware.d.ts.map +1 -1
- package/types/env.d.ts +23 -0
- package/types/getDevServer.native.d.ts.map +1 -1
- package/types/image/getImageData.d.ts +34 -0
- package/types/image/getImageData.d.ts.map +1 -0
- package/types/image.d.ts +2 -0
- package/types/image.d.ts.map +1 -0
- package/types/index.d.ts +19 -1
- package/types/index.d.ts.map +1 -1
- package/types/interfaces/router.d.ts.map +1 -1
- package/types/layouts/Drawer.d.ts +2 -2
- package/types/layouts/Stack.d.ts +2 -2
- package/types/layouts/Tabs.d.ts +2 -2
- package/types/metro-config/getViteMetroPluginOptions.d.ts.map +1 -1
- package/types/router/Route.d.ts.map +1 -1
- package/types/serve-worker.d.ts +1 -1
- package/types/server/getServerManifest.d.ts.map +1 -1
- package/types/server/oneServe.d.ts.map +1 -1
- package/types/ui/Slot.d.ts +1 -1
- package/types/ui/Slot.d.ts.map +1 -1
- package/types/ui/TabList.d.ts +1 -1
- package/types/ui/TabList.d.ts.map +1 -1
- package/types/ui/TabRouter.d.ts +1 -1
- package/types/ui/TabRouter.d.ts.map +1 -1
- package/types/ui/TabSlot.d.ts.map +1 -1
- package/types/ui/TabTrigger.d.ts +3 -3
- package/types/ui/TabTrigger.d.ts.map +1 -1
- package/types/ui/Tabs.d.ts +17 -2
- package/types/ui/Tabs.d.ts.map +1 -1
- package/types/ui/common.d.ts +2 -2
- package/types/ui/common.d.ts.map +1 -1
- package/types/ui/useComponent.d.ts.map +1 -1
- package/types/useLoader.d.ts.map +1 -1
- package/types/utils/trackLoaderDependencies.d.ts +6 -0
- package/types/utils/trackLoaderDependencies.d.ts.map +1 -0
- package/types/utils/watchFile.d.ts +8 -0
- package/types/utils/watchFile.d.ts.map +1 -0
- package/types/vercel/build/config/vc-build-output-config-base.d.ts +0 -1
- package/types/vercel/build/config/vc-build-output-config-base.d.ts.map +1 -1
- package/types/vite/DevHead.d.ts.map +1 -1
- package/types/vite/one.d.ts.map +1 -1
- package/types/vite/plugins/clientTreeShakePlugin.d.ts.map +1 -1
- package/types/vite/plugins/fileSystemRouterPlugin.d.ts.map +1 -1
- package/types/vite/plugins/imageDataPlugin.d.ts +3 -0
- package/types/vite/plugins/imageDataPlugin.d.ts.map +1 -0
- package/types/vite/plugins/imageDataPlugin.test.d.ts +2 -0
- package/types/vite/plugins/imageDataPlugin.test.d.ts.map +1 -0
- package/types/vite/types.d.ts +1 -1
- package/types/vite/types.d.ts.map +1 -1
|
@@ -0,0 +1,214 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf,
|
|
6
|
+
__hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __copyProps = (to, from, except, desc) => {
|
|
8
|
+
if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
|
|
9
|
+
get: () => from[key],
|
|
10
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
11
|
+
});
|
|
12
|
+
return to;
|
|
13
|
+
};
|
|
14
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
15
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
16
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
17
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
18
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
19
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
|
|
20
|
+
value: mod,
|
|
21
|
+
enumerable: !0
|
|
22
|
+
}) : target, mod));
|
|
23
|
+
var import_vitest = require("vitest");
|
|
24
|
+
import_vitest.vi.mock("node:fs", async () => ({
|
|
25
|
+
...(await import_vitest.vi.importActual("node:fs")),
|
|
26
|
+
existsSync: import_vitest.vi.fn(path => path.includes("test-image.jpg") || path.includes("hero.png"))
|
|
27
|
+
}));
|
|
28
|
+
(0, import_vitest.describe)("imageDataPlugin", () => {
|
|
29
|
+
(0, import_vitest.beforeEach)(() => {
|
|
30
|
+
import_vitest.vi.resetModules();
|
|
31
|
+
}), (0, import_vitest.afterEach)(() => {
|
|
32
|
+
import_vitest.vi.clearAllMocks();
|
|
33
|
+
}), (0, import_vitest.describe)("resolveId", () => {
|
|
34
|
+
(0, import_vitest.it)("should return null for non-imagedata imports", async () => {
|
|
35
|
+
const {
|
|
36
|
+
imageDataPlugin
|
|
37
|
+
} = await import("./imageDataPlugin"),
|
|
38
|
+
plugin = imageDataPlugin(),
|
|
39
|
+
mockConfig = {
|
|
40
|
+
publicDir: "/project/public",
|
|
41
|
+
root: "/project"
|
|
42
|
+
};
|
|
43
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
44
|
+
const result = await plugin.resolveId("./image.jpg", void 0);
|
|
45
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
46
|
+
}), (0, import_vitest.it)("should return null for imports with imagedata not as suffix", async () => {
|
|
47
|
+
const {
|
|
48
|
+
imageDataPlugin
|
|
49
|
+
} = await import("./imageDataPlugin"),
|
|
50
|
+
plugin = imageDataPlugin(),
|
|
51
|
+
mockConfig = {
|
|
52
|
+
publicDir: "/project/public",
|
|
53
|
+
root: "/project"
|
|
54
|
+
};
|
|
55
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
56
|
+
const result = await plugin.resolveId("./image?imagedata.jpg", void 0);
|
|
57
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
58
|
+
}), (0, import_vitest.it)("should resolve public dir paths starting with /", async () => {
|
|
59
|
+
const {
|
|
60
|
+
imageDataPlugin
|
|
61
|
+
} = await import("./imageDataPlugin"),
|
|
62
|
+
plugin = imageDataPlugin(),
|
|
63
|
+
mockConfig = {
|
|
64
|
+
publicDir: "/project/public",
|
|
65
|
+
root: "/project"
|
|
66
|
+
};
|
|
67
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
68
|
+
const result = await plugin.resolveId("/test-image.jpg?imagedata", void 0);
|
|
69
|
+
(0, import_vitest.expect)(result).toBe("\0imagedata:/project/public/test-image.jpg");
|
|
70
|
+
}), (0, import_vitest.it)("should resolve relative imports", async () => {
|
|
71
|
+
const {
|
|
72
|
+
imageDataPlugin
|
|
73
|
+
} = await import("./imageDataPlugin"),
|
|
74
|
+
plugin = imageDataPlugin(),
|
|
75
|
+
mockConfig = {
|
|
76
|
+
publicDir: "/project/public",
|
|
77
|
+
root: "/project"
|
|
78
|
+
};
|
|
79
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
80
|
+
const result = await plugin.resolveId("./test-image.jpg?imagedata", "/project/src/components/Hero.tsx");
|
|
81
|
+
(0, import_vitest.expect)(result).toBe("\0imagedata:/project/src/components/test-image.jpg");
|
|
82
|
+
}), (0, import_vitest.it)("should return null for non-existent files", async () => {
|
|
83
|
+
const {
|
|
84
|
+
imageDataPlugin
|
|
85
|
+
} = await import("./imageDataPlugin"),
|
|
86
|
+
plugin = imageDataPlugin(),
|
|
87
|
+
mockConfig = {
|
|
88
|
+
publicDir: "/project/public",
|
|
89
|
+
root: "/project"
|
|
90
|
+
};
|
|
91
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
92
|
+
const result = await plugin.resolveId("/nonexistent.jpg?imagedata", void 0);
|
|
93
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
94
|
+
});
|
|
95
|
+
}), (0, import_vitest.describe)("path traversal prevention", () => {
|
|
96
|
+
(0, import_vitest.it)("should block path traversal from public dir", async () => {
|
|
97
|
+
const {
|
|
98
|
+
imageDataPlugin
|
|
99
|
+
} = await import("./imageDataPlugin"),
|
|
100
|
+
plugin = imageDataPlugin(),
|
|
101
|
+
mockConfig = {
|
|
102
|
+
publicDir: "/project/public",
|
|
103
|
+
root: "/project"
|
|
104
|
+
};
|
|
105
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
106
|
+
const result = await plugin.resolveId("/../../../etc/passwd?imagedata", void 0);
|
|
107
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
108
|
+
}), (0, import_vitest.it)("should block path traversal from relative imports", async () => {
|
|
109
|
+
const {
|
|
110
|
+
imageDataPlugin
|
|
111
|
+
} = await import("./imageDataPlugin"),
|
|
112
|
+
plugin = imageDataPlugin(),
|
|
113
|
+
mockConfig = {
|
|
114
|
+
publicDir: "/project/public",
|
|
115
|
+
root: "/project"
|
|
116
|
+
};
|
|
117
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
118
|
+
const result = await plugin.resolveId("../../../../etc/passwd?imagedata", "/project/src/components/Hero.tsx");
|
|
119
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
120
|
+
}), (0, import_vitest.it)("should block path traversal from root", async () => {
|
|
121
|
+
const {
|
|
122
|
+
imageDataPlugin
|
|
123
|
+
} = await import("./imageDataPlugin"),
|
|
124
|
+
plugin = imageDataPlugin(),
|
|
125
|
+
mockConfig = {
|
|
126
|
+
publicDir: "/project/public",
|
|
127
|
+
root: "/project"
|
|
128
|
+
};
|
|
129
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
130
|
+
const result = await plugin.resolveId("../../../etc/passwd?imagedata", void 0);
|
|
131
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
132
|
+
}), (0, import_vitest.it)("should allow paths within project boundaries", async () => {
|
|
133
|
+
const {
|
|
134
|
+
imageDataPlugin
|
|
135
|
+
} = await import("./imageDataPlugin"),
|
|
136
|
+
plugin = imageDataPlugin(),
|
|
137
|
+
mockConfig = {
|
|
138
|
+
publicDir: "/project/public",
|
|
139
|
+
root: "/project"
|
|
140
|
+
};
|
|
141
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
142
|
+
const result = await plugin.resolveId("../../src/test-image.jpg?imagedata", "/project/src/components/Hero.tsx");
|
|
143
|
+
(0, import_vitest.expect)(result).toBe("\0imagedata:/project/src/test-image.jpg");
|
|
144
|
+
});
|
|
145
|
+
}), (0, import_vitest.describe)("load", () => {
|
|
146
|
+
(0, import_vitest.it)("should return null for non-virtual modules", async () => {
|
|
147
|
+
const {
|
|
148
|
+
imageDataPlugin
|
|
149
|
+
} = await import("./imageDataPlugin"),
|
|
150
|
+
plugin = imageDataPlugin(),
|
|
151
|
+
mockConfig = {
|
|
152
|
+
publicDir: "/project/public",
|
|
153
|
+
root: "/project"
|
|
154
|
+
};
|
|
155
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
156
|
+
const mockContext = {
|
|
157
|
+
addWatchFile: import_vitest.vi.fn()
|
|
158
|
+
},
|
|
159
|
+
result = await plugin.load.call(mockContext, "./image.jpg");
|
|
160
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
161
|
+
}), (0, import_vitest.it)("should return fallback data when sharp fails", async () => {
|
|
162
|
+
const {
|
|
163
|
+
imageDataPlugin
|
|
164
|
+
} = await import("./imageDataPlugin"),
|
|
165
|
+
plugin = imageDataPlugin(),
|
|
166
|
+
mockConfig = {
|
|
167
|
+
publicDir: "/project/public",
|
|
168
|
+
root: "/project"
|
|
169
|
+
};
|
|
170
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
171
|
+
const mockContext = {
|
|
172
|
+
addWatchFile: import_vitest.vi.fn()
|
|
173
|
+
},
|
|
174
|
+
result = await plugin.load.call(mockContext, "\0imagedata:/project/public/test-image.jpg");
|
|
175
|
+
(0, import_vitest.expect)(result).toContain("export default"), (0, import_vitest.expect)(result).toContain('"src":"/test-image.jpg"'), (0, import_vitest.expect)(result).toContain('"width":'), (0, import_vitest.expect)(result).toContain('"height":'), (0, import_vitest.expect)(mockContext.addWatchFile).toHaveBeenCalledWith("/project/public/test-image.jpg");
|
|
176
|
+
});
|
|
177
|
+
}), (0, import_vitest.describe)("plugin metadata", () => {
|
|
178
|
+
(0, import_vitest.it)("should have correct name", async () => {
|
|
179
|
+
const {
|
|
180
|
+
imageDataPlugin
|
|
181
|
+
} = await import("./imageDataPlugin"),
|
|
182
|
+
plugin = imageDataPlugin();
|
|
183
|
+
(0, import_vitest.expect)(plugin.name).toBe("one:imagedata");
|
|
184
|
+
}), (0, import_vitest.it)("should enforce pre", async () => {
|
|
185
|
+
const {
|
|
186
|
+
imageDataPlugin
|
|
187
|
+
} = await import("./imageDataPlugin"),
|
|
188
|
+
plugin = imageDataPlugin();
|
|
189
|
+
(0, import_vitest.expect)(plugin.enforce).toBe("pre");
|
|
190
|
+
});
|
|
191
|
+
});
|
|
192
|
+
});
|
|
193
|
+
(0, import_vitest.describe)("imageDataPlugin output format", () => {
|
|
194
|
+
(0, import_vitest.it)("should export a valid JSON object", async () => {
|
|
195
|
+
import_vitest.vi.resetModules();
|
|
196
|
+
const {
|
|
197
|
+
imageDataPlugin
|
|
198
|
+
} = await import("./imageDataPlugin"),
|
|
199
|
+
plugin = imageDataPlugin(),
|
|
200
|
+
mockConfig = {
|
|
201
|
+
publicDir: "/project/public",
|
|
202
|
+
root: "/project"
|
|
203
|
+
};
|
|
204
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
205
|
+
const mockContext = {
|
|
206
|
+
addWatchFile: import_vitest.vi.fn()
|
|
207
|
+
},
|
|
208
|
+
jsonMatch = (await plugin.load.call(mockContext, "\0imagedata:/project/public/test-image.jpg"))?.match(/export default (.+)$/);
|
|
209
|
+
if ((0, import_vitest.expect)(jsonMatch).toBeTruthy(), jsonMatch) {
|
|
210
|
+
const parsed = JSON.parse(jsonMatch[1]);
|
|
211
|
+
(0, import_vitest.expect)(parsed).toHaveProperty("src"), (0, import_vitest.expect)(parsed).toHaveProperty("width"), (0, import_vitest.expect)(parsed).toHaveProperty("height"), (0, import_vitest.expect)(parsed).toHaveProperty("blurDataURL"), (0, import_vitest.expect)(typeof parsed.src).toBe("string"), (0, import_vitest.expect)(typeof parsed.width).toBe("number"), (0, import_vitest.expect)(typeof parsed.height).toBe("number"), (0, import_vitest.expect)(typeof parsed.blurDataURL).toBe("string");
|
|
212
|
+
}
|
|
213
|
+
});
|
|
214
|
+
});
|
|
@@ -0,0 +1,184 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf, __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __copyProps = (to, from, except, desc) => {
|
|
7
|
+
if (from && typeof from == "object" || typeof from == "function")
|
|
8
|
+
for (let key of __getOwnPropNames(from))
|
|
9
|
+
!__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
10
|
+
return to;
|
|
11
|
+
};
|
|
12
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
13
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
14
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
15
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
16
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
17
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: !0 }) : target,
|
|
18
|
+
mod
|
|
19
|
+
));
|
|
20
|
+
var import_vitest = require("vitest");
|
|
21
|
+
import_vitest.vi.mock("node:fs", async () => ({
|
|
22
|
+
...await import_vitest.vi.importActual("node:fs"),
|
|
23
|
+
existsSync: import_vitest.vi.fn((path) => path.includes("test-image.jpg") || path.includes("hero.png"))
|
|
24
|
+
}));
|
|
25
|
+
(0, import_vitest.describe)("imageDataPlugin", () => {
|
|
26
|
+
(0, import_vitest.beforeEach)(() => {
|
|
27
|
+
import_vitest.vi.resetModules();
|
|
28
|
+
}), (0, import_vitest.afterEach)(() => {
|
|
29
|
+
import_vitest.vi.clearAllMocks();
|
|
30
|
+
}), (0, import_vitest.describe)("resolveId", () => {
|
|
31
|
+
(0, import_vitest.it)("should return null for non-imagedata imports", async () => {
|
|
32
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
33
|
+
publicDir: "/project/public",
|
|
34
|
+
root: "/project"
|
|
35
|
+
};
|
|
36
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
37
|
+
const result = await plugin.resolveId("./image.jpg", void 0);
|
|
38
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
39
|
+
}), (0, import_vitest.it)("should return null for imports with imagedata not as suffix", async () => {
|
|
40
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
41
|
+
publicDir: "/project/public",
|
|
42
|
+
root: "/project"
|
|
43
|
+
};
|
|
44
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
45
|
+
const result = await plugin.resolveId("./image?imagedata.jpg", void 0);
|
|
46
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
47
|
+
}), (0, import_vitest.it)("should resolve public dir paths starting with /", async () => {
|
|
48
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
49
|
+
publicDir: "/project/public",
|
|
50
|
+
root: "/project"
|
|
51
|
+
};
|
|
52
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
53
|
+
const result = await plugin.resolveId(
|
|
54
|
+
"/test-image.jpg?imagedata",
|
|
55
|
+
void 0
|
|
56
|
+
);
|
|
57
|
+
(0, import_vitest.expect)(result).toBe("\0imagedata:/project/public/test-image.jpg");
|
|
58
|
+
}), (0, import_vitest.it)("should resolve relative imports", async () => {
|
|
59
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
60
|
+
publicDir: "/project/public",
|
|
61
|
+
root: "/project"
|
|
62
|
+
};
|
|
63
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
64
|
+
const result = await plugin.resolveId(
|
|
65
|
+
"./test-image.jpg?imagedata",
|
|
66
|
+
"/project/src/components/Hero.tsx"
|
|
67
|
+
);
|
|
68
|
+
(0, import_vitest.expect)(result).toBe("\0imagedata:/project/src/components/test-image.jpg");
|
|
69
|
+
}), (0, import_vitest.it)("should return null for non-existent files", async () => {
|
|
70
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
71
|
+
publicDir: "/project/public",
|
|
72
|
+
root: "/project"
|
|
73
|
+
};
|
|
74
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
75
|
+
const result = await plugin.resolveId(
|
|
76
|
+
"/nonexistent.jpg?imagedata",
|
|
77
|
+
void 0
|
|
78
|
+
);
|
|
79
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
80
|
+
});
|
|
81
|
+
}), (0, import_vitest.describe)("path traversal prevention", () => {
|
|
82
|
+
(0, import_vitest.it)("should block path traversal from public dir", async () => {
|
|
83
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
84
|
+
publicDir: "/project/public",
|
|
85
|
+
root: "/project"
|
|
86
|
+
};
|
|
87
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
88
|
+
const result = await plugin.resolveId(
|
|
89
|
+
"/../../../etc/passwd?imagedata",
|
|
90
|
+
void 0
|
|
91
|
+
);
|
|
92
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
93
|
+
}), (0, import_vitest.it)("should block path traversal from relative imports", async () => {
|
|
94
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
95
|
+
publicDir: "/project/public",
|
|
96
|
+
root: "/project"
|
|
97
|
+
};
|
|
98
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
99
|
+
const result = await plugin.resolveId(
|
|
100
|
+
"../../../../etc/passwd?imagedata",
|
|
101
|
+
"/project/src/components/Hero.tsx"
|
|
102
|
+
);
|
|
103
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
104
|
+
}), (0, import_vitest.it)("should block path traversal from root", async () => {
|
|
105
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
106
|
+
publicDir: "/project/public",
|
|
107
|
+
root: "/project"
|
|
108
|
+
};
|
|
109
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
110
|
+
const result = await plugin.resolveId(
|
|
111
|
+
"../../../etc/passwd?imagedata",
|
|
112
|
+
void 0
|
|
113
|
+
);
|
|
114
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
115
|
+
}), (0, import_vitest.it)("should allow paths within project boundaries", async () => {
|
|
116
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
117
|
+
publicDir: "/project/public",
|
|
118
|
+
root: "/project"
|
|
119
|
+
};
|
|
120
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
121
|
+
const result = await plugin.resolveId(
|
|
122
|
+
"../../src/test-image.jpg?imagedata",
|
|
123
|
+
"/project/src/components/Hero.tsx"
|
|
124
|
+
);
|
|
125
|
+
(0, import_vitest.expect)(result).toBe("\0imagedata:/project/src/test-image.jpg");
|
|
126
|
+
});
|
|
127
|
+
}), (0, import_vitest.describe)("load", () => {
|
|
128
|
+
(0, import_vitest.it)("should return null for non-virtual modules", async () => {
|
|
129
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
130
|
+
publicDir: "/project/public",
|
|
131
|
+
root: "/project"
|
|
132
|
+
};
|
|
133
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
134
|
+
const mockContext = {
|
|
135
|
+
addWatchFile: import_vitest.vi.fn()
|
|
136
|
+
}, result = await plugin.load.call(mockContext, "./image.jpg");
|
|
137
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
138
|
+
}), (0, import_vitest.it)("should return fallback data when sharp fails", async () => {
|
|
139
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
140
|
+
publicDir: "/project/public",
|
|
141
|
+
root: "/project"
|
|
142
|
+
};
|
|
143
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
144
|
+
const mockContext = {
|
|
145
|
+
addWatchFile: import_vitest.vi.fn()
|
|
146
|
+
}, result = await plugin.load.call(
|
|
147
|
+
mockContext,
|
|
148
|
+
"\0imagedata:/project/public/test-image.jpg"
|
|
149
|
+
);
|
|
150
|
+
(0, import_vitest.expect)(result).toContain("export default"), (0, import_vitest.expect)(result).toContain('"src":"/test-image.jpg"'), (0, import_vitest.expect)(result).toContain('"width":'), (0, import_vitest.expect)(result).toContain('"height":'), (0, import_vitest.expect)(mockContext.addWatchFile).toHaveBeenCalledWith(
|
|
151
|
+
"/project/public/test-image.jpg"
|
|
152
|
+
);
|
|
153
|
+
});
|
|
154
|
+
}), (0, import_vitest.describe)("plugin metadata", () => {
|
|
155
|
+
(0, import_vitest.it)("should have correct name", async () => {
|
|
156
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin();
|
|
157
|
+
(0, import_vitest.expect)(plugin.name).toBe("one:imagedata");
|
|
158
|
+
}), (0, import_vitest.it)("should enforce pre", async () => {
|
|
159
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin();
|
|
160
|
+
(0, import_vitest.expect)(plugin.enforce).toBe("pre");
|
|
161
|
+
});
|
|
162
|
+
});
|
|
163
|
+
});
|
|
164
|
+
(0, import_vitest.describe)("imageDataPlugin output format", () => {
|
|
165
|
+
(0, import_vitest.it)("should export a valid JSON object", async () => {
|
|
166
|
+
import_vitest.vi.resetModules();
|
|
167
|
+
const { imageDataPlugin } = await import("./imageDataPlugin"), plugin = imageDataPlugin(), mockConfig = {
|
|
168
|
+
publicDir: "/project/public",
|
|
169
|
+
root: "/project"
|
|
170
|
+
};
|
|
171
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
172
|
+
const mockContext = {
|
|
173
|
+
addWatchFile: import_vitest.vi.fn()
|
|
174
|
+
}, jsonMatch = (await plugin.load.call(
|
|
175
|
+
mockContext,
|
|
176
|
+
"\0imagedata:/project/public/test-image.jpg"
|
|
177
|
+
))?.match(/export default (.+)$/);
|
|
178
|
+
if ((0, import_vitest.expect)(jsonMatch).toBeTruthy(), jsonMatch) {
|
|
179
|
+
const parsed = JSON.parse(jsonMatch[1]);
|
|
180
|
+
(0, import_vitest.expect)(parsed).toHaveProperty("src"), (0, import_vitest.expect)(parsed).toHaveProperty("width"), (0, import_vitest.expect)(parsed).toHaveProperty("height"), (0, import_vitest.expect)(parsed).toHaveProperty("blurDataURL"), (0, import_vitest.expect)(typeof parsed.src).toBe("string"), (0, import_vitest.expect)(typeof parsed.width).toBe("number"), (0, import_vitest.expect)(typeof parsed.height).toBe("number"), (0, import_vitest.expect)(typeof parsed.blurDataURL).toBe("string");
|
|
181
|
+
}
|
|
182
|
+
});
|
|
183
|
+
});
|
|
184
|
+
//# sourceMappingURL=imageDataPlugin.test.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/vite/plugins/imageDataPlugin.test.ts"],
|
|
4
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;AAAA,oBAAgE;AAGhE,iBAAG,KAAK,WAAW,aAEV;AAAA,EACL,GAFa,MAAM,iBAAG,aAAa,SAAS;AAAA,EAG5C,YAAY,iBAAG,GAAG,CAAC,SACV,KAAK,SAAS,gBAAgB,KAAK,KAAK,SAAS,UAAU,CACnE;AACH,EACD;AAAA,IAED,wBAAS,mBAAmB,MAAM;AAChC,gCAAW,MAAM;AACf,qBAAG,aAAa;AAAA,EAClB,CAAC,OAED,yBAAU,MAAM;AACd,qBAAG,cAAc;AAAA,EACnB,CAAC,OAED,wBAAS,aAAa,MAAM;AAC1B,0BAAG,gDAAgD,YAAY;AAC7D,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,QACjB,WAAW;AAAA,QACX,MAAM;AAAA,MACR;AAEA,MAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAG5C,YAAM,SAAS,MAAO,OAAO,UAAkB,eAAe,MAAS;AACvE,gCAAO,MAAM,EAAE,SAAS;AAAA,IAC1B,CAAC,OAED,kBAAG,+DAA+D,YAAY;AAC5E,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,QACjB,WAAW;AAAA,QACX,MAAM;AAAA,MACR;AAEA,MAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAI5C,YAAM,SAAS,MAAO,OAAO,UAAkB,yBAAyB,MAAS;AACjF,gCAAO,MAAM,EAAE,SAAS;AAAA,IAC1B,CAAC,OAED,kBAAG,mDAAmD,YAAY;AAChE,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,QACjB,WAAW;AAAA,QACX,MAAM;AAAA,MACR;AAEA,MAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAG5C,YAAM,SAAS,MAAO,OAAO;AAAA,QAC3B;AAAA,QACA;AAAA,MACF;AACA,gCAAO,MAAM,EAAE,KAAK,4CAA4C;AAAA,IAClE,CAAC,OAED,kBAAG,mCAAmC,YAAY;AAChD,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,QACjB,WAAW;AAAA,QACX,MAAM;AAAA,MACR;AAEA,MAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAG5C,YAAM,SAAS,MAAO,OAAO;AAAA,QAC3B;AAAA,QACA;AAAA,MACF;AACA,gCAAO,MAAM,EAAE,KAAK,oDAAoD;AAAA,IAC1E,CAAC,OAED,kBAAG,6CAA6C,YAAY;AAC1D,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,QACjB,WAAW;AAAA,QACX,MAAM;AAAA,MACR;AAEA,MAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAG5C,YAAM,SAAS,MAAO,OAAO;AAAA,QAC3B;AAAA,QACA;AAAA,MACF;AACA,gCAAO,MAAM,EAAE,SAAS;AAAA,IAC1B,CAAC;AAAA,EACH,CAAC,OAED,wBAAS,6BAA6B,MAAM;AAC1C,0BAAG,+CAA+C,YAAY;AAC5D,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,QACjB,WAAW;AAAA,QACX,MAAM;AAAA,MACR;AAEA,MAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAG5C,YAAM,SAAS,MAAO,OAAO;AAAA,QAC3B;AAAA,QACA;AAAA,MACF;AACA,gCAAO,MAAM,EAAE,SAAS;AAAA,IAC1B,CAAC,OAED,kBAAG,qDAAqD,YAAY;AAClE,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,QACjB,WAAW;AAAA,QACX,MAAM;AAAA,MACR;AAEA,MAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAG5C,YAAM,SAAS,MAAO,OAAO;AAAA,QAC3B;AAAA,QACA;AAAA,MACF;AACA,gCAAO,MAAM,EAAE,SAAS;AAAA,IAC1B,CAAC,OAED,kBAAG,yCAAyC,YAAY;AACtD,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,QACjB,WAAW;AAAA,QACX,MAAM;AAAA,MACR;AAEA,MAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAG5C,YAAM,SAAS,MAAO,OAAO;AAAA,QAC3B;AAAA,QACA;AAAA,MACF;AACA,gCAAO,MAAM,EAAE,SAAS;AAAA,IAC1B,CAAC,OAED,kBAAG,gDAAgD,YAAY;AAC7D,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,QACjB,WAAW;AAAA,QACX,MAAM;AAAA,MACR;AAEA,MAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAK5C,YAAM,SAAS,MAAO,OAAO;AAAA,QAC3B;AAAA,QACA;AAAA,MACF;AACA,gCAAO,MAAM,EAAE,KAAK,yCAAyC;AAAA,IAC/D,CAAC;AAAA,EACH,CAAC,OAED,wBAAS,QAAQ,MAAM;AACrB,0BAAG,8CAA8C,YAAY;AAC3D,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,QACjB,WAAW;AAAA,QACX,MAAM;AAAA,MACR;AAEA,MAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAG5C,YAAM,cAAc;AAAA,QAClB,cAAc,iBAAG,GAAG;AAAA,MACtB,GAEM,SAAS,MAAO,OAAO,KAAa,KAAK,aAAa,aAAa;AACzE,gCAAO,MAAM,EAAE,SAAS;AAAA,IAC1B,CAAC,OAED,kBAAG,gDAAgD,YAAY;AAC7D,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,QACjB,WAAW;AAAA,QACX,MAAM;AAAA,MACR;AAEA,MAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAG5C,YAAM,cAAc;AAAA,QAClB,cAAc,iBAAG,GAAG;AAAA,MACtB,GAIM,SAAS,MAAO,OAAO,KAAa;AAAA,QACxC;AAAA,QACA;AAAA,MACF;AAEA,gCAAO,MAAM,EAAE,UAAU,gBAAgB,OACzC,sBAAO,MAAM,EAAE,UAAU,yBAAyB,OAClD,sBAAO,MAAM,EAAE,UAAU,UAAU,OACnC,sBAAO,MAAM,EAAE,UAAU,WAAW,OACpC,sBAAO,YAAY,YAAY,EAAE;AAAA,QAC/B;AAAA,MACF;AAAA,IACF,CAAC;AAAA,EACH,CAAC,OAED,wBAAS,mBAAmB,MAAM;AAChC,0BAAG,4BAA4B,YAAY;AACzC,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB;AAC/B,gCAAO,OAAO,IAAI,EAAE,KAAK,eAAe;AAAA,IAC1C,CAAC,OAED,kBAAG,sBAAsB,YAAY;AACnC,YAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB;AAC/B,gCAAO,OAAO,OAAO,EAAE,KAAK,KAAK;AAAA,IACnC,CAAC;AAAA,EACH,CAAC;AACH,CAAC;AAAA,IAED,wBAAS,iCAAiC,MAAM;AAC9C,wBAAG,qCAAqC,YAAY;AAClD,qBAAG,aAAa;AAEhB,UAAM,EAAE,gBAAgB,IAAI,MAAM,OAAO,mBAAmB,GACtD,SAAS,gBAAgB,GAEzB,aAAa;AAAA,MACjB,WAAW;AAAA,MACX,MAAM;AAAA,IACR;AAEA,IAAI,OAAO,kBACP,OAAO,eAAuB,UAAU;AAG5C,UAAM,cAAc;AAAA,MAClB,cAAc,iBAAG,GAAG;AAAA,IACtB,GAQM,aANS,MAAO,OAAO,KAAa;AAAA,MACxC;AAAA,MACA;AAAA,IACF,IAG0B,MAAM,sBAAsB;AAGtD,YAFA,sBAAO,SAAS,EAAE,WAAW,GAEzB,WAAW;AACb,YAAM,SAAS,KAAK,MAAM,UAAU,CAAC,CAAC;AACtC,gCAAO,MAAM,EAAE,eAAe,KAAK,OACnC,sBAAO,MAAM,EAAE,eAAe,OAAO,OACrC,sBAAO,MAAM,EAAE,eAAe,QAAQ,OACtC,sBAAO,MAAM,EAAE,eAAe,aAAa,OAC3C,sBAAO,OAAO,OAAO,GAAG,EAAE,KAAK,QAAQ,OACvC,sBAAO,OAAO,OAAO,KAAK,EAAE,KAAK,QAAQ,OACzC,sBAAO,OAAO,OAAO,MAAM,EAAE,KAAK,QAAQ,OAC1C,sBAAO,OAAO,OAAO,WAAW,EAAE,KAAK,QAAQ;AAAA,IACjD;AAAA,EACF,CAAC;AACH,CAAC;",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
|
@@ -0,0 +1,228 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var __create = Object.create;
|
|
4
|
+
var __defProp = Object.defineProperty;
|
|
5
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
6
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
7
|
+
var __getProtoOf = Object.getPrototypeOf,
|
|
8
|
+
__hasOwnProp = Object.prototype.hasOwnProperty;
|
|
9
|
+
var __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
|
|
11
|
+
get: () => from[key],
|
|
12
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
13
|
+
});
|
|
14
|
+
return to;
|
|
15
|
+
};
|
|
16
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
17
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
18
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
19
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
20
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
21
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
|
|
22
|
+
value: mod,
|
|
23
|
+
enumerable: !0
|
|
24
|
+
}) : target, mod));
|
|
25
|
+
var import_vitest = require("vitest");
|
|
26
|
+
function _type_of(obj) {
|
|
27
|
+
"@swc/helpers - typeof";
|
|
28
|
+
|
|
29
|
+
return obj && typeof Symbol < "u" && obj.constructor === Symbol ? "symbol" : typeof obj;
|
|
30
|
+
}
|
|
31
|
+
import_vitest.vi.mock("node:fs", async function () {
|
|
32
|
+
var actual = await import_vitest.vi.importActual("node:fs");
|
|
33
|
+
return {
|
|
34
|
+
...actual,
|
|
35
|
+
existsSync: import_vitest.vi.fn(function (path) {
|
|
36
|
+
return path.includes("test-image.jpg") || path.includes("hero.png");
|
|
37
|
+
})
|
|
38
|
+
};
|
|
39
|
+
});
|
|
40
|
+
(0, import_vitest.describe)("imageDataPlugin", function () {
|
|
41
|
+
(0, import_vitest.beforeEach)(function () {
|
|
42
|
+
import_vitest.vi.resetModules();
|
|
43
|
+
}), (0, import_vitest.afterEach)(function () {
|
|
44
|
+
import_vitest.vi.clearAllMocks();
|
|
45
|
+
}), (0, import_vitest.describe)("resolveId", function () {
|
|
46
|
+
(0, import_vitest.it)("should return null for non-imagedata imports", async function () {
|
|
47
|
+
var {
|
|
48
|
+
imageDataPlugin
|
|
49
|
+
} = await import("./imageDataPlugin"),
|
|
50
|
+
plugin = imageDataPlugin(),
|
|
51
|
+
mockConfig = {
|
|
52
|
+
publicDir: "/project/public",
|
|
53
|
+
root: "/project"
|
|
54
|
+
};
|
|
55
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
56
|
+
var result = await plugin.resolveId("./image.jpg", void 0);
|
|
57
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
58
|
+
}), (0, import_vitest.it)("should return null for imports with imagedata not as suffix", async function () {
|
|
59
|
+
var {
|
|
60
|
+
imageDataPlugin
|
|
61
|
+
} = await import("./imageDataPlugin"),
|
|
62
|
+
plugin = imageDataPlugin(),
|
|
63
|
+
mockConfig = {
|
|
64
|
+
publicDir: "/project/public",
|
|
65
|
+
root: "/project"
|
|
66
|
+
};
|
|
67
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
68
|
+
var result = await plugin.resolveId("./image?imagedata.jpg", void 0);
|
|
69
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
70
|
+
}), (0, import_vitest.it)("should resolve public dir paths starting with /", async function () {
|
|
71
|
+
var {
|
|
72
|
+
imageDataPlugin
|
|
73
|
+
} = await import("./imageDataPlugin"),
|
|
74
|
+
plugin = imageDataPlugin(),
|
|
75
|
+
mockConfig = {
|
|
76
|
+
publicDir: "/project/public",
|
|
77
|
+
root: "/project"
|
|
78
|
+
};
|
|
79
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
80
|
+
var result = await plugin.resolveId("/test-image.jpg?imagedata", void 0);
|
|
81
|
+
(0, import_vitest.expect)(result).toBe("\0imagedata:/project/public/test-image.jpg");
|
|
82
|
+
}), (0, import_vitest.it)("should resolve relative imports", async function () {
|
|
83
|
+
var {
|
|
84
|
+
imageDataPlugin
|
|
85
|
+
} = await import("./imageDataPlugin"),
|
|
86
|
+
plugin = imageDataPlugin(),
|
|
87
|
+
mockConfig = {
|
|
88
|
+
publicDir: "/project/public",
|
|
89
|
+
root: "/project"
|
|
90
|
+
};
|
|
91
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
92
|
+
var result = await plugin.resolveId("./test-image.jpg?imagedata", "/project/src/components/Hero.tsx");
|
|
93
|
+
(0, import_vitest.expect)(result).toBe("\0imagedata:/project/src/components/test-image.jpg");
|
|
94
|
+
}), (0, import_vitest.it)("should return null for non-existent files", async function () {
|
|
95
|
+
var {
|
|
96
|
+
imageDataPlugin
|
|
97
|
+
} = await import("./imageDataPlugin"),
|
|
98
|
+
plugin = imageDataPlugin(),
|
|
99
|
+
mockConfig = {
|
|
100
|
+
publicDir: "/project/public",
|
|
101
|
+
root: "/project"
|
|
102
|
+
};
|
|
103
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
104
|
+
var result = await plugin.resolveId("/nonexistent.jpg?imagedata", void 0);
|
|
105
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
106
|
+
});
|
|
107
|
+
}), (0, import_vitest.describe)("path traversal prevention", function () {
|
|
108
|
+
(0, import_vitest.it)("should block path traversal from public dir", async function () {
|
|
109
|
+
var {
|
|
110
|
+
imageDataPlugin
|
|
111
|
+
} = await import("./imageDataPlugin"),
|
|
112
|
+
plugin = imageDataPlugin(),
|
|
113
|
+
mockConfig = {
|
|
114
|
+
publicDir: "/project/public",
|
|
115
|
+
root: "/project"
|
|
116
|
+
};
|
|
117
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
118
|
+
var result = await plugin.resolveId("/../../../etc/passwd?imagedata", void 0);
|
|
119
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
120
|
+
}), (0, import_vitest.it)("should block path traversal from relative imports", async function () {
|
|
121
|
+
var {
|
|
122
|
+
imageDataPlugin
|
|
123
|
+
} = await import("./imageDataPlugin"),
|
|
124
|
+
plugin = imageDataPlugin(),
|
|
125
|
+
mockConfig = {
|
|
126
|
+
publicDir: "/project/public",
|
|
127
|
+
root: "/project"
|
|
128
|
+
};
|
|
129
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
130
|
+
var result = await plugin.resolveId("../../../../etc/passwd?imagedata", "/project/src/components/Hero.tsx");
|
|
131
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
132
|
+
}), (0, import_vitest.it)("should block path traversal from root", async function () {
|
|
133
|
+
var {
|
|
134
|
+
imageDataPlugin
|
|
135
|
+
} = await import("./imageDataPlugin"),
|
|
136
|
+
plugin = imageDataPlugin(),
|
|
137
|
+
mockConfig = {
|
|
138
|
+
publicDir: "/project/public",
|
|
139
|
+
root: "/project"
|
|
140
|
+
};
|
|
141
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
142
|
+
var result = await plugin.resolveId("../../../etc/passwd?imagedata", void 0);
|
|
143
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
144
|
+
}), (0, import_vitest.it)("should allow paths within project boundaries", async function () {
|
|
145
|
+
var {
|
|
146
|
+
imageDataPlugin
|
|
147
|
+
} = await import("./imageDataPlugin"),
|
|
148
|
+
plugin = imageDataPlugin(),
|
|
149
|
+
mockConfig = {
|
|
150
|
+
publicDir: "/project/public",
|
|
151
|
+
root: "/project"
|
|
152
|
+
};
|
|
153
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
154
|
+
var result = await plugin.resolveId("../../src/test-image.jpg?imagedata", "/project/src/components/Hero.tsx");
|
|
155
|
+
(0, import_vitest.expect)(result).toBe("\0imagedata:/project/src/test-image.jpg");
|
|
156
|
+
});
|
|
157
|
+
}), (0, import_vitest.describe)("load", function () {
|
|
158
|
+
(0, import_vitest.it)("should return null for non-virtual modules", async function () {
|
|
159
|
+
var {
|
|
160
|
+
imageDataPlugin
|
|
161
|
+
} = await import("./imageDataPlugin"),
|
|
162
|
+
plugin = imageDataPlugin(),
|
|
163
|
+
mockConfig = {
|
|
164
|
+
publicDir: "/project/public",
|
|
165
|
+
root: "/project"
|
|
166
|
+
};
|
|
167
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
168
|
+
var mockContext = {
|
|
169
|
+
addWatchFile: import_vitest.vi.fn()
|
|
170
|
+
},
|
|
171
|
+
result = await plugin.load.call(mockContext, "./image.jpg");
|
|
172
|
+
(0, import_vitest.expect)(result).toBeNull();
|
|
173
|
+
}), (0, import_vitest.it)("should return fallback data when sharp fails", async function () {
|
|
174
|
+
var {
|
|
175
|
+
imageDataPlugin
|
|
176
|
+
} = await import("./imageDataPlugin"),
|
|
177
|
+
plugin = imageDataPlugin(),
|
|
178
|
+
mockConfig = {
|
|
179
|
+
publicDir: "/project/public",
|
|
180
|
+
root: "/project"
|
|
181
|
+
};
|
|
182
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
183
|
+
var mockContext = {
|
|
184
|
+
addWatchFile: import_vitest.vi.fn()
|
|
185
|
+
},
|
|
186
|
+
result = await plugin.load.call(mockContext, "\0imagedata:/project/public/test-image.jpg");
|
|
187
|
+
(0, import_vitest.expect)(result).toContain("export default"), (0, import_vitest.expect)(result).toContain('"src":"/test-image.jpg"'), (0, import_vitest.expect)(result).toContain('"width":'), (0, import_vitest.expect)(result).toContain('"height":'), (0, import_vitest.expect)(mockContext.addWatchFile).toHaveBeenCalledWith("/project/public/test-image.jpg");
|
|
188
|
+
});
|
|
189
|
+
}), (0, import_vitest.describe)("plugin metadata", function () {
|
|
190
|
+
(0, import_vitest.it)("should have correct name", async function () {
|
|
191
|
+
var {
|
|
192
|
+
imageDataPlugin
|
|
193
|
+
} = await import("./imageDataPlugin"),
|
|
194
|
+
plugin = imageDataPlugin();
|
|
195
|
+
(0, import_vitest.expect)(plugin.name).toBe("one:imagedata");
|
|
196
|
+
}), (0, import_vitest.it)("should enforce pre", async function () {
|
|
197
|
+
var {
|
|
198
|
+
imageDataPlugin
|
|
199
|
+
} = await import("./imageDataPlugin"),
|
|
200
|
+
plugin = imageDataPlugin();
|
|
201
|
+
(0, import_vitest.expect)(plugin.enforce).toBe("pre");
|
|
202
|
+
});
|
|
203
|
+
});
|
|
204
|
+
});
|
|
205
|
+
(0, import_vitest.describe)("imageDataPlugin output format", function () {
|
|
206
|
+
(0, import_vitest.it)("should export a valid JSON object", async function () {
|
|
207
|
+
import_vitest.vi.resetModules();
|
|
208
|
+
var {
|
|
209
|
+
imageDataPlugin
|
|
210
|
+
} = await import("./imageDataPlugin"),
|
|
211
|
+
plugin = imageDataPlugin(),
|
|
212
|
+
mockConfig = {
|
|
213
|
+
publicDir: "/project/public",
|
|
214
|
+
root: "/project"
|
|
215
|
+
};
|
|
216
|
+
plugin.configResolved && plugin.configResolved(mockConfig);
|
|
217
|
+
var mockContext = {
|
|
218
|
+
addWatchFile: import_vitest.vi.fn()
|
|
219
|
+
},
|
|
220
|
+
result = await plugin.load.call(mockContext, "\0imagedata:/project/public/test-image.jpg"),
|
|
221
|
+
jsonMatch = result?.match(/export default (.+)$/);
|
|
222
|
+
if ((0, import_vitest.expect)(jsonMatch).toBeTruthy(), jsonMatch) {
|
|
223
|
+
var parsed = JSON.parse(jsonMatch[1]);
|
|
224
|
+
(0, import_vitest.expect)(parsed).toHaveProperty("src"), (0, import_vitest.expect)(parsed).toHaveProperty("width"), (0, import_vitest.expect)(parsed).toHaveProperty("height"), (0, import_vitest.expect)(parsed).toHaveProperty("blurDataURL"), (0, import_vitest.expect)(_type_of(parsed.src)).toBe("string"), (0, import_vitest.expect)(_type_of(parsed.width)).toBe("number"), (0, import_vitest.expect)(_type_of(parsed.height)).toBe("number"), (0, import_vitest.expect)(_type_of(parsed.blurDataURL)).toBe("string");
|
|
225
|
+
}
|
|
226
|
+
});
|
|
227
|
+
});
|
|
228
|
+
//# sourceMappingURL=imageDataPlugin.test.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["import_vitest","require","_type_of","obj","Symbol","constructor","vi","mock","actual","importActual","existsSync","fn","path","includes","describe","beforeEach","resetModules","afterEach","clearAllMocks","it","imageDataPlugin","plugin","mockConfig","publicDir","root","configResolved","result","resolveId","expect","toBeNull","toBe","mockContext","addWatchFile","load","call","toContain","toHaveBeenCalledWith","name","enforce","jsonMatch","match","toBeTruthy","parsed","JSON","parse","toHaveProperty","src","width","height","blurDataURL"],"sources":["../../../../src/vite/plugins/imageDataPlugin.test.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|