one 1.2.52 → 1.2.54
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/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 -0
- package/dist/cjs/vercel/build/config/vc-build-output-config-base.js +2 -0
- 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 -0
- 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 +107 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.js +85 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.js.map +6 -0
- package/dist/cjs/vite/plugins/imageDataPlugin.native.js +115 -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/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 -0
- 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 -0
- 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 -0
- 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 +62 -0
- package/dist/esm/vite/plugins/imageDataPlugin.js.map +6 -0
- package/dist/esm/vite/plugins/imageDataPlugin.mjs +73 -0
- package/dist/esm/vite/plugins/imageDataPlugin.mjs.map +1 -0
- package/dist/esm/vite/plugins/imageDataPlugin.native.js +78 -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 +14 -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/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 -0
- 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 +120 -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/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.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,85 @@
|
|
|
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 __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: !0 });
|
|
9
|
+
}, __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from == "object" || typeof from == "function")
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
!__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
13
|
+
return to;
|
|
14
|
+
};
|
|
15
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
16
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
17
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
18
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
19
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
20
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: !0 }) : target,
|
|
21
|
+
mod
|
|
22
|
+
)), __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
|
|
23
|
+
var imageDataPlugin_exports = {};
|
|
24
|
+
__export(imageDataPlugin_exports, {
|
|
25
|
+
imageDataPlugin: () => imageDataPlugin
|
|
26
|
+
});
|
|
27
|
+
module.exports = __toCommonJS(imageDataPlugin_exports);
|
|
28
|
+
var import_node_fs = require("node:fs"), import_node_path = require("node:path");
|
|
29
|
+
const IMAGEDATA_SUFFIX = "?imagedata", VIRTUAL_PREFIX = "\0imagedata:";
|
|
30
|
+
let sharpWarned = !1;
|
|
31
|
+
async function getSharp() {
|
|
32
|
+
try {
|
|
33
|
+
const sharpModule = await import("sharp");
|
|
34
|
+
return sharpModule.default || sharpModule;
|
|
35
|
+
} catch {
|
|
36
|
+
return sharpWarned || (sharpWarned = !0, console.warn(
|
|
37
|
+
`
|
|
38
|
+
[one] To use ?imagedata imports, install sharp:
|
|
39
|
+
|
|
40
|
+
npm install sharp
|
|
41
|
+
`
|
|
42
|
+
)), null;
|
|
43
|
+
}
|
|
44
|
+
}
|
|
45
|
+
function imageDataPlugin() {
|
|
46
|
+
let publicDir, root;
|
|
47
|
+
function getSrcPath(filePath) {
|
|
48
|
+
return filePath.startsWith(publicDir) ? "/" + (0, import_node_path.relative)(publicDir, filePath) : "/" + (0, import_node_path.relative)(root, filePath);
|
|
49
|
+
}
|
|
50
|
+
function isPathWithinBounds(filePath, allowedDir) {
|
|
51
|
+
const resolved = (0, import_node_path.resolve)(filePath), allowed = (0, import_node_path.resolve)(allowedDir);
|
|
52
|
+
return resolved.startsWith(allowed + "/") || resolved === allowed;
|
|
53
|
+
}
|
|
54
|
+
function createImageDataExport(src, width = 0, height = 0, blurDataURL = "") {
|
|
55
|
+
return `export default ${JSON.stringify({ src, width, height, blurDataURL })}`;
|
|
56
|
+
}
|
|
57
|
+
return {
|
|
58
|
+
name: "one:imagedata",
|
|
59
|
+
enforce: "pre",
|
|
60
|
+
configResolved(resolvedConfig) {
|
|
61
|
+
publicDir = resolvedConfig.publicDir, root = resolvedConfig.root;
|
|
62
|
+
},
|
|
63
|
+
async resolveId(id, importer) {
|
|
64
|
+
if (!id.endsWith(IMAGEDATA_SUFFIX)) return null;
|
|
65
|
+
const cleanId = id.slice(0, -IMAGEDATA_SUFFIX.length);
|
|
66
|
+
let filePath, allowedDir;
|
|
67
|
+
return cleanId.startsWith("/") ? (filePath = (0, import_node_path.resolve)(publicDir, cleanId.slice(1)), allowedDir = publicDir) : importer ? (filePath = (0, import_node_path.resolve)((0, import_node_path.dirname)(importer.replace(VIRTUAL_PREFIX, "")), cleanId), allowedDir = root) : (filePath = (0, import_node_path.resolve)(root, cleanId), allowedDir = root), isPathWithinBounds(filePath, allowedDir) ? (0, import_node_fs.existsSync)(filePath) ? VIRTUAL_PREFIX + filePath : (console.warn(`[one] ?imagedata: File not found: ${filePath}`), null) : (console.warn(`[one] ?imagedata: Path traversal blocked: ${cleanId}`), null);
|
|
68
|
+
},
|
|
69
|
+
async load(id) {
|
|
70
|
+
if (!id.startsWith(VIRTUAL_PREFIX)) return null;
|
|
71
|
+
const filePath = id.slice(VIRTUAL_PREFIX.length), src = getSrcPath(filePath);
|
|
72
|
+
this.addWatchFile(filePath);
|
|
73
|
+
const sharp = await getSharp();
|
|
74
|
+
if (!sharp)
|
|
75
|
+
return createImageDataExport(src);
|
|
76
|
+
try {
|
|
77
|
+
const image = sharp(filePath), metadata = await image.metadata(), { width = 0, height = 0 } = metadata, blurDataURL = `data:image/jpeg;base64,${(await image.resize(10).blur(1).jpeg({ quality: 40 }).toBuffer()).toString("base64")}`;
|
|
78
|
+
return createImageDataExport(src, width, height, blurDataURL);
|
|
79
|
+
} catch (e) {
|
|
80
|
+
return console.warn(`[one] ?imagedata: Failed to process ${filePath}:`, e), createImageDataExport(src);
|
|
81
|
+
}
|
|
82
|
+
}
|
|
83
|
+
};
|
|
84
|
+
}
|
|
85
|
+
//# sourceMappingURL=imageDataPlugin.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../../../src/vite/plugins/imageDataPlugin.ts"],
|
|
4
|
+
"mappings": ";;;;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,qBAA2B,oBAC3B,mBAA2C;AAG3C,MAAM,mBAAmB,cACnB,iBAAiB;AAEvB,IAAI,cAAc;AAElB,eAAe,WAAmD;AAChE,MAAI;AAEF,UAAM,cAAc,MAAM,OAAO,OAAO;AACxC,WAAQ,YAAoB,WAAW;AAAA,EACzC,QAAY;AACV,WAAK,gBACH,cAAc,IACd,QAAQ;AAAA,MACN;AAAA;AAAA;AAAA;AAAA;AAAA,IACF,IAEK;AAAA,EACT;AACF;AAEO,SAAS,kBAA0B;AACxC,MAAI,WACA;AAEJ,WAAS,WAAW,UAA0B;AAC5C,WAAO,SAAS,WAAW,SAAS,IAChC,UAAM,2BAAS,WAAW,QAAQ,IAClC,UAAM,2BAAS,MAAM,QAAQ;AAAA,EACnC;AAEA,WAAS,mBAAmB,UAAkB,YAA6B;AACzE,UAAM,eAAW,0BAAQ,QAAQ,GAC3B,cAAU,0BAAQ,UAAU;AAClC,WAAO,SAAS,WAAW,UAAU,GAAG,KAAK,aAAa;AAAA,EAC5D;AAEA,WAAS,sBAAsB,KAAa,QAAQ,GAAG,SAAS,GAAG,cAAc,IAAI;AACnF,WAAO,kBAAkB,KAAK,UAAU,EAAE,KAAK,OAAO,QAAQ,YAAY,CAAC,CAAC;AAAA,EAC9E;AAEA,SAAO;AAAA,IACL,MAAM;AAAA,IACN,SAAS;AAAA,IAET,eAAe,gBAAgC;AAC7C,kBAAY,eAAe,WAC3B,OAAO,eAAe;AAAA,IACxB;AAAA,IAEA,MAAM,UAAU,IAAI,UAAU;AAC5B,UAAI,CAAC,GAAG,SAAS,gBAAgB,EAAG,QAAO;AAE3C,YAAM,UAAU,GAAG,MAAM,GAAG,CAAC,iBAAiB,MAAM;AACpD,UAAI,UACA;AAgBJ,aAbI,QAAQ,WAAW,GAAG,KACxB,eAAW,0BAAQ,WAAW,QAAQ,MAAM,CAAC,CAAC,GAC9C,aAAa,aACJ,YAET,eAAW,8BAAQ,0BAAQ,SAAS,QAAQ,gBAAgB,EAAE,CAAC,GAAG,OAAO,GACzE,aAAa,SAEb,eAAW,0BAAQ,MAAM,OAAO,GAChC,aAAa,OAIV,mBAAmB,UAAU,UAAU,QAKvC,2BAAW,QAAQ,IAKjB,iBAAiB,YAJtB,QAAQ,KAAK,qCAAqC,QAAQ,EAAE,GACrD,SANP,QAAQ,KAAK,6CAA6C,OAAO,EAAE,GAC5D;AAAA,IASX;AAAA,IAEA,MAAM,KAAK,IAAI;AACb,UAAI,CAAC,GAAG,WAAW,cAAc,EAAG,QAAO;AAE3C,YAAM,WAAW,GAAG,MAAM,eAAe,MAAM,GACzC,MAAM,WAAW,QAAQ;AAG/B,WAAK,aAAa,QAAQ;AAE1B,YAAM,QAAQ,MAAM,SAAS;AAE7B,UAAI,CAAC;AACH,eAAO,sBAAsB,GAAG;AAGlC,UAAI;AACF,cAAM,QAAQ,MAAM,QAAQ,GACtB,WAAW,MAAM,MAAM,SAAS,GAChC,EAAE,QAAQ,GAAG,SAAS,EAAE,IAAI,UAI5B,cAAc,2BADD,MAAM,MAAM,OAAO,EAAE,EAAE,KAAK,CAAC,EAAE,KAAK,EAAE,SAAS,GAAG,CAAC,EAAE,SAAS,GACxB,SAAS,QAAQ,CAAC;AAE3E,eAAO,sBAAsB,KAAK,OAAO,QAAQ,WAAW;AAAA,MAC9D,SAAS,GAAG;AACV,uBAAQ,KAAK,uCAAuC,QAAQ,KAAK,CAAC,GAC3D,sBAAsB,GAAG;AAAA,MAClC;AAAA,IACF;AAAA,EACF;AACF;",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|
|
@@ -0,0 +1,115 @@
|
|
|
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 __export = (target, all) => {
|
|
10
|
+
for (var name in all) __defProp(target, name, {
|
|
11
|
+
get: all[name],
|
|
12
|
+
enumerable: !0
|
|
13
|
+
});
|
|
14
|
+
},
|
|
15
|
+
__copyProps = (to, from, except, desc) => {
|
|
16
|
+
if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
|
|
17
|
+
get: () => from[key],
|
|
18
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
19
|
+
});
|
|
20
|
+
return to;
|
|
21
|
+
};
|
|
22
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
23
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
24
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
25
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
26
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
27
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
|
|
28
|
+
value: mod,
|
|
29
|
+
enumerable: !0
|
|
30
|
+
}) : target, mod)),
|
|
31
|
+
__toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
|
|
32
|
+
value: !0
|
|
33
|
+
}), mod);
|
|
34
|
+
var imageDataPlugin_exports = {};
|
|
35
|
+
__export(imageDataPlugin_exports, {
|
|
36
|
+
imageDataPlugin: () => imageDataPlugin
|
|
37
|
+
});
|
|
38
|
+
module.exports = __toCommonJS(imageDataPlugin_exports);
|
|
39
|
+
var import_fs = require("fs"),
|
|
40
|
+
import_path = require("path"),
|
|
41
|
+
IMAGEDATA_SUFFIX = "?imagedata",
|
|
42
|
+
VIRTUAL_PREFIX = "\0imagedata:",
|
|
43
|
+
sharpWarned = !1;
|
|
44
|
+
async function getSharp() {
|
|
45
|
+
try {
|
|
46
|
+
var sharpModule = await import("sharp");
|
|
47
|
+
return sharpModule.default || sharpModule;
|
|
48
|
+
} catch {
|
|
49
|
+
return sharpWarned || (sharpWarned = !0, console.warn(`
|
|
50
|
+
[one] To use ?imagedata imports, install sharp:
|
|
51
|
+
|
|
52
|
+
npm install sharp
|
|
53
|
+
`)), null;
|
|
54
|
+
}
|
|
55
|
+
}
|
|
56
|
+
function imageDataPlugin() {
|
|
57
|
+
var publicDir, root;
|
|
58
|
+
function getSrcPath(filePath) {
|
|
59
|
+
return filePath.startsWith(publicDir) ? "/" + (0, import_path.relative)(publicDir, filePath) : "/" + (0, import_path.relative)(root, filePath);
|
|
60
|
+
}
|
|
61
|
+
function isPathWithinBounds(filePath, allowedDir) {
|
|
62
|
+
var resolved = (0, import_path.resolve)(filePath),
|
|
63
|
+
allowed = (0, import_path.resolve)(allowedDir);
|
|
64
|
+
return resolved.startsWith(allowed + "/") || resolved === allowed;
|
|
65
|
+
}
|
|
66
|
+
function createImageDataExport(src) {
|
|
67
|
+
var width = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : 0,
|
|
68
|
+
height = arguments.length > 2 && arguments[2] !== void 0 ? arguments[2] : 0,
|
|
69
|
+
blurDataURL = arguments.length > 3 && arguments[3] !== void 0 ? arguments[3] : "";
|
|
70
|
+
return `export default ${JSON.stringify({
|
|
71
|
+
src,
|
|
72
|
+
width,
|
|
73
|
+
height,
|
|
74
|
+
blurDataURL
|
|
75
|
+
})}`;
|
|
76
|
+
}
|
|
77
|
+
return {
|
|
78
|
+
name: "one:imagedata",
|
|
79
|
+
enforce: "pre",
|
|
80
|
+
configResolved(resolvedConfig) {
|
|
81
|
+
publicDir = resolvedConfig.publicDir, root = resolvedConfig.root;
|
|
82
|
+
},
|
|
83
|
+
async resolveId(id, importer) {
|
|
84
|
+
if (!id.endsWith(IMAGEDATA_SUFFIX)) return null;
|
|
85
|
+
var cleanId = id.slice(0, -IMAGEDATA_SUFFIX.length),
|
|
86
|
+
filePath,
|
|
87
|
+
allowedDir;
|
|
88
|
+
return cleanId.startsWith("/") ? (filePath = (0, import_path.resolve)(publicDir, cleanId.slice(1)), allowedDir = publicDir) : importer ? (filePath = (0, import_path.resolve)((0, import_path.dirname)(importer.replace(VIRTUAL_PREFIX, "")), cleanId), allowedDir = root) : (filePath = (0, import_path.resolve)(root, cleanId), allowedDir = root), isPathWithinBounds(filePath, allowedDir) ? (0, import_fs.existsSync)(filePath) ? VIRTUAL_PREFIX + filePath : (console.warn(`[one] ?imagedata: File not found: ${filePath}`), null) : (console.warn(`[one] ?imagedata: Path traversal blocked: ${cleanId}`), null);
|
|
89
|
+
},
|
|
90
|
+
async load(id) {
|
|
91
|
+
if (!id.startsWith(VIRTUAL_PREFIX)) return null;
|
|
92
|
+
var filePath = id.slice(VIRTUAL_PREFIX.length),
|
|
93
|
+
src = getSrcPath(filePath);
|
|
94
|
+
this.addWatchFile(filePath);
|
|
95
|
+
var sharp = await getSharp();
|
|
96
|
+
if (!sharp) return createImageDataExport(src);
|
|
97
|
+
try {
|
|
98
|
+
var image = sharp(filePath),
|
|
99
|
+
metadata = await image.metadata(),
|
|
100
|
+
{
|
|
101
|
+
width = 0,
|
|
102
|
+
height = 0
|
|
103
|
+
} = metadata,
|
|
104
|
+
blurBuffer = await image.resize(10).blur(1).jpeg({
|
|
105
|
+
quality: 40
|
|
106
|
+
}).toBuffer(),
|
|
107
|
+
blurDataURL = `data:image/jpeg;base64,${blurBuffer.toString("base64")}`;
|
|
108
|
+
return createImageDataExport(src, width, height, blurDataURL);
|
|
109
|
+
} catch (e) {
|
|
110
|
+
return console.warn(`[one] ?imagedata: Failed to process ${filePath}:`, e), createImageDataExport(src);
|
|
111
|
+
}
|
|
112
|
+
}
|
|
113
|
+
};
|
|
114
|
+
}
|
|
115
|
+
//# sourceMappingURL=imageDataPlugin.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["__toCommonJS","mod","__copyProps","__defProp","value","imageDataPlugin_exports","__export","imageDataPlugin","module","exports","import_fs","require","import_path","IMAGEDATA_SUFFIX","VIRTUAL_PREFIX","sharpWarned","getSharp","sharpModule","default","console","warn","publicDir","root","getSrcPath","filePath","startsWith","relative","isPathWithinBounds","allowedDir","resolved","resolve","allowed","createImageDataExport","src","width","arguments","length","height","blurDataURL","JSON","stringify","name","enforce","configResolved","resolvedConfig","resolveId","id","importer","endsWith","cleanId","slice","dirname","replace","existsSync","load","addWatchFile","sharp","image","metadata","blurBuffer","resize","blur","jpeg","quality","toBuffer","toString","e"],"sources":["../../../../src/vite/plugins/imageDataPlugin.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -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": "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",
|
|
5
|
+
"names": []
|
|
6
|
+
}
|