@@ -11,7 +20,7 @@ const [_home, ...restRoutes] = routes
class="
container mx-auto max-w-3xl
font-sans text-xs color-gray
- bg-white
+ bg-white
"
>
@@ -26,7 +35,7 @@ const [_home, ...restRoutes] = routes
src="/logo.svg"
alt="Post-processing logo"
class="max-w-36 sm:max-w-xs align-baseline"
- >
+ />
-
+
diff --git a/playground/src/pages/noise.vue b/playground/src/pages/noise.vue
index d7272d4a..5936c337 100644
--- a/playground/src/pages/noise.vue
+++ b/playground/src/pages/noise.vue
@@ -1,6 +1,6 @@
-
+
diff --git a/src/core/composables/effect.ts b/src/core/composables/effect.ts
index e010e246..c68aafd8 100644
--- a/src/core/composables/effect.ts
+++ b/src/core/composables/effect.ts
@@ -1,10 +1,10 @@
import type { Effect } from 'postprocessing'
import { EffectPass } from 'postprocessing'
-import { inject, onUnmounted, shallowRef, watchEffect, defineExpose } from 'vue'
+import { inject, onUnmounted, shallowRef, watchEffect } from 'vue'
import { useTresContext } from '@tresjs/core'
import { effectComposerInjectionKey } from '../injectionKeys'
-export const useEffect = ( newEffectFunction: () => T) => {
+export const useEffect = (newEffectFunction: () => T) => {
const composer = inject(effectComposerInjectionKey)
const pass = shallowRef(null)
const effect = shallowRef(null)
@@ -12,27 +12,27 @@ export const useEffect = ( newEffectFunction: () => T) => {
const { scene, camera } = useTresContext()
watchEffect(() => {
- if (!camera.value || !effect?.value) return
+ if (!camera.value || !effect?.value) { return }
effect.value.mainCamera = camera.value
})
-
+
let unwatch = () => {} // seperate declaration prevents error in HMR
unwatch = watchEffect(() => {
- if (!camera.value || !composer?.value || !scene.value) return
-
+ if (!camera.value || !composer?.value || !scene.value) { return }
+
unwatch()
- if (effect.value) return
-
+ if (effect.value) { return }
+
effect.value = newEffectFunction()
pass.value = new EffectPass(camera.value, effect.value)
-
+
composer.value.addPass(pass.value)
})
onUnmounted(() => {
- if (pass.value) composer?.value?.removePass(pass.value)
+ if (pass.value) { composer?.value?.removePass(pass.value) }
effect.value?.dispose()
pass.value?.dispose()
})
@@ -41,4 +41,4 @@ export const useEffect = ( newEffectFunction: () => T) => {
pass,
effect,
}
-}
\ No newline at end of file
+}
diff --git a/src/core/effects/Bloom.vue b/src/core/effects/Bloom.vue
index 84de2852..72f04ebe 100644
--- a/src/core/effects/Bloom.vue
+++ b/src/core/effects/Bloom.vue
@@ -1,6 +1,6 @@
-
-
diff --git a/src/core/effects/DepthOfField.vue b/src/core/effects/DepthOfField.vue
index 4e9d9e7f..39326cfb 100644
--- a/src/core/effects/DepthOfField.vue
+++ b/src/core/effects/DepthOfField.vue
@@ -43,25 +43,23 @@ export interface DepthOfFieldProps {
const props = defineProps()
const { camera } = useTresContext()
-
+
const { pass, effect } = useEffect(() => new DepthOfFieldEffect(camera.value, props))
defineExpose({ pass, effect }) // to allow users to modify pass and effect via template ref
makePropWatchers(
[
// blendFunction is not updated, because it has no setter in BloomEffect
- [ () => props.worldFocusDistance, 'circleOfConfusionMaterial.worldFocusDistance'],
- [ () => props.focusDistance, 'circleOfConfusionMaterial.focusDistance' ],
- [ () => props.worldFocusRange, 'circleOfConfusionMaterial.worldFocusRange'],
- [ () => props.focusRange, 'circleOfConfusionMaterial.focusRange'],
- [ () => props.bokehScale, 'bokehScale'],
- [ () => props.resolutionScale, 'blurPass.resolution.scale'],
- [ () => props.resolutionX, 'resolution.width'],
- [ () => props.resolutionY, 'resolution.height'],
- ],
+ [() => props.worldFocusDistance, 'circleOfConfusionMaterial.worldFocusDistance'],
+ [() => props.focusDistance, 'circleOfConfusionMaterial.focusDistance'],
+ [() => props.worldFocusRange, 'circleOfConfusionMaterial.worldFocusRange'],
+ [() => props.focusRange, 'circleOfConfusionMaterial.focusRange'],
+ [() => props.bokehScale, 'bokehScale'],
+ [() => props.resolutionScale, 'blurPass.resolution.scale'],
+ [() => props.resolutionX, 'resolution.width'],
+ [() => props.resolutionY, 'resolution.height'],
+ ],
effect,
() => new DepthOfFieldEffect(),
)
-
-
\ No newline at end of file
diff --git a/src/core/effects/Glitch.vue b/src/core/effects/Glitch.vue
index a24fd344..72aa9b10 100644
--- a/src/core/effects/Glitch.vue
+++ b/src/core/effects/Glitch.vue
@@ -1,8 +1,8 @@
-
-
diff --git a/src/core/effects/Noise.vue b/src/core/effects/Noise.vue
index 9b2997f4..57da7616 100644
--- a/src/core/effects/Noise.vue
+++ b/src/core/effects/Noise.vue
@@ -26,5 +26,3 @@ makePropWatchersUsingAllProps(
() => new NoiseEffect(),
)
-
-
diff --git a/src/core/effects/Outline.vue b/src/core/effects/Outline.vue
index 7499a306..5de9556e 100644
--- a/src/core/effects/Outline.vue
+++ b/src/core/effects/Outline.vue
@@ -1,7 +1,7 @@
-
-
diff --git a/src/core/effects/Pixelation.vue b/src/core/effects/Pixelation.vue
index c7a103ee..c5fcc518 100644
--- a/src/core/effects/Pixelation.vue
+++ b/src/core/effects/Pixelation.vue
@@ -21,5 +21,3 @@ makePropWatchersUsingAllProps(
() => new PixelationEffect(),
)
-
-
diff --git a/src/core/effects/Vignette.vue b/src/core/effects/Vignette.vue
index 4e512ebf..7d9be8fe 100644
--- a/src/core/effects/Vignette.vue
+++ b/src/core/effects/Vignette.vue
@@ -30,5 +30,3 @@ makePropWatchersUsingAllProps(
() => new VignetteEffect(),
)
-
-
diff --git a/src/core/injectionKeys.ts b/src/core/injectionKeys.ts
index 75ee62ff..c64598b5 100644
--- a/src/core/injectionKeys.ts
+++ b/src/core/injectionKeys.ts
@@ -1,4 +1,4 @@
import type { EffectComposer } from 'postprocessing'
import type { InjectionKey, ShallowRef } from 'vue'
-export const effectComposerInjectionKey: InjectionKey> = Symbol()
+export const effectComposerInjectionKey: InjectionKey> = Symbol('effectComposer')
diff --git a/src/index.ts b/src/index.ts
index 4af89488..c7e8ad25 100644
--- a/src/index.ts
+++ b/src/index.ts
@@ -9,9 +9,9 @@ import Noise from './core/effects/Noise.vue'
import { useEffect } from './core/composables/effect.ts'
-export {
+export {
Bloom,
- DepthOfField,
+ DepthOfField,
EffectComposer,
Glitch,
Noise,
diff --git a/src/util/object.ts b/src/util/object.ts
index 0e0c9e9e..e21acccc 100644
--- a/src/util/object.ts
+++ b/src/util/object.ts
@@ -2,24 +2,24 @@ const pathRegex = /([^[.\]])+/g
/**
* Retrieves the value at a given path within a provided object.
- *
+ *
* @template T - The type of value to be returned
- *
+ *
* @param {any} obj - The object to extract value from
* @param {string | string[]} path - A path or an array of path where the value should be get from
- *
+ *
* @returns {T | undefined} - The value at the given path in the object, or undefined if path is not found
- *
+ *
* @example
- *
+ *
* const obj = { a: { b: { c: 1 } } }
- *
+ *
* const result = get(obj, 'a.b.c')
- *
+ *
* console.log(result) // 1
- */
+ */
export const get = (obj: any, path: string | string[]): T | undefined => {
- if (!path) return undefined
+ if (!path) { return undefined }
const pathArray = Array.isArray(path) ? path : path.match(pathRegex)
@@ -28,51 +28,52 @@ export const get = (obj: any, path: string | string[]): T | undefined => {
/**
* Sets a value at a given path within a provided object. If the path does not exist, nested objects will be created.
- *
+ *
* @param {any} obj - The original object to set value in
* @param {string | string[]} path - A path or an array of path where the value should be set
* @param {any} value - The value to be set at the provided path
- *
+ *
* @returns {void}
- *
+ *
* @example
* const obj = { a: { b: { c: 1 } } }
- *
+ *
* set(obj, 'a.b.c', 2)
- *
+ *
* console.log(obj) // { a: { b: { c: 2 } } }
- */
+ */
export const set = (obj: any, path: string | string[], value: any): void => {
const pathArray = Array.isArray(path) ? path : path.match(pathRegex)
- if (pathArray)
+ if (pathArray) {
pathArray.reduce((acc, key, i) => {
- if (acc[key] === undefined) acc[key] = {}
- if (i === pathArray.length - 1) acc[key] = value
+ if (acc[key] === undefined) { acc[key] = {} }
+ if (i === pathArray.length - 1) { acc[key] = value }
return acc[key]
}, obj)
+ }
}
/**
* Omits given properties from a provided object.
- *
+ *
* @template T - An object with string keys and any type of values
*
* @param {T} obj - The original object to omit properties from
* @param {(keyof T)[]} properties - An array of property key names to omit from the base object
- *
+ *
* @returns {Partial} The new object with omitted properties
- *
+ *
* @example
* const obj = { a: 1, b: 2, c: 3 }
* const propsToOmit = ['b', 'c']
- *
+ *
* const newObj = omit(obj, propsToOmit)
- *
+ *
* console.log(newObj) // { a: 1 }
*/
export const omit = >(obj: T, properties: (keyof T)[]): Partial => {
const newObj = { ...obj }
properties.forEach(prop => delete newObj[prop])
return newObj
-}
\ No newline at end of file
+}
diff --git a/src/util/prop.ts b/src/util/prop.ts
index 337172b2..15be378e 100644
--- a/src/util/prop.ts
+++ b/src/util/prop.ts
@@ -1,10 +1,10 @@
import type { Ref, WatchOptions } from 'vue'
import { watch } from 'vue'
-import { set, get } from './object'
+import { get, set } from './object'
/**
* Creates a prop watcher function that monitors changes to a property and updates a target object.
- *
+ *
* @template T - The type of the property being watched.
* @template E - The type of the target object.
* @param {() => T} propGetter - A function that retrieves the prop value to be watched.
@@ -17,23 +17,20 @@ export const makePropWatcher = (
propGetter: () => T,
target: Ref,
propertyPath: string,
- newPlainObjectFunction: () => E & { dispose?(): void },
+ newPlainObjectFunction: () => E & { dispose?: () => void },
watchOptions: WatchOptions = {},
-) =>
- watch(propGetter, (newValue) => {
- if (!target.value) return
-
- if (newValue === undefined) {
- const plainObject = newPlainObjectFunction()
+) => watch(propGetter, (newValue) => {
+ if (!target.value) { return }
+
+ if (newValue === undefined) {
+ const plainObject = newPlainObjectFunction()
- set(target.value, propertyPath, get(plainObject, propertyPath))
+ set(target.value, propertyPath, get(plainObject, propertyPath))
- plainObject.dispose?.()
- }
- else
- set(target.value, propertyPath, propGetter())
- },
- watchOptions)
+ plainObject.dispose?.()
+ }
+ else { set(target.value, propertyPath, propGetter()) }
+ }, watchOptions)
/**
* Creates multiple prop watchers for monitoring changes to multiple properties and updating a target object.
@@ -47,16 +44,18 @@ export const makePropWatcher = (
export const makePropWatchers = (
propGettersAndPropertyPaths: (string | (() => any))[][],
target: Ref,
- newPlainObjectFunction: () => E & { dispose?(): void },
-) =>
- propGettersAndPropertyPaths.map(([propGetterFn, path]) => makePropWatcher(
- propGetterFn as () => any, target, path as string, newPlainObjectFunction,
- ))
+ newPlainObjectFunction: () => E & { dispose?: () => void },
+) => propGettersAndPropertyPaths.map(([propGetterFn, path]) => makePropWatcher(
+ propGetterFn as () => any,
+ target,
+ path as string,
+ newPlainObjectFunction,
+ ))
/**
* Creates multiple prop watchers via the props object for monitoring changes to multiple properties and updating a target object.
* Use this method in case the prop names match the names of the properties you want to set on your target object.
- *
+ *
* @param props - The props object. Usually created via defineProps.
* @param {Ref} target - A Ref representing the target object to be updated.
* @param {() => E & { dispose?(): void }} newPlainObjectFunction - A function that creates a new plain object to retrieve the defaults from with an optional "dispose" method for cleanup.
@@ -64,10 +63,10 @@ export const makePropWatchers = (
export const makePropWatchersUsingAllProps = (
props: { [key: string]: any },
target: Ref,
- newPlainObjectFunction: () => E & { dispose?(): void }) =>
- Object.keys(props).map(key => makePropWatcher(
- () => props[key],
- target,
- key,
- newPlainObjectFunction,
- ))
\ No newline at end of file
+ newPlainObjectFunction: () => E & { dispose?: () => void },
+) => Object.keys(props).map(key => makePropWatcher(
+ () => props[key],
+ target,
+ key,
+ newPlainObjectFunction,
+ ))
diff --git a/src/vite-env.d.ts b/src/vite-env.d.ts
index aafef950..11f02fe2 100644
--- a/src/vite-env.d.ts
+++ b/src/vite-env.d.ts
@@ -1,8 +1 @@
///
-
-declare module '*.vue' {
- import type { DefineComponent } from 'vue'
- // eslint-disable-next-line @typescript-eslint/no-explicit-any, @typescript-eslint/ban-types
- const component: DefineComponent<{}, {}, any>
- export default component
-}
diff --git a/tsconfig.json b/tsconfig.json
index 7a303f6b..01af4568 100644
--- a/tsconfig.json
+++ b/tsconfig.json
@@ -1,27 +1,27 @@
{
"compilerOptions": {
- "baseUrl": ".",
+ "incremental": false,
"target": "esnext",
+ "jsx": "preserve",
+ "lib": ["esnext", "dom"],
+ "baseUrl": ".",
"module": "esnext",
"moduleResolution": "node",
- "strict": true,
- "jsx": "preserve",
- "sourceMap": true,
+ "paths": {
+ "/@/*": ["src/*"]
+ },
"resolveJsonModule": true,
- "esModuleInterop": true,
- "lib": ["esnext", "dom"],
"types": ["vite/client"],
- "incremental": false,
- "skipLibCheck": true,
- "noUnusedLocals": false,
+ "strict": true,
"strictNullChecks": true,
- "forceConsistentCasingInFileNames": true,
+ "noUnusedLocals": false,
"declaration": true,
- "paths": {
- "/@/*": ["src/*"]
- }
+ "sourceMap": true,
+ "esModuleInterop": true,
+ "forceConsistentCasingInFileNames": true,
+ "skipLibCheck": true
},
+ "references": [{ "path": "./tsconfig.node.json" }],
"include": ["src/**/*.ts", "src/**/*.d.ts", "src/**/*.tsx", "src/**/*.vue"],
- "exclude": ["dist", "node_modules", "src/**/*.cy.ts", "src/**/*.test.ts"],
- "references": [{ "path": "./tsconfig.node.json" }]
+ "exclude": ["dist", "node_modules", "src/**/*.cy.ts", "src/**/*.test.ts"]
}
diff --git a/vite.config.ts b/vite.config.ts
index 4ce56460..3d210604 100644
--- a/vite.config.ts
+++ b/vite.config.ts
@@ -7,7 +7,7 @@ import analyze from 'rollup-plugin-analyzer'
import { visualizer } from 'rollup-plugin-visualizer'
import { resolve } from 'pathe'
-import { lightGreen, magenta, gray, bold } from 'kolorist'
+import { bold, gray, lightGreen, magenta } from 'kolorist'
import pkg from './package.json'
@@ -68,9 +68,9 @@ export default defineConfig({
// for externalized deps
globals: {
'@tresjs/core': 'TresjsCore',
- three: 'Three',
- vue: 'Vue',
- postprocessing: 'Postprocessing',
+ 'three': 'Three',
+ 'vue': 'Vue',
+ 'postprocessing': 'Postprocessing',
'@vueuse/core': 'VueUseCore',
},
},
diff --git a/vite.config.ts.timestamp-1695304641367-06bf84dd0bc62.mjs b/vite.config.ts.timestamp-1695304641367-06bf84dd0bc62.mjs
deleted file mode 100644
index ea074355..00000000
--- a/vite.config.ts.timestamp-1695304641367-06bf84dd0bc62.mjs
+++ /dev/null
@@ -1,165 +0,0 @@
-// vite.config.ts
-import { defineConfig } from "file:///Users/tino/Code/tresjs/post-processing/node_modules/.pnpm/vite@4.3.9/node_modules/vite/dist/node/index.js";
-import vue from "file:///Users/tino/Code/tresjs/post-processing/node_modules/.pnpm/@vitejs+plugin-vue@4.2.3_vite@4.3.9_vue@3.3.4/node_modules/@vitejs/plugin-vue/dist/index.mjs";
-import banner from "file:///Users/tino/Code/tresjs/post-processing/node_modules/.pnpm/vite-plugin-banner@0.7.0/node_modules/vite-plugin-banner/dist/index.mjs";
-import dts from "file:///Users/tino/Code/tresjs/post-processing/node_modules/.pnpm/vite-plugin-dts@2.3.0_vite@4.3.9/node_modules/vite-plugin-dts/dist/index.mjs";
-import analyze from "file:///Users/tino/Code/tresjs/post-processing/node_modules/.pnpm/rollup-plugin-analyzer@4.0.0/node_modules/rollup-plugin-analyzer/index.js";
-import { visualizer } from "file:///Users/tino/Code/tresjs/post-processing/node_modules/.pnpm/rollup-plugin-visualizer@5.9.2/node_modules/rollup-plugin-visualizer/dist/plugin/index.js";
-import { resolve } from "file:///Users/tino/Code/tresjs/post-processing/node_modules/.pnpm/pathe@1.1.1/node_modules/pathe/dist/index.mjs";
-import { lightGreen, magenta, gray, bold } from "file:///Users/tino/Code/tresjs/post-processing/node_modules/.pnpm/kolorist@1.8.0/node_modules/kolorist/dist/esm/index.mjs";
-
-// package.json
-var package_default = {
- name: "@tresjs/post-processing",
- description: "Post-processing library for TresJS",
- version: "0.4.0",
- type: "module",
- author: "Alvaro Saburido (https://github.com/alvarosabu/)",
- files: [
- "dist",
- "*.d.ts"
- ],
- license: "MIT",
- main: "./dist/tres-postprocessing.js",
- module: "./dist/tres-postprocessing.js",
- exports: {
- ".": {
- types: "./dist/index.d.ts",
- import: "./dist/tres-postprocessing.js"
- },
- "./*": "./*"
- },
- publishConfig: {
- access: "public"
- },
- keywords: [
- "vue",
- "3d",
- "threejs",
- "three",
- "post-processing",
- "effects",
- "fx"
- ],
- scripts: {
- dev: "vite",
- playground: "cd playground && npm run dev",
- build: "vite build",
- preview: "vite preview",
- release: "release-it",
- lint: "eslint . --ext .js,.jsx,.ts,.tsx,.vue",
- "lint:fix": "pnpm run lint --fix",
- "docs:dev": "vitepress dev docs",
- "docs:build": "vitepress build docs",
- "docs:preview": "vitepress preview docs"
- },
- peerDependencies: {
- three: ">=0.133",
- vue: ">=3.3"
- },
- dependencies: {
- "@tresjs/core": "^3.0.1",
- "@vueuse/core": "^10.2.0",
- postprocessing: "^6.32.1",
- "three-stdlib": "^2.23.10"
- },
- devDependencies: {
- "@release-it/conventional-changelog": "^5.1.1",
- "@tresjs/eslint-config-vue": "^0.2.0",
- "@types/three": "^0.152.1",
- "@vitejs/plugin-vue": "^4.2.3",
- gsap: "^3.12.1",
- kolorist: "^1.8.0",
- pathe: "^1.1.1",
- prettier: "^2.8.8",
- "release-it": "^15.11.0",
- "rollup-plugin-analyzer": "^4.0.0",
- "rollup-plugin-visualizer": "^5.9.2",
- three: "^0.153.0",
- typescript: "^5.1.3",
- unocss: "^0.53.3",
- vite: "^4.3.9",
- "vite-plugin-banner": "^0.7.0",
- "vite-plugin-dts": "2.3.0",
- "vite-svg-loader": "^4.0.0",
- vitepress: "1.0.0-beta.3",
- vue: "^3.3.4",
- "vue-tsc": "^1.8.1"
- }
-};
-
-// vite.config.ts
-var __vite_injected_original_dirname = "/Users/tino/Code/tresjs/post-processing";
-console.log(`${lightGreen("\u25B2")} ${gray("\u25A0")} ${magenta("\u{1D5EB}")} ${bold("Tres/post-processing")} v${package_default.version}`);
-var vite_config_default = defineConfig({
- resolve: {
- alias: {
- "/@": resolve(__vite_injected_original_dirname, "./src")
- },
- dedupe: ["@tresjs/core"]
- },
- plugins: [
- vue({
- script: {
- propsDestructure: true
- },
- template: {
- compilerOptions: {
- isCustomElement: (tag) => tag.startsWith("Tres") && tag !== "TresCanvas"
- }
- }
- }),
- dts({
- insertTypesEntry: true
- }),
- banner({
- content: `/**
- * name: ${package_default.name}
- * version: v${package_default.version}
- * (c) ${(/* @__PURE__ */ new Date()).getFullYear()}
- * description: ${package_default.description}
- * author: ${package_default.author}
- */`
- })
- ],
- build: {
- lib: {
- entry: resolve(__vite_injected_original_dirname, "src/index.ts"),
- name: "tres-postprocessing",
- fileName: "tres-postprocessing"
- },
- copyPublicDir: false,
- watch: {
- include: [resolve(__vite_injected_original_dirname, "src")]
- },
- rollupOptions: {
- plugins: [
- analyze(),
- visualizer({
- gzipSize: true,
- brotliSize: true,
- open: false
- })
- ],
- external: ["three", "vue", "@tresjs/core", "postprocessing"],
- output: {
- exports: "named",
- // Provide global variables to use in the UMD build
- // for externalized deps
- globals: {
- "@tresjs/core": "TresjsCore",
- three: "Three",
- vue: "Vue",
- postprocessing: "Postprocessing"
- }
- }
- }
- },
- optimizeDeps: {
- exclude: ["three", "vue", "@tresjs/core", "postprocessing"]
- }
-});
-export {
- vite_config_default as default
-};
-//# sourceMappingURL=data:application/json;base64,{
  "version": 3,
  "sources": ["vite.config.ts", "package.json"],
  "sourcesContent": ["const __vite_injected_original_dirname = \"/Users/tino/Code/tresjs/post-processing\";const __vite_injected_original_filename = \"/Users/tino/Code/tresjs/post-processing/vite.config.ts\";const __vite_injected_original_import_meta_url = \"file:///Users/tino/Code/tresjs/post-processing/vite.config.ts\";import { defineConfig } from 'vite'\nimport vue from '@vitejs/plugin-vue'\n\nimport banner from 'vite-plugin-banner'\nimport dts from 'vite-plugin-dts'\nimport analyze from 'rollup-plugin-analyzer'\nimport { visualizer } from 'rollup-plugin-visualizer'\nimport { resolve } from 'pathe'\n\nimport { lightGreen, magenta, gray, bold } from 'kolorist'\n\nimport pkg from './package.json'\n\n// eslint-disable-next-line no-console\nconsole.log(`${lightGreen('\u25B2')} ${gray('\u25A0')} ${magenta('\uD835\uDDEB')} ${bold('Tres/post-processing')} v${pkg.version}`)\n\n// https://vitejs.dev/config/\nexport default defineConfig({\n  resolve: {\n    alias: {\n      '/@': resolve(__dirname, './src'),\n    },\n    dedupe: ['@tresjs/core'],\n  },\n  plugins: [\n    vue({\n      script: {\n        propsDestructure: true,\n      },\n      template: {\n        compilerOptions: {\n          isCustomElement: tag => tag.startsWith('Tres') && tag !== 'TresCanvas',\n        },\n      },\n    }),\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  ],\n  build: {\n    lib: {\n      entry: resolve(__dirname, 'src/index.ts'),\n      name: 'tres-postprocessing',\n      fileName: 'tres-postprocessing',\n    },\n    copyPublicDir: false,\n    watch: {\n      include: [resolve(__dirname, 'src')],\n    },\n    rollupOptions: {\n      plugins: [\n        analyze(),\n        visualizer({\n          gzipSize: true,\n          brotliSize: true,\n          open: false,\n        }),\n      ],\n      external: ['three', 'vue', '@tresjs/core', 'postprocessing'],\n      output: {\n        exports: 'named',\n        // Provide global variables to use in the UMD build\n        // for externalized deps\n        globals: {\n          '@tresjs/core': 'TresjsCore',\n          three: 'Three',\n          vue: 'Vue',\n          postprocessing: 'Postprocessing',\n        },\n      },\n    },\n  },\n  optimizeDeps: {\n    exclude: ['three', 'vue', '@tresjs/core', 'postprocessing'],\n  },\n})\n", "{\n  \"name\": \"@tresjs/post-processing\",\n  \"description\": \"Post-processing library for TresJS\",\n  \"version\": \"0.4.0\",\n  \"type\": \"module\",\n  \"author\": \"Alvaro Saburido <hola@alvarosaburido.dev> (https://github.com/alvarosabu/)\",\n  \"files\": [\n    \"dist\",\n    \"*.d.ts\"\n  ],\n  \"license\": \"MIT\",\n  \"main\": \"./dist/tres-postprocessing.js\",\n  \"module\": \"./dist/tres-postprocessing.js\",\n  \"exports\": {\n    \".\": {\n      \"types\": \"./dist/index.d.ts\",\n      \"import\": \"./dist/tres-postprocessing.js\"\n    },\n    \"./*\": \"./*\"\n  },\n  \"publishConfig\": {\n    \"access\": \"public\"\n  },\n  \"keywords\": [\n    \"vue\",\n    \"3d\",\n    \"threejs\",\n    \"three\",\n    \"post-processing\",\n    \"effects\",\n    \"fx\"\n  ],\n  \"scripts\": {\n    \"dev\": \"vite\",\n    \"playground\": \"cd playground && npm run dev\",\n    \"build\": \"vite build\",\n    \"preview\": \"vite preview\",\n    \"release\": \"release-it\",\n    \"lint\": \"eslint . --ext .js,.jsx,.ts,.tsx,.vue\",\n    \"lint:fix\": \"pnpm run lint --fix\",\n    \"docs:dev\": \"vitepress dev docs\",\n    \"docs:build\": \"vitepress build docs\",\n    \"docs:preview\": \"vitepress preview docs\"\n  },\n  \"peerDependencies\": {\n    \"three\": \">=0.133\",\n    \"vue\": \">=3.3\"\n  },\n  \"dependencies\": {\n    \"@tresjs/core\": \"^3.0.1\",\n    \"@vueuse/core\": \"^10.2.0\",\n    \"postprocessing\": \"^6.32.1\",\n    \"three-stdlib\": \"^2.23.10\"\n  },\n  \"devDependencies\": {\n    \"@release-it/conventional-changelog\": \"^5.1.1\",\n    \"@tresjs/eslint-config-vue\": \"^0.2.0\",\n    \"@types/three\": \"^0.152.1\",\n    \"@vitejs/plugin-vue\": \"^4.2.3\",\n    \"gsap\": \"^3.12.1\",\n    \"kolorist\": \"^1.8.0\",\n    \"pathe\": \"^1.1.1\",\n    \"prettier\": \"^2.8.8\",\n    \"release-it\": \"^15.11.0\",\n    \"rollup-plugin-analyzer\": \"^4.0.0\",\n    \"rollup-plugin-visualizer\": \"^5.9.2\",\n    \"three\": \"^0.153.0\",\n    \"typescript\": \"^5.1.3\",\n    \"unocss\": \"^0.53.3\",\n    \"vite\": \"^4.3.9\",\n    \"vite-plugin-banner\": \"^0.7.0\",\n    \"vite-plugin-dts\": \"2.3.0\",\n    \"vite-svg-loader\": \"^4.0.0\",\n    \"vitepress\": \"1.0.0-beta.3\",\n    \"vue\": \"^3.3.4\",\n    \"vue-tsc\": \"^1.8.1\"\n  }\n}\n"],
  "mappings": "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",
  "names": []
}
