1
0

vite.config.ts.timestamp-1678272846346.mjs 30 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343
  1. // vite.config.ts
  2. import { defineConfig } from "file:///Users/alvarosabu/Projects/tres/node_modules/.pnpm/vite@4.1.4/node_modules/vite/dist/node/index.js";
  3. import vue from "file:///Users/alvarosabu/Projects/tres/node_modules/.pnpm/@vitejs+plugin-vue@4.0.0_vite@4.1.4/node_modules/@vitejs/plugin-vue/dist/index.mjs";
  4. import banner from "file:///Users/alvarosabu/Projects/tres/node_modules/.pnpm/vite-plugin-banner@0.7.0/node_modules/vite-plugin-banner/dist/index.mjs";
  5. import Inspect from "file:///Users/alvarosabu/Projects/tres/node_modules/.pnpm/vite-plugin-inspect@0.7.15_vite@4.1.4/node_modules/vite-plugin-inspect/dist/index.mjs";
  6. import dts from "file:///Users/alvarosabu/Projects/tres/node_modules/.pnpm/vite-plugin-dts@2.0.0-beta.1_vite@4.1.4/node_modules/vite-plugin-dts/dist/index.mjs";
  7. // plugins/vite-plugin-tres.ts
  8. import { createUnplugin } from "file:///Users/alvarosabu/Projects/tres/node_modules/.pnpm/unplugin@1.1.0/node_modules/unplugin/dist/index.mjs";
  9. import * as THREE from "file:///Users/alvarosabu/Projects/tres/node_modules/.pnpm/three@0.150.1/node_modules/three/build/three.module.js";
  10. import fs from "fs";
  11. import { join } from "file:///Users/alvarosabu/Projects/tres/node_modules/.pnpm/pathe@1.1.0/node_modules/pathe/dist/index.mjs";
  12. var unplugin = createUnplugin(() => {
  13. return {
  14. name: "unplugin-tres",
  15. buildStart() {
  16. console.log("\u2728 Magically generating components...");
  17. const outputDir = join(".tres", "components");
  18. if (!fs.existsSync(outputDir)) {
  19. fs.mkdirSync(outputDir, { recursive: true });
  20. }
  21. let indexTemplate = "";
  22. for (const key in THREE) {
  23. const value = THREE[key];
  24. if (key === "Scene")
  25. continue;
  26. if (typeof value === "function" && /^\s*class\s+/.test(value.toString())) {
  27. const outputFilePath = join(outputDir, `${key}.ts`);
  28. const template = `
  29. import { defineComponent } from 'vue';
  30. import { ${key}, Color, Vector3 } from 'three';
  31. export type SizeFlexibleParams =
  32. | number[]
  33. | {
  34. width: number
  35. height: number
  36. }
  37. export interface Vector2PropInterface {
  38. x?: number
  39. y?: number
  40. width?: number
  41. height?: number
  42. }
  43. export interface Vector3PropInterface extends Vector2PropInterface {
  44. z?: number
  45. }
  46. export type VectorFlexibleParams = THREE.Vector3 | number[] | Vector3PropInterface | number
  47. let ${key}Instance: ${key};
  48. let instanceProps: string[] = [];
  49. export function normalizeVectorFlexibleParam(value: VectorFlexibleParams): Array<number> {
  50. if (typeof value === 'number') {
  51. return [value, value, value]
  52. }
  53. if (value instanceof Vector3) {
  54. return [value.x, value.y, value.z]
  55. }
  56. return value as Array<number>
  57. }
  58. export function normalizeColor(value: Color | Array<number> | string | number) {
  59. if (value instanceof Color) {
  60. return value
  61. }
  62. if (Array.isArray(value)) {
  63. return new Color(...value)
  64. }
  65. return new Color(value)
  66. }
  67. /**
  68. * Tres${key}Props
  69. * @type {Partial<${key}> & {parentInstance?: ${key}}}
  70. * @memberof Tres${key}
  71. * @description This is a partial of the ${key} class, with the parentInstance property added.
  72. *
  73. **/
  74. export type Tres${key}Props = Partial<${key}> & {
  75. parentInstance?: ${key},
  76. /**
  77. *
  78. * Array of arguments to pass to the ${key} constructor
  79. *
  80. * @type {Array<any>}
  81. * @memberof Tres${key}Props
  82. * @see https://threejs.org/docs/?q=${key}
  83. *
  84. **/
  85. args?: Array<any>,
  86. /**
  87. *
  88. * Object's local position
  89. *
  90. * @type {VectorFlexibleParams}
  91. * @memberof Tres${key}Props
  92. **/
  93. position?: VectorFlexibleParams
  94. }
  95. try {
  96. ${key}Instance = new ${key}();
  97. instanceProps = [...Object.keys(${key}Instance)]
  98. } catch (e) {
  99. }
  100. export const Tres${key} = /* #__PURE__ */ defineComponent<Tres${key}Props>({
  101. name: 'Tres${key}',
  102. props: ['parentInstance', 'args', ...instanceProps] as unknown as undefined,
  103. setup(props, { slots, expose, ...rest }) {
  104. /* const cleanedProps = Object.keys(props).reduce((acc, key) => {
  105. if (props[key] !== undefined && key !== 'parentInstance') {
  106. if( ${key}Instance[key] instanceof Color) {
  107. acc[key] = normalizeColor(props[key])
  108. } else if ( ${key}Instance[key] instanceof Vector3) {
  109. acc[key] = normalizeVectorFlexibleParam(props[key])
  110. } else {
  111. acc[key] = props[key]
  112. }
  113. }
  114. return acc
  115. }, {}) */
  116. if(props.args) {
  117. ${key}Instance = new ${key}(...props.args);
  118. } else {
  119. ${key}Instance = new ${key}();
  120. }
  121. console.log('instance', {${key}Instance, props, slots: slots.default ? slots.default() : null, rest, type: ${key}.name})
  122. expose({${key}Instance})
  123. function append(parent, child) {
  124. const regex = /[A-Z][a-z]+/g
  125. const propName = child.type.match(regex).pop().toLowerCase()
  126. if (parent[propName]) {
  127. parent[propName] = child
  128. }
  129. }
  130. if (props.parentInstance) {
  131. append(props.parentInstance, ${key}Instance)
  132. }
  133. const preparedSlots = slots.default
  134. // eslint-disable-next-line max-len
  135. ? slots.default().map((slot) => { slot.props = {
  136. ...slot.props,
  137. parentInstance: ${key}Instance };
  138. return slot;
  139. })
  140. : null
  141. return () => {
  142. return preparedSlots;
  143. };
  144. },
  145. });
  146. export default Tres${key};
  147. `;
  148. indexTemplate += `export { default as Tres${key} } from './${key}'
  149. `;
  150. fs.writeFileSync(outputFilePath, template);
  151. }
  152. fs.writeFileSync(join(outputDir, `index.ts`), indexTemplate);
  153. }
  154. }
  155. };
  156. });
  157. var ViteTresPlugin = unplugin.vite;
  158. // vite.config.ts
  159. import { resolve } from "file:///Users/alvarosabu/Projects/tres/node_modules/.pnpm/pathe@1.1.0/node_modules/pathe/dist/index.mjs";
  160. import { lightGreen, yellow, gray, bold } from "file:///Users/alvarosabu/Projects/tres/node_modules/.pnpm/kolorist@1.7.0/node_modules/kolorist/dist/esm/index.mjs";
  161. // package.json
  162. var package_default = {
  163. name: "@tresjs/core",
  164. description: "Declarative ThreeJS using Vue Components",
  165. version: "1.8.1",
  166. type: "module",
  167. author: "Alvaro Saburido <hola@alvarosaburido.dev> (https://github.com/alvarosabu/)",
  168. files: [
  169. "dist"
  170. ],
  171. license: "MIT",
  172. main: "./dist/tres.umd.cjs",
  173. module: "./dist/tres.js",
  174. types: "./dist/index.d.ts",
  175. exports: {
  176. ".": {
  177. import: "./dist/tres.js",
  178. require: "./dist/tres.umd.cjs"
  179. },
  180. "./types": {
  181. require: "./dist/index.d.ts",
  182. import: "./dist/index.d.ts"
  183. },
  184. "./styles": "./dist/style.css",
  185. "./*": "./dist/tres.js"
  186. },
  187. publishConfig: {
  188. access: "public"
  189. },
  190. keywords: [
  191. "vue",
  192. "3d",
  193. "threejs",
  194. "three",
  195. "threejs-vue"
  196. ],
  197. scripts: {
  198. dev: "vite",
  199. build: "vite build",
  200. preview: "vite preview",
  201. test: "vitest",
  202. "test:ci": "vitest run",
  203. "test:ui": "vitest --ui",
  204. coverage: "vitest run --coverage",
  205. lint: "eslint . --ext .js,.jsx,.ts,.tsx,.vue",
  206. changelog: "conventional-changelog -p angular -i CHANGELOG.md -s"
  207. },
  208. peerDependencies: {
  209. three: "latest",
  210. vue: "^3.2.47"
  211. },
  212. dependencies: {
  213. "@alvarosabu/utils": "^2.3.0",
  214. "@vueuse/core": "^9.13.0"
  215. },
  216. devDependencies: {
  217. "@tresjs/cientos": "workspace:^1.8.0",
  218. "@types/three": "latest",
  219. "@vitejs/plugin-vue": "^4.0.0",
  220. "@vitest/coverage-c8": "^0.28.5",
  221. "@vitest/ui": "^0.28.5",
  222. "@vue/test-utils": "^2.3.0",
  223. "happy-dom": "^8.7.1",
  224. jsdom: "^21.1.0",
  225. kolorist: "^1.7.0",
  226. pathe: "^1.1.0",
  227. "rollup-plugin-analyzer": "^4.0.0",
  228. "rollup-plugin-visualizer": "^5.9.0",
  229. three: "latest",
  230. "unplugin-vue-components": "^0.24.1",
  231. vite: "^4.1.4",
  232. "vite-plugin-banner": "^0.7.0",
  233. "vite-plugin-dts": "2.0.0-beta.1",
  234. "vite-plugin-glsl": "^1.1.2",
  235. "vite-plugin-inspect": "^0.7.15",
  236. "vite-plugin-require-transform": "^1.0.9",
  237. vitest: "^0.28.5",
  238. "vue-demi": "^0.13.11"
  239. }
  240. };
  241. // vite.config.ts
  242. var __vite_injected_original_dirname = "/Users/alvarosabu/Projects/tres/packages/tres";
  243. console.log(`${lightGreen("\u25B2")} ${gray("\u25A0")} ${yellow("\u25CF")} ${bold("Tres")} v${package_default.version}`);
  244. var vite_config_default = defineConfig({
  245. server: {
  246. port: 5174
  247. },
  248. resolve: {
  249. alias: {
  250. "/@": resolve(__vite_injected_original_dirname, "./src")
  251. },
  252. dedupe: ["@tresjs/cientos"]
  253. },
  254. plugins: [
  255. vue({
  256. isProduction: false
  257. }),
  258. ViteTresPlugin(),
  259. dts({
  260. insertTypesEntry: true
  261. }),
  262. banner({
  263. content: `/**
  264. * name: ${package_default.name}
  265. * version: v${package_default.version}
  266. * (c) ${new Date().getFullYear()}
  267. * description: ${package_default.description}
  268. * author: ${package_default.author}
  269. */`
  270. }),
  271. Inspect()
  272. ],
  273. test: {
  274. environment: "jsdom",
  275. globals: true,
  276. threads: false,
  277. alias: {
  278. "/@": resolve(__vite_injected_original_dirname, "./src")
  279. }
  280. },
  281. build: {
  282. lib: {
  283. entry: resolve(__vite_injected_original_dirname, "src/index.ts"),
  284. name: "tres",
  285. fileName: "tres"
  286. },
  287. watch: {
  288. include: [resolve(__vite_injected_original_dirname, "src")]
  289. },
  290. copyPublicDir: false,
  291. rollupOptions: {
  292. plugins: [
  293. /* analyze(), */
  294. /* visualizer({
  295. open: true,
  296. gzipSize: true,
  297. brotliSize: true,
  298. }), */
  299. ],
  300. external: ["vue", "@vueuse/core", "three"],
  301. output: {
  302. exports: "named",
  303. // Provide global variables to use in the UMD build
  304. // for externalized deps
  305. globals: {
  306. vue: "Vue",
  307. "@vueuse/core": "VueUseCore",
  308. three: "Three"
  309. }
  310. }
  311. }
  312. },
  313. optimizeDeps: {
  314. exclude: ["vue", "three"]
  315. }
  316. });
  317. export {
  318. vite_config_default as default
  319. };
  320. //# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.ts", "plugins/vite-plugin-tres.ts", "package.json"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"/Users/alvarosabu/Projects/tres/packages/tres\";const __vite_injected_original_filename = \"/Users/alvarosabu/Projects/tres/packages/tres/vite.config.ts\";const __vite_injected_original_import_meta_url = \"file:///Users/alvarosabu/Projects/tres/packages/tres/vite.config.ts\";/// <reference types=\"vitest\" />\n\nimport { defineConfig } from 'vite'\n\nimport vue from '@vitejs/plugin-vue'\nimport banner from 'vite-plugin-banner'\nimport Inspect from 'vite-plugin-inspect'\n\nimport dts from 'vite-plugin-dts'\nimport Components from 'unplugin-vue-components/vite'\n\nimport { ViteTresPlugin } from './plugins/vite-plugin-tres'\nimport analyze from 'rollup-plugin-analyzer'\n/* import { visualizer } from 'rollup-plugin-visualizer' */\nimport { resolve } from 'pathe'\n\nimport { lightGreen, yellow, gray, bold } from 'kolorist'\n\nimport pkg from './package.json'\n\n// eslint-disable-next-line no-console\nconsole.log(`${lightGreen('\u25B2')} ${gray('\u25A0')} ${yellow('\u25CF')} ${bold('Tres')} v${pkg.version}`)\n// https://vitejs.dev/config/\nexport default defineConfig({\n  server: {\n    port: 5174,\n  },\n  resolve: {\n    alias: {\n      '/@': resolve(__dirname, './src'),\n    },\n    dedupe: ['@tresjs/cientos'],\n  },\n  plugins: [\n    vue({\n      isProduction: false,\n    }),\n    ViteTresPlugin(),\n    dts({\n      insertTypesEntry: true,\n    }),\n    banner({\n      content: `/**\\n * name: ${pkg.name}\\n * version: v${\n        pkg.version\n      }\\n * (c) ${new Date().getFullYear()}\\n * description: ${pkg.description}\\n * author: ${pkg.author}\\n */`,\n    }),\n    Inspect(),\n  ],\n  test: {\n    environment: 'jsdom',\n    globals: true,\n    threads: false,\n    alias: {\n      '/@': resolve(__dirname, './src'),\n    },\n  },\n  build: {\n    lib: {\n      entry: resolve(__dirname, 'src/index.ts'),\n      name: 'tres',\n      fileName: 'tres',\n    },\n    watch: {\n      include: [resolve(__dirname, 'src')],\n    },\n    copyPublicDir: false,\n    rollupOptions: {\n      plugins: [\n        /* analyze(), */\n        /*    visualizer({\n          open: true,\n          gzipSize: true,\n          brotliSize: true,\n        }), */\n      ],\n\n      external: ['vue', '@vueuse/core', 'three'],\n      output: {\n        exports: 'named',\n        // Provide global variables to use in the UMD build\n        // for externalized deps\n        globals: {\n          vue: 'Vue',\n          '@vueuse/core': 'VueUseCore',\n          three: 'Three',\n        },\n      },\n    },\n  },\n  optimizeDeps: {\n    exclude: ['vue', 'three'],\n  },\n})\n", "const __vite_injected_original_dirname = \"/Users/alvarosabu/Projects/tres/packages/tres/plugins\";const __vite_injected_original_filename = \"/Users/alvarosabu/Projects/tres/packages/tres/plugins/vite-plugin-tres.ts\";const __vite_injected_original_import_meta_url = \"file:///Users/alvarosabu/Projects/tres/packages/tres/plugins/vite-plugin-tres.ts\";import { createUnplugin } from 'unplugin'\nimport * as THREE from 'three'\n\nimport fs from 'fs'\nimport { join } from 'pathe'\n\nexport const unplugin = createUnplugin(() => {\n  return {\n    name: 'unplugin-tres',\n    buildStart() {\n      console.log('\u2728 Magically generating components...')\n      const outputDir = join('.tres', 'components')\n\n      if (!fs.existsSync(outputDir)) {\n        fs.mkdirSync(outputDir, { recursive: true })\n      }\n\n      let indexTemplate = ''\n\n      for (const key in THREE) {\n        const value = (THREE as any)[key]\n        if (key === 'Scene') continue\n        if (typeof value === 'function' && /^\\s*class\\s+/.test(value.toString())) {\n          const outputFilePath = join(outputDir, `${key}.ts`)\n\n          const template = `\n      import { defineComponent } from 'vue';\n      import { ${key}, Color, Vector3 } from 'three';\n\n      export type SizeFlexibleParams =\n        | number[]\n        | {\n            width: number\n            height: number\n          }\n\n      export interface Vector2PropInterface {\n        x?: number\n        y?: number\n        width?: number\n        height?: number\n      }\n\n      export interface Vector3PropInterface extends Vector2PropInterface {\n        z?: number\n      }\n\n      export type VectorFlexibleParams = THREE.Vector3 | number[] | Vector3PropInterface | number\n\n\n      let ${key}Instance: ${key};\n      let instanceProps: string[] = [];\n\n      export function normalizeVectorFlexibleParam(value: VectorFlexibleParams): Array<number> {\n        if (typeof value === 'number') {\n          return [value, value, value]\n        }\n        if (value instanceof Vector3) {\n          return [value.x, value.y, value.z]\n        }\n        return value as Array<number>\n      }\n      \n      export function normalizeColor(value: Color | Array<number> | string | number) {\n        if (value instanceof Color) {\n          return value\n        }\n        if (Array.isArray(value)) {\n          return new Color(...value)\n        }\n        return new Color(value)\n      }\n      \n\n      /**\n       * Tres${key}Props\n       * @type {Partial<${key}> & {parentInstance?: ${key}}}\n       * @memberof Tres${key}\n       * @description This is a partial of the ${key} class, with the parentInstance property added.\n       * \n       **/\n      export type Tres${key}Props = Partial<${key}> & {\n        parentInstance?: ${key},\n        /** \n         * \n         * Array of arguments to pass to the ${key} constructor\n         *  \n         * @type {Array<any>}\n         * @memberof Tres${key}Props\n         * @see https://threejs.org/docs/?q=${key}\n         *  \n         **/\n        args?: Array<any>,\n        /**\n         *\n         * Object's local position\n         * \n         * @type {VectorFlexibleParams}\n         * @memberof Tres${key}Props\n        **/\n        position?: VectorFlexibleParams\n      }\n\n      try {\n        ${key}Instance = new ${key}();\n        instanceProps = [...Object.keys(${key}Instance)]\n      } catch (e) {\n      }\n\n      export const Tres${key} = /* #__PURE__ */ defineComponent<Tres${key}Props>({\n        name: 'Tres${key}',\n        props: ['parentInstance', 'args', ...instanceProps] as unknown as undefined,\n        setup(props, { slots, expose, ...rest }) {\n         \n        /*   const cleanedProps = Object.keys(props).reduce((acc, key) => {\n            if (props[key] !== undefined && key !== 'parentInstance') {\n              if( ${key}Instance[key] instanceof Color) {\n                acc[key] = normalizeColor(props[key])\n              } else if ( ${key}Instance[key] instanceof Vector3) {\n                acc[key] = normalizeVectorFlexibleParam(props[key])\n              } else {\n                acc[key] = props[key]\n              }\n            }\n            return acc\n          }, {}) */\n\n          if(props.args) {\n            ${key}Instance = new ${key}(...props.args);\n          } else {\n            ${key}Instance = new ${key}();\n          }\n\n          console.log('instance', {${key}Instance, props, slots: slots.default ? slots.default() : null, rest, type: ${key}.name})\n          expose({${key}Instance})\n\n          function append(parent, child) {\n            const regex = /[A-Z][a-z]+/g\n            const propName = child.type.match(regex).pop().toLowerCase()\n            if (parent[propName]) {\n              parent[propName] = child\n            }\n          }\n      \n          if (props.parentInstance) {\n            append(props.parentInstance, ${key}Instance)\n          }\n\n          const preparedSlots = slots.default \n            // eslint-disable-next-line max-len\n            ? slots.default().map((slot) => { slot.props = { \n              ...slot.props, \n              parentInstance: ${key}Instance }; \n              return slot; \n            })\n            : null\n          return () => {\n            return preparedSlots;\n          };\n        },\n      });\n\n      export default Tres${key};\n    `\n          indexTemplate += `export { default as Tres${key} } from './${key}'\\n`\n          fs.writeFileSync(outputFilePath, template)\n        }\n\n        fs.writeFileSync(join(outputDir, `index.ts`), indexTemplate)\n      }\n    },\n  }\n})\n\nexport const ViteTresPlugin = unplugin.vite\n", "{\n  \"name\": \"@tresjs/core\",\n  \"description\": \"Declarative ThreeJS using Vue Components\",\n  \"version\": \"1.8.1\",\n  \"type\": \"module\",\n  \"author\": \"Alvaro Saburido <hola@alvarosaburido.dev> (https://github.com/alvarosabu/)\",\n  \"files\": [\n    \"dist\"\n  ],\n  \"license\": \"MIT\",\n  \"main\": \"./dist/tres.umd.cjs\",\n  \"module\": \"./dist/tres.js\",\n  \"types\": \"./dist/index.d.ts\",\n  \"exports\": {\n    \".\": {\n      \"import\": \"./dist/tres.js\",\n      \"require\": \"./dist/tres.umd.cjs\"\n    },\n    \"./types\": {\n      \"require\": \"./dist/index.d.ts\",\n      \"import\": \"./dist/index.d.ts\"\n    },\n    \"./styles\": \"./dist/style.css\",\n    \"./*\": \"./dist/tres.js\"\n  },\n  \"publishConfig\": {\n    \"access\": \"public\"\n  },\n  \"keywords\": [\n    \"vue\",\n    \"3d\",\n    \"threejs\",\n    \"three\",\n    \"threejs-vue\"\n  ],\n  \"scripts\": {\n    \"dev\": \"vite\",\n    \"build\": \"vite build\",\n    \"preview\": \"vite preview\",\n    \"test\": \"vitest\",\n    \"test:ci\": \"vitest run\",\n    \"test:ui\": \"vitest --ui\",\n    \"coverage\": \"vitest run --coverage\",\n    \"lint\": \"eslint . --ext .js,.jsx,.ts,.tsx,.vue\",\n    \"changelog\": \"conventional-changelog -p angular -i CHANGELOG.md -s\"\n  },\n  \"peerDependencies\": {\n    \"three\": \"latest\",\n    \"vue\": \"^3.2.47\"\n  },\n  \"dependencies\": {\n    \"@alvarosabu/utils\": \"^2.3.0\",\n    \"@vueuse/core\": \"^9.13.0\"\n  },\n  \"devDependencies\": {\n    \"@tresjs/cientos\": \"workspace:^1.8.0\",\n    \"@types/three\": \"latest\",\n    \"@vitejs/plugin-vue\": \"^4.0.0\",\n    \"@vitest/coverage-c8\": \"^0.28.5\",\n    \"@vitest/ui\": \"^0.28.5\",\n    \"@vue/test-utils\": \"^2.3.0\",\n    \"happy-dom\": \"^8.7.1\",\n    \"jsdom\": \"^21.1.0\",\n    \"kolorist\": \"^1.7.0\",\n    \"pathe\": \"^1.1.0\",\n    \"rollup-plugin-analyzer\": \"^4.0.0\",\n    \"rollup-plugin-visualizer\": \"^5.9.0\",\n    \"three\": \"latest\",\n    \"unplugin-vue-components\": \"^0.24.1\",\n    \"vite\": \"^4.1.4\",\n    \"vite-plugin-banner\": \"^0.7.0\",\n    \"vite-plugin-dts\": \"2.0.0-beta.1\",\n    \"vite-plugin-glsl\": \"^1.1.2\",\n    \"vite-plugin-inspect\": \"^0.7.15\",\n    \"vite-plugin-require-transform\": \"^1.0.9\",\n    \"vitest\": \"^0.28.5\",\n    \"vue-demi\": \"^0.13.11\"\n  }\n}\n"],
  "mappings": "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",
  "names": []
}
